"strings"
"time"
- "immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front/markets"
-
"github.com/jloup/utils"
- "github.com/shopspring/decimal"
- "immae.eu/Immae/Projets/Cryptomonnaies/Cryptoportfolio/Front/db"
+ "git.immae.eu/Cryptoportfolio/Front.git/db"
+ "git.immae.eu/Cryptoportfolio/Front.git/markets"
)
type MarketConfigQuery struct {
}
+ if _, ok := config.Config["key"]; !ok {
+ config.Config["key"] = ""
+ }
+
+ if _, ok := config.Config["secret"]; !ok {
+ config.Config["secret"] = ""
+ }
+
return config.Config, nil
}
-type MarketBalanceQuery struct {
+type TestMarketCredentialsQuery struct {
In struct {
- User db.User
- Market string
- Currency string
+ User db.User
+ Market string
}
}
-func (q MarketBalanceQuery) ValidateParams() *Error {
+func (q TestMarketCredentialsQuery) ValidateParams() *Error {
if q.In.Market != "poloniex" {
return &Error{BadRequest, "invalid market name", fmt.Errorf("'%v' is not a valid market name", q.In.Market)}
}
- // TODO: we should request market for available currencies.
- if q.In.Currency != "BTC" && q.In.Currency != "USDT" && q.In.Currency != "ETH" {
- return &Error{BadRequest, "invalid currency, accept [BTC, USDT, ETH]", fmt.Errorf("'%v' is not a valid currency", q.In.Currency)}
- }
-
return nil
}
-func (q MarketBalanceQuery) Run() (interface{}, *Error) {
+func (q TestMarketCredentialsQuery) Run() (interface{}, *Error) {
config, err := db.GetUserMarketConfig(q.In.User.Id, q.In.Market)
if err != nil {
return nil, NewInternalError(err)
}
- if config.Config["key"] == "" || config.Config["secret"] == "" {
- return nil, &Error{BadRequest, "your credentials for this market are not setup", fmt.Errorf("'%v' credentials are not setup", 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)}
}
- result := struct {
- Value decimal.Decimal `json:"value"`
- ValueCurrency string `json:"valueCurrency"`
- Balance map[string]markets.Balance `json:"balance"`
- }{}
-
- resultErr := CallExternalService(fmt.Sprintf("'%s' GetBalanceValue", q.In.Market), EXTERNAL_SERVICE_TIMEOUT_SECONDS*time.Second, func() *Error {
- balance, err := Poloniex.GetBalance(config.Config["key"], config.Config["secret"])
+ 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) {
return &Error{InvalidMarketCredentials, "wrong market credentials", fmt.Errorf("wrong '%v' market credentials", q.In.Market)}
return NewInternalError(err)
}
- for currency, value := range balance.Balances {
- if value.BTCValue.Abs().LessThan(decimal.NewFromFloat(0.0001)) {
- delete(balance.Balances, currency)
- }
- }
-
- result.Balance = balance.Balances
- result.ValueCurrency = "BTC"
- result.Value = balance.BTCValue.Round(8)
-
return nil
})
if resultErr != nil {
- return nil, resultErr
+ return nil, NewInternalError(resultErr)
}
- return &result, nil
+ return nil, nil
}
type UpdateMarketConfigQuery struct {
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)
}
return nil, nil
}
+
+type GetPortfolioQuery struct {
+ In struct {
+ User db.User
+ Market string
+ }
+}
+
+func (q GetPortfolioQuery) ValidateParams() *Error {
+ if q.In.Market != "poloniex" {
+ return &Error{BadRequest, "invalid market name", fmt.Errorf("'%v' is not a valid market name", q.In.Market)}
+ }
+
+ return nil
+}
+
+func (q GetPortfolioQuery) Run() (interface{}, *Error) {
+ marketConfig, err := db.GetUserMarketConfig(q.In.User.Id, q.In.Market)
+ if err != nil {
+ return nil, NewInternalError(err)
+ }
+
+ report, err := GetWeekPortfolio(*marketConfig)
+ if ErrorIs(err, NotFound) {
+ return nil, err.(*Error)
+ }
+
+ if err != nil {
+ return nil, NewInternalError(err)
+ }
+
+ return report.Round(), nil
+}