1
0
mirror of https://github.com/directorz/mailfull-go.git synced 2025-12-17 17:47:04 +00:00

implement setters and change to call it from constructor

This commit is contained in:
teru
2016-08-05 18:26:54 +09:00
parent c7d3c62281
commit 215df0c819
3 changed files with 89 additions and 30 deletions

View File

@@ -22,26 +22,46 @@ func (p AliasDomainSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] }
// NewAliasDomain creates a new AliasDomain instance.
func NewAliasDomain(name, target string) (*AliasDomain, error) {
if !validAliasDomainName(name) {
return nil, ErrInvalidAliasDomainName
}
if !validAliasDomainTarget(target) {
return nil, ErrInvalidAliasDomainTarget
ad := &AliasDomain{}
if err := ad.setName(name); err != nil {
return nil, err
}
ad := &AliasDomain{
name: name,
target: target,
if err := ad.SetTarget(target); err != nil {
return nil, err
}
return ad, nil
}
// setName sets the name.
func (ad *AliasDomain) setName(name string) error {
if !validAliasDomainName(name) {
return ErrInvalidAliasDomainName
}
ad.name = name
return nil
}
// Name returns name.
func (ad *AliasDomain) Name() string {
return ad.name
}
// SetTarget sets the target.
func (ad *AliasDomain) SetTarget(target string) error {
if !validAliasDomainTarget(target) {
return ErrInvalidAliasDomainTarget
}
ad.target = target
return nil
}
// Target returns target.
func (ad *AliasDomain) Target() string {
return ad.target

View File

@@ -28,33 +28,52 @@ func (p AliasUserSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] }
// NewAliasUser creates a new AliasUser instance.
func NewAliasUser(name string, targets []string) (*AliasUser, error) {
if !validAliasUserName(name) {
return nil, ErrInvalidAliasUserName
au := &AliasUser{}
if err := au.setName(name); err != nil {
return nil, err
}
if len(targets) < 1 {
return nil, ErrNotEnoughAliasUserTargets
}
for _, target := range targets {
if !validAliasUserTarget(target) {
return nil, ErrInvalidAliasUserTarget
}
}
au := &AliasUser{
name: name,
targets: targets,
if err := au.SetTargets(targets); err != nil {
return nil, err
}
return au, nil
}
// setName sets the name.
func (au *AliasUser) setName(name string) error {
if !validAliasUserName(name) {
return ErrInvalidAliasUserName
}
au.name = name
return nil
}
// Name returns name.
func (au *AliasUser) Name() string {
return au.name
}
// SetTargets sets targets.
func (au *AliasUser) SetTargets(targets []string) error {
if len(targets) < 1 {
return ErrNotEnoughAliasUserTargets
}
for _, target := range targets {
if !validAliasUserTarget(target) {
return ErrInvalidAliasUserTarget
}
}
au.targets = targets
return nil
}
// Targets returns targets.
func (au *AliasUser) Targets() []string {
return au.targets

34
user.go
View File

@@ -25,29 +25,49 @@ func (p UserSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] }
// NewUser creates a new User instance.
func NewUser(name, hashedPassword string, forwards []string) (*User, error) {
if !validUserName(name) {
return nil, ErrInvalidUserName
u := &User{}
if err := u.setName(name); err != nil {
return nil, err
}
u := &User{
name: name,
hashedPassword: hashedPassword,
forwards: forwards,
}
u.SetHashedPassword(hashedPassword)
u.SetForwards(forwards)
return u, nil
}
// setName sets the name.
func (u *User) setName(name string) error {
if !validUserName(name) {
return ErrInvalidUserName
}
u.name = name
return nil
}
// Name returns name.
func (u *User) Name() string {
return u.name
}
// SetHashedPassword sets the hashed password.
func (u *User) SetHashedPassword(hashedPassword string) {
u.hashedPassword = hashedPassword
}
// HashedPassword returns hashedPassword.
func (u *User) HashedPassword() string {
return u.hashedPassword
}
// SetForwards sets forwards.
func (u *User) SetForwards(forwards []string) {
u.forwards = forwards
}
// Forwards returns forwards.
func (u *User) Forwards() []string {
return u.forwards