Files
golib/cluster/errors.go
2021-04-12 19:33:12 +02:00

116 lines
3.7 KiB
Go

//+build amd64 arm64 arm64be ppc64 ppc64le mips64 mips64le riscv64 s390x sparc64 wasm
/***********************************************************************************************************************
*
* MIT License
*
* Copyright (c) 2021 Nicolas JUHEL
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*
**********************************************************************************************************************/
package cluster
import liberr "github.com/nabbar/golib/errors"
const (
ErrorParamsEmpty liberr.CodeError = iota + liberr.MinPkgCluster
ErrorParamsMissing
ErrorParamsMismatching
ErrorLeader
ErrorLeaderTransfer
ErrorNodeUser
ErrorNodeHostNew
ErrorNodeHostStart
ErrorNodeHostJoin
ErrorNodeHostStop
ErrorNodeHostRestart
ErrorCommandSync
ErrorCommandASync
ErrorCommandLocal
ErrorValidateConfig
ErrorValidateCluster
ErrorValidateNode
ErrorValidateGossip
ErrorValidateExpert
ErrorValidateEngine
)
var isCodeError = false
func IsCodeError() bool {
return isCodeError
}
func init() {
isCodeError = liberr.ExistInMapMessage(ErrorParamsEmpty)
liberr.RegisterIdFctMessage(ErrorParamsEmpty, getMessage)
}
func getMessage(code liberr.CodeError) (message string) {
switch code {
case liberr.UNK_ERROR:
return ""
case ErrorParamsEmpty:
return "at least on given parameters is empty"
case ErrorParamsMissing:
return "at least on given parameters is missing"
case ErrorParamsMismatching:
return "at least on given parameters is mismatching awaiting type"
case ErrorLeader:
return "enable to retrieve cluster leader"
case ErrorLeaderTransfer:
return "enable to transfer cluster leader"
case ErrorNodeUser:
return "enable to retrieve node user"
case ErrorNodeHostNew:
return "enable to init new NodeHost"
case ErrorNodeHostStart:
return "enable to start cluster"
case ErrorNodeHostJoin:
return "enable to join cluster"
case ErrorNodeHostStop:
return "enable to stop cluster or node"
case ErrorNodeHostRestart:
return "enable to restart node properly"
case ErrorCommandSync:
return "enable to call synchronous command"
case ErrorCommandASync:
return "enable to call asynchronous command"
case ErrorCommandLocal:
return "enable to call local command"
case ErrorValidateConfig:
return "config seems to be not valid"
case ErrorValidateCluster:
return "cluster config seems to be not valid"
case ErrorValidateNode:
return "node config seems to be not valid"
case ErrorValidateGossip:
return "gossip config seems to be not valid"
case ErrorValidateExpert:
return "expert config seems to be not valid"
case ErrorValidateEngine:
return "engine config seems to be not valid"
}
return ""
}