mirror of https://github.com/on4kjm/FLEcli.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.6 KiB
115 lines
3.6 KiB
4 years ago
|
package cmd
|
||
|
/*
|
||
|
Copyright © 2020 Jean-Marc Meessen, ON4KJM <on4kjm@gmail.com>
|
||
|
|
||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
you may not use this file except in compliance with the License.
|
||
|
You may obtain a copy of the License at
|
||
|
|
||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
|
||
|
Unless required by applicable law or agreed to in writing, software
|
||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
See the License for the specific language governing permissions and
|
||
|
limitations under the License.
|
||
|
*/
|
||
|
|
||
|
import (
|
||
|
"regexp"
|
||
|
"strings"
|
||
4 years ago
|
"fmt"
|
||
|
"time"
|
||
4 years ago
|
)
|
||
|
|
||
|
|
||
4 years ago
|
var validSotaRegexp = regexp.MustCompile(`^[0-9A-Z]{1,3}/[A-Z]{2}-[\d]{3}$`)
|
||
|
|
||
|
// ValidateSota verifies whether the supplied string is a valid SOTA reference.
|
||
|
// The syntax is: AA/NN-CCC: Association/Name-3-digit numeric Code (e.g. G/CE-001).
|
||
|
func ValidateSota(inputStr string) (ref, errorMsg string) {
|
||
|
inputStr = strings.ToUpper(strings.TrimSpace(inputStr))
|
||
|
wrongInputStr := "*" + inputStr
|
||
|
if validSotaRegexp.MatchString(inputStr) {
|
||
|
return inputStr, ""
|
||
|
}
|
||
|
return wrongInputStr, "Invalid SOTA reference"
|
||
|
}
|
||
|
|
||
|
var validWwffRegexp = regexp.MustCompile(`^[\d]{0,1}[A-Z]{1,2}FF-[\d]{4}$`)
|
||
|
|
||
|
// ValidateWwff verifies whether the supplied string is a valid WWFF reference.
|
||
|
// The syntax is: AAFF-CCCC: AA = national prefix, CCCC = 4-digit numeric code (e.g. ONFF-0001).
|
||
|
func ValidateWwff(inputStr string) (ref, errorMsg string) {
|
||
|
inputStr = strings.ToUpper(strings.TrimSpace(inputStr))
|
||
|
wrongInputStr := "*" + inputStr
|
||
|
if validWwffRegexp.MatchString(inputStr) {
|
||
|
return inputStr, ""
|
||
|
}
|
||
|
return wrongInputStr, "Invalid WWFF reference"
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
4 years ago
|
var validCallRegexp = regexp.MustCompile(`[\d]{0,1}[A-Z]{1,2}\d([A-Z]{1,4}|\d{3,3}|\d{1,3}[A-Z])[A-Z]{0,5}`)
|
||
|
var validPrefixRegexp = regexp.MustCompile(`\A\d?[a-zA-Z]{1,2}$`)
|
||
|
|
||
4 years ago
|
// ValidateCall verifies whether the supplied string is a valid callsign.
|
||
4 years ago
|
// prefix and suffix are not checked for validity
|
||
|
// If it is not valid, the supicious string is prefixed with a * and an erroMsg is genrated.
|
||
|
func ValidateCall(sign string) (call, errorMsg string) {
|
||
|
sign = strings.ToUpper(strings.TrimSpace(sign))
|
||
|
sp := strings.Split(sign, "/")
|
||
|
wrongSign := "*" + sign
|
||
|
switch len(sp) {
|
||
|
case 1:
|
||
|
if validCallRegexp.MatchString(sign) {
|
||
|
return sign, ""
|
||
|
}
|
||
4 years ago
|
return wrongSign, "Invalid call"
|
||
4 years ago
|
case 2:
|
||
|
// some ambiguity here we need to resolve, could be a prefix or a suffix
|
||
|
if validCallRegexp.MatchString(sp[0]) {
|
||
|
//Callisign with suffix (unchecked)
|
||
|
return sign, ""
|
||
4 years ago
|
}
|
||
|
//else we are dealing with a prefixed Callsign
|
||
|
//validate the part that should contain the call (sp[1])
|
||
|
if !validCallRegexp.MatchString(sp[1]) {
|
||
|
return wrongSign, "Invalid call"
|
||
|
}
|
||
|
//validate the prefix
|
||
|
if !validPrefixRegexp.MatchString(sp[0]) {
|
||
|
return wrongSign, "Invalid prefix"
|
||
4 years ago
|
}
|
||
4 years ago
|
return sign, ""
|
||
4 years ago
|
case 3:
|
||
4 years ago
|
//validate the part that should contain the call (sp[1])
|
||
|
if !validCallRegexp.MatchString(sp[1]) {
|
||
|
return wrongSign, "Invalid call"
|
||
|
}
|
||
|
//validate the prefix
|
||
|
if !validPrefixRegexp.MatchString(sp[0]) {
|
||
|
return wrongSign, "Invalid prefix"
|
||
|
}
|
||
|
//We don't check the suffix
|
||
|
return sign, ""
|
||
4 years ago
|
}
|
||
4 years ago
|
return wrongSign, "Too many '/'"
|
||
4 years ago
|
}
|
||
|
|
||
|
// ValidateDate verifies whether the string is a valid date (YYYY-MM-DD).
|
||
|
func ValidateDate(inputStr string) (ref, errorMsg string) {
|
||
|
|
||
|
const RFC3339FullDate = "2006-01-02"
|
||
|
|
||
|
inputStr = strings.ToUpper(strings.TrimSpace(inputStr))
|
||
|
wrongInputStr := "*" + inputStr
|
||
|
_, err := time.Parse(RFC3339FullDate, inputStr)
|
||
|
|
||
|
if err == nil {
|
||
|
return inputStr, ""
|
||
|
}
|
||
|
|
||
|
return wrongInputStr, fmt.Sprint(err)
|
||
4 years ago
|
}
|