web3_onlyfans/services/api/main.go

66 lines
2.1 KiB
Go
Raw Normal View History

2025-01-23 13:06:36 +03:00
package main
import (
2025-01-23 13:11:39 +03:00
"log"
"net/http"
"os"
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
"github.com/gorilla/mux"
"web3-onlyfans/services/api/internal/handlers"
"web3-onlyfans/services/api/internal/utils"
"web3-onlyfans/services/api/internal/neo"
2025-01-23 13:06:36 +03:00
)
func main() {
2025-01-23 13:11:39 +03:00
// Загружаем конфиг (примерно)
configPath := os.Getenv("API_CONFIG_PATH")
if configPath == "" {
configPath = "./config.yaml"
}
cfg, err := utils.LoadConfig(configPath)
if err != nil {
log.Fatalf("failed to load config: %v", err)
}
// Инициализируем логгер
logger := utils.NewLogger(cfg.LogLevel)
// Инициализируем NeoClient (RPC + кошелёк)
neoCli, err := neo.NewNeoClient(cfg.NeoRPC, cfg.WalletPath, cfg.WalletPass)
if err != nil {
logger.Fatalf("failed to init neo client: %v", err)
}
// Роуты
r := mux.NewRouter()
// NFT endpoints
r.HandleFunc("/nft/mint", func(w http.ResponseWriter, r *http.Request) {
handlers.MintNFTHandler(w, r, neoCli, logger, cfg)
}).Methods("POST")
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
r.HandleFunc("/nft/properties", func(w http.ResponseWriter, r *http.Request) {
handlers.NFTPropertiesHandler(w, r, neoCli, logger, cfg)
}).Methods("GET")
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
// Market endpoints
r.HandleFunc("/market/list", func(w http.ResponseWriter, r *http.Request) {
handlers.MarketListHandler(w, r, neoCli, logger, cfg)
}).Methods("GET")
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
r.HandleFunc("/market/buy", func(w http.ResponseWriter, r *http.Request) {
handlers.MarketBuyHandler(w, r, neoCli, logger, cfg)
}).Methods("POST")
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
// Token endpoints (например, посмотреть баланс)
r.HandleFunc("/token/balance", func(w http.ResponseWriter, r *http.Request) {
handlers.TokenBalanceHandler(w, r, neoCli, logger, cfg)
}).Methods("GET")
2025-01-23 13:06:36 +03:00
2025-01-23 13:11:39 +03:00
// Запуск сервера
addr := cfg.ListenAddr
logger.Infof("API starting on %s", addr)
if err := http.ListenAndServe(addr, r); err != nil {
logger.Fatalf("server error: %v", err)
}
2025-01-23 13:06:36 +03:00
}