mirror of
https://github.com/qdm12/gluetun.git
synced 2026-06-11 14:53:36 +02:00
4a78989d9d
- main reason being it's a burden to always define sentinel errors at global scope, wrap them with `%w` instead of using a string directly - only use sentinel errors when it has to be checked using `errors.Is` - replace all usage of these sentinel errors in `fmt.Errorf` with direct strings that were in the sentinel error - exclude the sentinel error definition requirement from .golangci.yml - update unit tests to use ContainersError instead of ErrorIs so it stays as a "not a change detector test" without requiring a sentinel error
39 lines
838 B
Go
39 lines
838 B
Go
package updater
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
|
"golang.org/x/text/cases"
|
|
)
|
|
|
|
func parseFilename(fileName, hostname string, titleCaser cases.Caser) (
|
|
country, city string, err error,
|
|
) {
|
|
const prefix = "ipvanish-"
|
|
s := strings.TrimPrefix(fileName, prefix)
|
|
|
|
const ext = ".ovpn"
|
|
host := strings.Split(hostname, ".")[0]
|
|
suffix := "-" + host + ext
|
|
s = strings.TrimSuffix(s, suffix)
|
|
|
|
parts := strings.Split(s, "-")
|
|
|
|
countryCodes := constants.CountryCodes()
|
|
countryCode := strings.ToLower(parts[0])
|
|
country, ok := countryCodes[countryCode]
|
|
if !ok {
|
|
return "", "", fmt.Errorf("country code is unknown: %s", countryCode)
|
|
}
|
|
country = titleCaser.String(country)
|
|
|
|
if len(parts) > 1 {
|
|
city = strings.Join(parts[1:], " ")
|
|
city = titleCaser.String(city)
|
|
}
|
|
|
|
return country, city, nil
|
|
}
|