init import

This commit is contained in:
Олег Бородин
2026-05-24 11:02:51 +02:00
commit 25365aef77
154 changed files with 21501 additions and 0 deletions
+52
View File
@@ -0,0 +1,52 @@
/*
* Copyright 2026 Oleg Borodin <onborodin@gmail.com>
*
*
*/
package auxhttp
import (
"encoding/base64"
"fmt"
"strings"
)
func EncodeBasicAuth(username, password string) string {
auth := username + ":" + password
return "Basic " + base64.StdEncoding.EncodeToString([]byte(auth))
}
func ParseBasicAuth(basicFields string) (string, string, error) {
var err error
var username string
var password string
if basicFields == "" {
err := fmt.Errorf("Empty auth field")
return username, password, err
}
authFields := strings.SplitN(basicFields, " ", 2)
if len(authFields) < 2 {
err = fmt.Errorf("Cannot split auth field: %s", basicFields)
return username, password, err
}
authType := strings.TrimSpace(authFields[0])
if strings.ToLower(authType) != strings.ToLower("Basic") {
err = fmt.Errorf("Not basic auth type")
return username, password, err
}
authPairEncoded := authFields[1]
pairEncoded, err := base64.StdEncoding.DecodeString(authPairEncoded)
if err != nil {
err = fmt.Errorf("Cannon decode auth pair")
return username, password, err
}
authPair := strings.SplitN(string(pairEncoded), ":", 2)
if len(authPair) != 2 {
err = fmt.Errorf("Wrong auth pair")
return username, password, err
}
username = authPair[0]
password = authPair[1]
return username, password, err
}
+93
View File
@@ -0,0 +1,93 @@
/*
* Copyright 2026 Oleg Borodin <onborodin@gmail.com>
*
*
*/
package auxhttp
import (
"fmt"
"strconv"
"strings"
)
func ParseOCIContentRange(ref string) (int64, int64, error) {
var start, end int64
var err error
startstop := strings.TrimSpace(ref)
tmp := strings.SplitN(startstop, "-", 2)
if len(tmp) != 2 {
err = fmt.Errorf("Wrong Content-Range definition, strange range def %v", startstop)
return start, end, err
}
startstr := tmp[0]
endstr := tmp[1]
start, err = strconv.ParseInt(startstr, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Range definition, strange start %s", startstr)
return start, end, err
}
end, err = strconv.ParseInt(endstr, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Range definition, strange end %s", endstr)
return start, end, err
}
return start, end, err
}
func ParseContentRange(ref string) (int64, int64, int64, error) {
var start, end, total int64
var err error
const bytesUnit = "bytes"
tmp := strings.SplitN(ref, " ", 2)
if len(tmp) != 2 {
err := fmt.Errorf("Wrong Content-Range definition, len is only %d", len(tmp))
return start, end, total, err
}
unit := strings.ToLower(tmp[0])
if unit != bytesUnit {
err = fmt.Errorf("Wrong Content-Range definition, strange length def %s", unit)
return start, end, total, err
}
ranger := strings.TrimSpace(tmp[1])
tmp = strings.Split(ranger, "/")
if len(tmp) != 2 {
err = fmt.Errorf("Wrong Content-Range definition, dont found total")
return start, end, total, err
}
totalstr := tmp[1]
if totalstr == "*" {
total = 0
} else {
total, err = strconv.ParseInt(totalstr, 10, 64)
if err != nil {
return start, end, total, err
}
}
startstop := tmp[0]
tmp = strings.SplitN(startstop, "-", 2)
if len(tmp) != 2 {
err = fmt.Errorf("Wrong Content-Range definition, strange range def %v", startstop)
return start, end, total, err
}
startstr := tmp[0]
endstr := tmp[1]
start, err = strconv.ParseInt(startstr, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Range definition, strange start %s", startstr)
return start, end, total, err
}
end, err = strconv.ParseInt(endstr, 10, 64)
if err != nil {
err = fmt.Errorf("Wrong Content-Range definition, strange end %s", endstr)
return start, end, total, err
}
return start, end, total, err
}