Premier commit
This commit is contained in:
71
github/github.go
Normal file
71
github/github.go
Normal file
@ -0,0 +1,71 @@
|
||||
package github
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"regexp"
|
||||
|
||||
"github.com/foxdeveloper/namecheck"
|
||||
"github.com/foxdeveloper/namecheck/util"
|
||||
)
|
||||
|
||||
const (
|
||||
EndpointAPI string = "https://github.com/"
|
||||
AvailableHTTPCode int = http.StatusNotFound
|
||||
UsernameShort int = 1
|
||||
UsernameLong int = 15
|
||||
UsernameLegalPattern string = "^[A-Za-z0-9_]+$"
|
||||
UsernameIllegalPattern string = "github"
|
||||
)
|
||||
|
||||
var (
|
||||
legalRegexp = regexp.MustCompile(UsernameLegalPattern)
|
||||
illegalRegexp = regexp.MustCompile(UsernameIllegalPattern)
|
||||
)
|
||||
|
||||
type Github struct{}
|
||||
|
||||
func init() {
|
||||
namecheck.AddSn(&Github{})
|
||||
}
|
||||
|
||||
func (t *Github) String() string {
|
||||
return "Github"
|
||||
}
|
||||
|
||||
// IsValid check the validity of the username
|
||||
func (t *Github) IsValid(username string) bool {
|
||||
return isLongEnough(username) &&
|
||||
isShortEnough(username) &&
|
||||
containsNoIllegalPattern(username) &&
|
||||
containsOnlyLegalChars(username)
|
||||
}
|
||||
|
||||
// IsAvailable check username availability
|
||||
func (t *Github) IsAvailable(username string) (bool, error) {
|
||||
res, err := http.Get(EndpointAPI + username)
|
||||
if err != nil {
|
||||
myErr := &namecheck.ErrUnknownAvailability{Username: username, Cause: err}
|
||||
return false, myErr
|
||||
}
|
||||
|
||||
// Prevent memory leaks
|
||||
defer res.Body.Close()
|
||||
|
||||
return res.StatusCode == AvailableHTTPCode, nil
|
||||
}
|
||||
|
||||
func isLongEnough(username string) bool {
|
||||
return util.Counter(username) >= UsernameShort
|
||||
}
|
||||
|
||||
func isShortEnough(username string) bool {
|
||||
return util.Counter(username) <= UsernameLong
|
||||
}
|
||||
|
||||
func containsOnlyLegalChars(username string) bool {
|
||||
return legalRegexp.MatchString(util.ToLower(username))
|
||||
}
|
||||
|
||||
func containsNoIllegalPattern(username string) bool {
|
||||
return len(illegalRegexp.FindStringIndex(util.ToLower(username))) == 0
|
||||
}
|
68
github/github_test.go
Normal file
68
github/github_test.go
Normal file
@ -0,0 +1,68 @@
|
||||
package github_test
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
var (
|
||||
gh github.Github = github.Github{}
|
||||
)
|
||||
|
||||
func TestName(t *testing.T) {
|
||||
want := "Twitter"
|
||||
got := tw.String()
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.Name() = %s; want %s", got, want)
|
||||
}
|
||||
|
||||
}
|
||||
func TestUsernameTooShort(t *testing.T) {
|
||||
username := ""
|
||||
want := false
|
||||
got := tw.IsValid(username)
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.IsValid(%s) = %t; want %t", username, got, want)
|
||||
}
|
||||
}
|
||||
func TestUsernameTooLong(t *testing.T) {
|
||||
username := "azetrgdkalakdzjazdzaidadhazdazidazdazmdazldkazda"
|
||||
want := false
|
||||
got := tw.IsValid(username)
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.IsValid(%s) = %t; want %t", username, got, want)
|
||||
}
|
||||
}
|
||||
func TestUsernameContainsIllegalPattern(t *testing.T) {
|
||||
username := "psetwiTterdo"
|
||||
want := false
|
||||
got := tw.IsValid(username)
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.IsValid(%s) = %t; want %t", username, got, want)
|
||||
}
|
||||
}
|
||||
func TestUsernameContainsNotOnlyLegalPattern(t *testing.T) {
|
||||
username := "pseudo-"
|
||||
want := false
|
||||
got := tw.IsValid(username)
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.IsValid(%s) = %t; want %t", username, got, want)
|
||||
}
|
||||
}
|
||||
func TestUsernameAvailablePattern(t *testing.T) {
|
||||
username := "jubobs"
|
||||
want := false
|
||||
got, err := tw.IsAvailable(username)
|
||||
|
||||
if err != nil {
|
||||
t.Errorf("%v", err)
|
||||
}
|
||||
|
||||
if got != want {
|
||||
t.Errorf("twitter.IsValid(%s) = %t; want %t", username, got, want)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user