summaryrefslogtreecommitdiffstats
path: root/vendor/golang.org/x/text/secure/precis/profiles.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/golang.org/x/text/secure/precis/profiles.go')
-rw-r--r--vendor/golang.org/x/text/secure/precis/profiles.go69
1 files changed, 69 insertions, 0 deletions
diff --git a/vendor/golang.org/x/text/secure/precis/profiles.go b/vendor/golang.org/x/text/secure/precis/profiles.go
new file mode 100644
index 000000000..8b46d504c
--- /dev/null
+++ b/vendor/golang.org/x/text/secure/precis/profiles.go
@@ -0,0 +1,69 @@
+// Copyright 2015 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package precis
+
+import (
+ "unicode"
+
+ "golang.org/x/text/runes"
+ "golang.org/x/text/transform"
+ "golang.org/x/text/unicode/norm"
+)
+
+var (
+ Nickname *Profile = nickname // Implements the Nickname profile specified in RFC 7700.
+ UsernameCaseMapped *Profile = usernameCaseMap // Implements the UsernameCaseMapped profile specified in RFC 7613.
+ UsernameCasePreserved *Profile = usernameNoCaseMap // Implements the UsernameCasePreserved profile specified in RFC 7613.
+ OpaqueString *Profile = opaquestring // Implements the OpaqueString profile defined in RFC 7613 for passwords and other secure labels.
+)
+
+var (
+ nickname = &Profile{
+ options: getOpts(
+ AdditionalMapping(func() transform.Transformer {
+ return &nickAdditionalMapping{}
+ }),
+ IgnoreCase,
+ Norm(norm.NFKC),
+ DisallowEmpty,
+ ),
+ class: freeform,
+ }
+ usernameCaseMap = &Profile{
+ options: getOpts(
+ FoldWidth,
+ LowerCase(),
+ Norm(norm.NFC),
+ BidiRule,
+ ),
+ class: identifier,
+ }
+ usernameNoCaseMap = &Profile{
+ options: getOpts(
+ FoldWidth,
+ Norm(norm.NFC),
+ BidiRule,
+ ),
+ class: identifier,
+ }
+ opaquestring = &Profile{
+ options: getOpts(
+ AdditionalMapping(func() transform.Transformer {
+ return mapSpaces
+ }),
+ Norm(norm.NFC),
+ DisallowEmpty,
+ ),
+ class: freeform,
+ }
+)
+
+// mapSpaces is a shared value of a runes.Map transformer.
+var mapSpaces transform.Transformer = runes.Map(func(r rune) rune {
+ if unicode.Is(unicode.Zs, r) {
+ return ' '
+ }
+ return r
+})