mirror of
https://github.com/lyx0/nourybot.git
synced 2024-11-13 19:49:55 +01:00
add twitch helix client
This commit is contained in:
parent
3f49874886
commit
f5d6eca30c
|
@ -13,12 +13,16 @@ import (
|
||||||
_ "github.com/lib/pq"
|
_ "github.com/lib/pq"
|
||||||
"github.com/lyx0/nourybot/internal/data"
|
"github.com/lyx0/nourybot/internal/data"
|
||||||
"github.com/lyx0/nourybot/pkg/common"
|
"github.com/lyx0/nourybot/pkg/common"
|
||||||
|
"github.com/nicklaw5/helix"
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
)
|
)
|
||||||
|
|
||||||
type config struct {
|
type config struct {
|
||||||
twitchUsername string
|
twitchUsername string
|
||||||
twitchOauth string
|
twitchOauth string
|
||||||
|
twitchClientId string
|
||||||
|
twitchClientSecret string
|
||||||
|
twitchAccessToken string
|
||||||
commandPrefix string
|
commandPrefix string
|
||||||
environment string
|
environment string
|
||||||
db struct {
|
db struct {
|
||||||
|
@ -31,6 +35,7 @@ type config struct {
|
||||||
|
|
||||||
type Application struct {
|
type Application struct {
|
||||||
TwitchClient *twitch.Client
|
TwitchClient *twitch.Client
|
||||||
|
HelixClient *helix.Client
|
||||||
Logger *zap.SugaredLogger
|
Logger *zap.SugaredLogger
|
||||||
Db *sql.DB
|
Db *sql.DB
|
||||||
Models data.Models
|
Models data.Models
|
||||||
|
@ -53,6 +58,9 @@ func main() {
|
||||||
// Twitch
|
// Twitch
|
||||||
cfg.twitchUsername = os.Getenv("TWITCH_USERNAME")
|
cfg.twitchUsername = os.Getenv("TWITCH_USERNAME")
|
||||||
cfg.twitchOauth = os.Getenv("TWITCH_OAUTH")
|
cfg.twitchOauth = os.Getenv("TWITCH_OAUTH")
|
||||||
|
cfg.twitchClientId = os.Getenv("TWITCH_CLIENT_ID")
|
||||||
|
cfg.twitchClientSecret = os.Getenv("TWITCH_CLIENT_SECRET")
|
||||||
|
cfg.twitchAccessToken = os.Getenv("TWITCH_ACCESS_TOKEN")
|
||||||
cfg.commandPrefix = os.Getenv("TWITCH_COMMAND_PREFIX")
|
cfg.commandPrefix = os.Getenv("TWITCH_COMMAND_PREFIX")
|
||||||
tc := twitch.NewClient(cfg.twitchUsername, cfg.twitchOauth)
|
tc := twitch.NewClient(cfg.twitchUsername, cfg.twitchOauth)
|
||||||
|
|
||||||
|
@ -65,6 +73,23 @@ func main() {
|
||||||
cfg.db.maxIdleConns = 25
|
cfg.db.maxIdleConns = 25
|
||||||
cfg.db.maxIdleTime = "15m"
|
cfg.db.maxIdleTime = "15m"
|
||||||
|
|
||||||
|
helixClient, err := helix.NewClient(&helix.Options{
|
||||||
|
ClientID: cfg.twitchClientId,
|
||||||
|
ClientSecret: cfg.twitchClientSecret,
|
||||||
|
AppAccessToken: cfg.twitchAccessToken,
|
||||||
|
// ClientID: cfg.twitchClientId,
|
||||||
|
})
|
||||||
|
helixResp, err := helixClient.GetUsers(&helix.UsersParams{
|
||||||
|
IDs: []string{"596581605", "31437432"},
|
||||||
|
Logins: []string{"nourybot", "nourylul"},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
sugar.Errorw("Helix: Error getting user data",
|
||||||
|
"helixResp", helixResp,
|
||||||
|
"err", err,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
// Establish database connection
|
// Establish database connection
|
||||||
db, err := openDB(cfg)
|
db, err := openDB(cfg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -76,6 +101,7 @@ func main() {
|
||||||
// Initialize Application
|
// Initialize Application
|
||||||
app := &Application{
|
app := &Application{
|
||||||
TwitchClient: tc,
|
TwitchClient: tc,
|
||||||
|
HelixClient: helixClient,
|
||||||
Logger: sugar,
|
Logger: sugar,
|
||||||
Db: db,
|
Db: db,
|
||||||
Models: data.NewModels(db),
|
Models: data.NewModels(db),
|
||||||
|
@ -132,6 +158,7 @@ func main() {
|
||||||
"Database Idle Conns", cfg.db.maxIdleConns,
|
"Database Idle Conns", cfg.db.maxIdleConns,
|
||||||
"Database Idle Time", cfg.db.maxIdleTime,
|
"Database Idle Time", cfg.db.maxIdleTime,
|
||||||
"Database", db.Stats(),
|
"Database", db.Stats(),
|
||||||
|
"Helix", helixResp,
|
||||||
)
|
)
|
||||||
|
|
||||||
// Start time
|
// Start time
|
||||||
|
|
Loading…
Reference in a new issue