|
|
@ -2,9 +2,11 @@ package model
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
"fmt"
|
|
|
|
"regexp"
|
|
|
|
"regexp"
|
|
|
|
|
|
|
|
|
|
|
|
json "github.com/json-iterator/go"
|
|
|
|
json "github.com/json-iterator/go"
|
|
|
|
|
|
|
|
"github.com/synctv-org/synctv/internal/conf"
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
)
|
|
|
|
)
|
|
|
@ -14,7 +16,6 @@ var (
|
|
|
|
ErrRoomIdTooLong = errors.New("room id too long")
|
|
|
|
ErrRoomIdTooLong = errors.New("room id too long")
|
|
|
|
ErrRoomIdHasInvalidChar = errors.New("room id has invalid char")
|
|
|
|
ErrRoomIdHasInvalidChar = errors.New("room id has invalid char")
|
|
|
|
|
|
|
|
|
|
|
|
ErrEmptyPassword = errors.New("empty password")
|
|
|
|
|
|
|
|
ErrPasswordTooLong = errors.New("password too long")
|
|
|
|
ErrPasswordTooLong = errors.New("password too long")
|
|
|
|
ErrPasswordHasInvalidChar = errors.New("password has invalid char")
|
|
|
|
ErrPasswordHasInvalidChar = errors.New("password has invalid char")
|
|
|
|
|
|
|
|
|
|
|
@ -28,6 +29,12 @@ var (
|
|
|
|
alphaNumChineseReg = regexp.MustCompile(`^[\p{Han}a-zA-Z0-9_\-]+$`)
|
|
|
|
alphaNumChineseReg = regexp.MustCompile(`^[\p{Han}a-zA-Z0-9_\-]+$`)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
type FormatEmptyPasswordError string
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func (f FormatEmptyPasswordError) Error() string {
|
|
|
|
|
|
|
|
return fmt.Sprintf("%s password empty", string(f))
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
type CreateRoomReq struct {
|
|
|
|
type CreateRoomReq struct {
|
|
|
|
RoomId string `json:"roomId"`
|
|
|
|
RoomId string `json:"roomId"`
|
|
|
|
Password string `json:"password"`
|
|
|
|
Password string `json:"password"`
|
|
|
@ -55,6 +62,8 @@ func (c *CreateRoomReq) Validate() error {
|
|
|
|
} else if !alphaNumReg.MatchString(c.Password) {
|
|
|
|
} else if !alphaNumReg.MatchString(c.Password) {
|
|
|
|
return ErrPasswordHasInvalidChar
|
|
|
|
return ErrPasswordHasInvalidChar
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} else if conf.Conf.Room.MustPassword {
|
|
|
|
|
|
|
|
return FormatEmptyPasswordError("room")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if c.Username == "" {
|
|
|
|
if c.Username == "" {
|
|
|
@ -66,7 +75,7 @@ func (c *CreateRoomReq) Validate() error {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if c.UserPassword == "" {
|
|
|
|
if c.UserPassword == "" {
|
|
|
|
return ErrEmptyPassword
|
|
|
|
return FormatEmptyPasswordError("user")
|
|
|
|
} else if len(c.UserPassword) > 32 {
|
|
|
|
} else if len(c.UserPassword) > 32 {
|
|
|
|
return ErrPasswordTooLong
|
|
|
|
return ErrPasswordTooLong
|
|
|
|
} else if !alphaNumReg.MatchString(c.UserPassword) {
|
|
|
|
} else if !alphaNumReg.MatchString(c.UserPassword) {
|
|
|
@ -105,7 +114,7 @@ func (l *LoginRoomReq) Validate() error {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if l.UserPassword == "" {
|
|
|
|
if l.UserPassword == "" {
|
|
|
|
return ErrEmptyPassword
|
|
|
|
return FormatEmptyPasswordError("user")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|