Chromium Code Reviews| Index: service/info/support/namespace.go | 
| diff --git a/service/info/support/namespace.go b/service/info/support/namespace.go | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..6cb2e90ebf5ac5a29fb6b3a0cca2a6b4e92f16f1 | 
| --- /dev/null | 
| +++ b/service/info/support/namespace.go | 
| @@ -0,0 +1,24 @@ | 
| +// Copyright 2015 The LUCI Authors. All rights reserved. | 
| +// Use of this source code is governed under the Apache License, Version 2.0 | 
| +// that can be found in the LICENSE file. | 
| + | 
| +// Package support provides Info-related support functionality. It is designed | 
| +// to be used by implementing packages. | 
| +package support | 
| + | 
| +import ( | 
| + "fmt" | 
| + "regexp" | 
| +) | 
| + | 
| +// validNamespace matches valid namespace names. | 
| +var validNamespace = regexp.MustCompile(`^[0-9A-Za-z._-]{0,100}$`) | 
| 
 
dnj
2016/09/01 15:25:40
Added this package b/c both impl/memory and impl/c
 
iannucci
2016/09/16 01:01:14
maybe it should move to service/datastore?
 
dnj
2016/09/16 05:44:43
I think namespace is a concept owned by "info" ser
 
 | 
| + | 
| +// ValidNamespace will return an error if the supplied string is not a valid | 
| +// namespace. | 
| +func ValidNamespace(ns string) error { | 
| + if validNamespace.MatchString(ns) { | 
| + return nil | 
| + } | 
| + return fmt.Errorf("appengine: namespace %q does not match /%s/", ns, validNamespace) | 
| +} |