2022-02-15 12:09:53 +01:00
|
|
|
package protocol
|
|
|
|
|
|
|
|
import "regexp"
|
|
|
|
|
|
|
|
// CreateRegexMatcher Création d'une instance de RegexMatcher
|
|
|
|
func CreateRegexMatcher(pattern string) *RegexMatcher {
|
|
|
|
compile, err := regexp.Compile(pattern)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return &RegexMatcher{matcher: compile}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegexMatcher Propose des méthodes relatives au matching de chaine de caractère
|
|
|
|
type RegexMatcher struct {
|
|
|
|
matcher *regexp.Regexp
|
|
|
|
}
|
|
|
|
|
2022-02-19 18:10:52 +01:00
|
|
|
// Match Permet de vérifier la validité d'une donnée affiliée à un protocole
|
|
|
|
func (m RegexMatcher) Match(data string) bool {
|
2022-02-15 12:09:53 +01:00
|
|
|
return m.matcher.MatchString(data)
|
|
|
|
}
|
2022-02-22 09:07:58 +01:00
|
|
|
|
|
|
|
// Build Permet de construire une chaine respectant une commande. Retourne la chaine et bool (TRUE si correct et FALSE si incorrect)
|
|
|
|
func (m RegexMatcher) Build(cmd string, datas ...string) (string, bool) {
|
|
|
|
str := cmd
|
|
|
|
|
|
|
|
for _, data := range datas {
|
|
|
|
str += " " + data
|
|
|
|
}
|
|
|
|
|
2022-02-22 10:03:52 +01:00
|
|
|
str += "\r\n"
|
|
|
|
|
|
|
|
if m.Match(str) {
|
|
|
|
return str, true
|
|
|
|
} else {
|
|
|
|
return "", false
|
|
|
|
}
|
2022-02-22 09:07:58 +01:00
|
|
|
}
|
2022-02-22 10:52:07 +01:00
|
|
|
|
|
|
|
// Parse Permet de récupérer les différentes données de la chaine sur base du regex
|
|
|
|
func (m RegexMatcher) Parse(data string) []string {
|
|
|
|
return m.matcher.FindAllStringSubmatch(data, -1)[0]
|
|
|
|
}
|