aboutsummaryrefslogtreecommitdiff
path: root/api/const.go
blob: 4f608d575ab6dfe0fa85d5f83693cb1f6e8010b5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package api

import (
	"net/http"

	"github.com/jloup/utils"
)

//go:generate stringer -type=Status -output const_string.go
type Status uint32

const EXTERNAL_SERVICE_TIMEOUT_SECONDS = 20

const (
	OK Status = iota
	NOK
)

var (
	errorFlagCounter               utils.Counter = 0
	BadRequest                     utils.Flag    = utils.InitFlag(&errorFlagCounter, "BadRequest")
	EmailExists                    utils.Flag    = utils.InitFlag(&errorFlagCounter, "EmailExists")
	ExternalServiceTimeout         utils.Flag    = utils.InitFlag(&errorFlagCounter, "ExternalServiceTimeout")
	InternalError                  utils.Flag    = utils.InitFlag(&errorFlagCounter, "InternalError")
	InvalidCredentials             utils.Flag    = utils.InitFlag(&errorFlagCounter, "InvalidCredentials")
	InvalidEmail                   utils.Flag    = utils.InitFlag(&errorFlagCounter, "InvalidEmail")
	InvalidMarketCredentials       utils.Flag    = utils.InitFlag(&errorFlagCounter, "InvalidMarketCredentials")
	MarketCredentialsNotConfigured utils.Flag    = utils.InitFlag(&errorFlagCounter, "MarketCredentialsNotConfigured")
	IPRestrictedApiKey             utils.Flag    = utils.InitFlag(&errorFlagCounter, "IPRestrictedApiKey")
	InvalidOtp                     utils.Flag    = utils.InitFlag(&errorFlagCounter, "InvalidOtp")
	InvalidPassword                utils.Flag    = utils.InitFlag(&errorFlagCounter, "InvalidPassword")
	NeedOtpValidation              utils.Flag    = utils.InitFlag(&errorFlagCounter, "NeedOtpValidation")
	NotAuthorized                  utils.Flag    = utils.InitFlag(&errorFlagCounter, "NotAuthorized")
	NotFound                       utils.Flag    = utils.InitFlag(&errorFlagCounter, "NotFound")
	OtpAlreadySetup                utils.Flag    = utils.InitFlag(&errorFlagCounter, "OtpAlreadySetup")
	OtpNotSetup                    utils.Flag    = utils.InitFlag(&errorFlagCounter, "OtpNotSetup")
	UserNotConfirmed               utils.Flag    = utils.InitFlag(&errorFlagCounter, "UserNotConfirmed")

	StatusBadRequest     utils.Flag = utils.Join("BadRequest", BadRequest, InvalidPassword, InvalidEmail, InvalidMarketCredentials, IPRestrictedApiKey, MarketCredentialsNotConfigured)
	StatusUnauthorized   utils.Flag = utils.Join("Unauthorized", InvalidCredentials, InvalidOtp)
	StatusForbidden      utils.Flag = utils.Join("Forbidden", UserNotConfirmed, NotAuthorized, OtpAlreadySetup, OtpNotSetup, NeedOtpValidation)
	StatusConflicts      utils.Flag = utils.Join("Conflicts", EmailExists)
	StatusNotFound       utils.Flag = utils.Join("NotFound", NotFound)
	StatusGatewayTimeout utils.Flag = utils.Join("GatewayTimeout", ExternalServiceTimeout)
)

func StatusToHttpCode(status Status, code utils.Flag) int {
	if status == OK {
		return http.StatusOK
	}

	switch {
	case utils.Intersect(code, StatusBadRequest):
		return http.StatusBadRequest
	case utils.Intersect(code, StatusUnauthorized):
		return http.StatusUnauthorized
	case utils.Intersect(code, StatusForbidden):
		return http.StatusForbidden
	case utils.Intersect(code, StatusConflicts):
		return http.StatusConflict
	case utils.Intersect(code, StatusNotFound):
		return http.StatusNotFound
	case utils.Intersect(code, StatusGatewayTimeout):
		return http.StatusGatewayTimeout
	}

	return http.StatusInternalServerError
}