return nil, NewInternalError(err)
}
- if config.Config["key"] == "" || config.Config["secret"] == "" {
- return nil, &Error{InvalidMarketCredentials, "no market credentials", fmt.Errorf("market credentials are empty for marketId '%v'", q.In.Market)}
+ if config == nil || config.Config["key"] == "" || config.Config["secret"] == "" {
+ return nil, &Error{MarketCredentialsNotConfigured, "no market credentials", fmt.Errorf("market credentials are empty for marketId '%v'", q.In.Market)}
}
- resultErr := CallExternalService(fmt.Sprintf("'%s' GetBalanceValue", q.In.Market), EXTERNAL_SERVICE_TIMEOUT_SECONDS*time.Second, func() *Error {
+ resultErr := CallExternalService(fmt.Sprintf("'%s' TestCredentials", q.In.Market), EXTERNAL_SERVICE_TIMEOUT_SECONDS*time.Second, func() error {
err := Poloniex.TestCredentials(config.Config["key"], config.Config["secret"])
if utils.ErrIs(err, markets.InvalidCredentials) {
})
if resultErr != nil {
- return nil, resultErr
+ return nil, NewInternalError(resultErr)
}
return nil, nil
configMap["secret"] = q.In.Secret
}
- _, err := db.SetUserMarketConfig(q.In.User.Id, q.In.Market, configMap)
+ marketConfig, err := db.SetUserMarketConfig(q.In.User.Id, q.In.Market, configMap)
+ if err != nil {
+ return nil, NewInternalError(err)
+ }
+
+ resultErr := CallExternalService(fmt.Sprintf("'%s' TestCredentials", q.In.Market), EXTERNAL_SERVICE_TIMEOUT_SECONDS*time.Second, func() error {
+ err := Poloniex.TestCredentials(marketConfig.Config["key"], marketConfig.Config["secret"])
+
+ if utils.ErrIs(err, markets.InvalidCredentials) {
+ return &Error{InvalidMarketCredentials, "wrong market credentials", fmt.Errorf("wrong '%v' market credentials", q.In.Market)}
+ }
+
+ if utils.ErrIs(err, markets.IPRestricted) {
+ return &Error{IPRestrictedApiKey, "ip restricted api key", fmt.Errorf("'%v' ip restricted", q.In.Market)}
+ }
+
+ if err != nil {
+ return NewInternalError(err)
+ }
+
+ return nil
+ })
+
+ var newStatus db.MarketConfigStatus = db.MarketConfigEnabled
+
+ if ErrorIs(resultErr, InvalidMarketCredentials) || ErrorIs(resultErr, IPRestrictedApiKey) {
+ newStatus = db.MarketConfigInvalidCredentials
+ } else if resultErr != nil {
+ return nil, NewInternalError(resultErr)
+ }
+
+ marketConfig, err = db.SetMarketConfigStatus(*marketConfig, newStatus)
if err != nil {
return nil, NewInternalError(err)
}