"strings"
"time"
+ "git.immae.eu/Cryptoportfolio/Front.git/db"
+ "git.immae.eu/Cryptoportfolio/Front.git/markets"
"github.com/jloup/utils"
- "immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front/db"
- "immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front/markets"
)
type MarketConfigQuery struct {
}
if config == nil || 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)}
+ return nil, &Error{MarketCredentialsNotConfigured, "no market credentials", fmt.Errorf("market credentials are empty for marketId '%v'", q.In.Market)}
}
resultErr := CallExternalService(fmt.Sprintf("'%s' TestCredentials", q.In.Market), EXTERNAL_SERVICE_TIMEOUT_SECONDS*time.Second, func() error {
return nil
})
- if resultErr != nil {
+ var newStatus db.MarketConfigStatus = config.Status
+
+ if ErrorIs(resultErr, InvalidMarketCredentials) || ErrorIs(resultErr, IPRestrictedApiKey) || ErrorIs(resultErr, MarketCredentialsNotConfigured) {
+ newStatus = db.MarketConfigInvalidCredentials
+ } else if resultErr != nil {
+ return nil, NewInternalError(resultErr)
+ } else if resultErr != nil {
return nil, NewInternalError(resultErr)
}
+ if newStatus != config.Status {
+ config, err = db.SetMarketConfigStatus(*config, newStatus)
+ if err != nil {
+ return nil, NewInternalError(err)
+ }
+ }
+
return nil, nil
}
var newStatus db.MarketConfigStatus = db.MarketConfigEnabled
- if ErrorIs(resultErr, InvalidMarketCredentials) || ErrorIs(resultErr, IPRestrictedApiKey) {
+ if ErrorIs(resultErr, InvalidMarketCredentials) || ErrorIs(resultErr, IPRestrictedApiKey) || ErrorIs(resultErr, MarketCredentialsNotConfigured) {
newStatus = db.MarketConfigInvalidCredentials
} else if resultErr != nil {
return nil, NewInternalError(resultErr)