Files
golib/errors/code.go
Nicolas JUHEL 573af6ce3a Package AWS :
- Config Model : add a config model with a golib RouerStatus Config Model to use a AWS connection for API with a request status health check
  - Config Interface : add function GetAccessKey to retrieve the accesskey value currently used into the current connection
  - function Walk (Object, version, ...) : fix bug with pointer of string not initialized

Package Config :
  - interface Component : add status router pointer into the Init function to allow used a global router status for all component status registration as router status component

Package Status :
  - move Status Config as an sub package of Package Status

Package Errors :
  - add CamelCase const

Package Logger :
  - fix following bump dependencies

Global :
  - bump dependencies
  - change init of errors files : change function never call vy panic to prevent an error code collision
2022-09-13 12:31:04 +02:00

201 lines
4.0 KiB
Go

/*
* MIT License
*
* Copyright (c) 2020 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 errors
import (
"reflect"
"runtime"
"sort"
"strconv"
"strings"
)
var idMsgFct = make(map[CodeError]Message)
type Message func(code CodeError) (message string)
type CodeError uint16
const UNK_ERROR CodeError = 0
const UnknownError CodeError = 0
const UNK_MESSAGE = "unknown error"
const UnknownMessage = "unknown error"
const NUL_MESSAGE = ""
const NullMessage = ""
func (c CodeError) GetUint16() uint16 {
return uint16(c)
}
func (c CodeError) GetInt() int {
return int(c)
}
func (c CodeError) GetString() string {
return strconv.Itoa(c.GetInt())
}
func (c CodeError) GetMessage() string {
if c == UnknownError {
return UnknownMessage
}
if f, ok := idMsgFct[findCodeErrorInMapMessage(c)]; ok {
if m := f(c); m != "" {
return m
}
}
return UnknownMessage
}
func (c CodeError) Error(p Error) Error {
return NewError(c.GetUint16(), c.GetMessage(), p)
}
func (c CodeError) ErrorParent(p ...error) Error {
e := c.Error(nil)
e.AddParent(p...)
return e
}
func (c CodeError) IfError(e Error) Error {
return NewErrorIfError(c.GetUint16(), c.GetMessage(), e)
}
func (c CodeError) Iferror(e error) Error {
return NewErrorIferror(c.GetUint16(), c.GetMessage(), e)
}
func GetCodePackages(rootPackage string) map[CodeError]string {
var res = make(map[CodeError]string)
for i, f := range idMsgFct {
p := reflect.ValueOf(f).Pointer()
n, _ := runtime.FuncForPC(p).FileLine(p)
if strings.Contains(n, "/vendor/") {
a := strings.SplitN(n, "/vendor/", 2)
n = a[1]
}
if strings.Contains(n, rootPackage) {
a := strings.SplitN(n, rootPackage, 2)
n = a[1]
}
if !strings.HasPrefix(n, "/") {
n = "/" + n
}
res[i] = n
}
return res
}
func RegisterIdFctMessage(minCode CodeError, fct Message) {
if idMsgFct == nil {
idMsgFct = make(map[CodeError]Message)
}
idMsgFct[minCode] = fct
orderMapMessage()
}
func ExistInMapMessage(code CodeError) bool {
if f, ok := idMsgFct[findCodeErrorInMapMessage(code)]; ok {
if m := f(code); m != NullMessage {
return true
}
}
return false
}
func getMapMessageKey() []CodeError {
var (
keys = make([]int, 0)
res = make([]CodeError, 0)
)
for k := range idMsgFct {
keys = append(keys, int(k.GetUint16()))
}
sort.Ints(keys)
for _, k := range keys {
res = append(res, CodeError(k))
}
return res
}
func orderMapMessage() {
var res = make(map[CodeError]Message)
for _, k := range getMapMessageKey() {
res[k] = idMsgFct[k]
}
idMsgFct = res
}
func findCodeErrorInMapMessage(code CodeError) CodeError {
var res CodeError = 0
for _, k := range getMapMessageKey() {
if k <= code && k > res {
res = k
}
}
return res
}
func isCodeInSlice(code CodeError, slice []CodeError) bool {
for _, c := range slice {
if c == code {
return true
}
}
return false
}
func unicCodeSlice(slice []CodeError) []CodeError {
var res = make([]CodeError, 0)
for _, c := range slice {
if !isCodeInSlice(c, res) {
res = append(res, c)
}
}
return res
}