2018-05-14 16:26:38 +00:00
|
|
|
package platform
|
|
|
|
|
|
|
|
import "context"
|
|
|
|
|
2018-08-01 18:54:32 +00:00
|
|
|
// User is a user. 🎉
|
2018-05-14 16:26:38 +00:00
|
|
|
type User struct {
|
2018-07-30 14:29:52 +00:00
|
|
|
ID ID `json:"id,omitempty"`
|
2018-05-14 16:26:38 +00:00
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserService represents a service for managing user data.
|
|
|
|
type UserService interface {
|
|
|
|
// Returns a single user by ID.
|
|
|
|
FindUserByID(ctx context.Context, id ID) (*User, error)
|
|
|
|
|
|
|
|
// Returns the first user that matches filter.
|
|
|
|
FindUser(ctx context.Context, filter UserFilter) (*User, error)
|
|
|
|
|
|
|
|
// Returns a list of users that match filter and the total count of matching users.
|
|
|
|
// Additional options provide pagination & sorting.
|
|
|
|
FindUsers(ctx context.Context, filter UserFilter, opt ...FindOptions) ([]*User, int, error)
|
|
|
|
|
|
|
|
// Creates a new user and sets u.ID with the new identifier.
|
|
|
|
CreateUser(ctx context.Context, u *User) error
|
|
|
|
|
|
|
|
// Updates a single user with changeset.
|
|
|
|
// Returns the new user state after update.
|
|
|
|
UpdateUser(ctx context.Context, id ID, upd UserUpdate) (*User, error)
|
|
|
|
|
|
|
|
// Removes a user by ID.
|
|
|
|
DeleteUser(ctx context.Context, id ID) error
|
|
|
|
}
|
|
|
|
|
2018-09-25 16:43:05 +00:00
|
|
|
// BasicAuthService is the service for managing basic auth.
|
|
|
|
type BasicAuthService interface {
|
|
|
|
SetPassword(ctx context.Context, name string, password string) error
|
|
|
|
ComparePassword(ctx context.Context, name string, password string) error
|
|
|
|
CompareAndSetPassword(ctx context.Context, name string, old string, new string) error
|
|
|
|
}
|
|
|
|
|
2018-05-14 16:26:38 +00:00
|
|
|
// UserUpdate represents updates to a user.
|
|
|
|
// Only fields which are set are updated.
|
|
|
|
type UserUpdate struct {
|
|
|
|
Name *string `json:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserFilter represents a set of filter that restrict the returned results.
|
|
|
|
type UserFilter struct {
|
|
|
|
ID *ID
|
|
|
|
Name *string
|
|
|
|
}
|