gonextcloud/client/users.go

235 lines
5.8 KiB
Go
Raw Normal View History

package client
import (
2018-07-24 18:26:12 +00:00
"encoding/json"
req "github.com/levigross/grequests"
"github.com/partitio/gonextcloud/client/types"
2018-07-05 13:22:56 +00:00
"net/http"
"path"
2018-07-24 18:26:12 +00:00
"strconv"
)
func (c *Client) UserList() ([]string, error) {
if !c.loggedIn() {
return nil, unauthorized
}
u := c.baseURL.ResolveReference(routes.users)
res, err := c.session.Get(u.String(), nil)
if err != nil {
return nil, err
}
2018-07-24 18:26:12 +00:00
var r types.UserListResponse
res.JSON(&r)
return r.Ocs.Data.Users, nil
}
func (c *Client) User(name string) (*types.User, error) {
2018-07-24 18:26:12 +00:00
if name == "" {
return nil, &types.APIError{Message: "name cannot be empty"}
}
if !c.loggedIn() {
return nil, unauthorized
}
u := c.baseURL.ResolveReference(routes.users)
u.Path = path.Join(u.Path, name)
res, err := c.session.Get(u.String(), nil)
if err != nil {
return nil, err
}
2018-07-24 18:26:12 +00:00
var r types.UserResponse
js := res.String()
// Nextcloud does not encode JSON properly
js = reformatJSON(js)
if err := json.Unmarshal([]byte(js), &r); err != nil {
return nil, err
}
2018-07-24 18:26:12 +00:00
if r.Ocs.Meta.Statuscode != 100 {
e := types.ErrorFromMeta(r.Ocs.Meta)
return nil, &e
}
return &r.Ocs.Data, nil
}
func (c *Client) UserSearch(search string) ([]string, error) {
if !c.loggedIn() {
return nil, unauthorized
}
u := c.baseURL.ResolveReference(routes.users)
ro := &req.RequestOptions{
Params: map[string]string{"search": search},
}
res, err := c.session.Get(u.String(), ro)
if err != nil {
return nil, err
}
var r types.UserListResponse
res.JSON(&r)
if r.Ocs.Meta.Statuscode != 100 {
2018-07-24 18:26:12 +00:00
e := types.ErrorFromMeta(r.Ocs.Meta)
return nil, &e
}
return r.Ocs.Data.Users, nil
}
func (c *Client) UserCreate(username string, password string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"userid": username,
"password": password,
},
}
2018-07-05 13:22:56 +00:00
return c.userBaseRequest("", "", ro, http.MethodPost)
}
func (c *Client) UserDelete(name string) error {
2018-07-05 13:22:56 +00:00
return c.userBaseRequest(name, "", nil, http.MethodDelete)
}
func (c *Client) UserEnable(name string) error {
ro := &req.RequestOptions{
Data: map[string]string{},
}
2018-07-05 13:22:56 +00:00
return c.userBaseRequest(name, "enable", ro, http.MethodPut)
}
func (c *Client) UserDisable(name string) error {
ro := &req.RequestOptions{
Data: map[string]string{},
}
2018-07-05 13:22:56 +00:00
return c.userBaseRequest(name, "disable", ro, http.MethodPut)
}
func (c *Client) UserSendWelcomeEmail(name string) error {
2018-07-05 13:22:56 +00:00
return c.userBaseRequest(name, "welcome", nil, http.MethodPost)
}
func (c *Client) UserUpdateEmail(name string, email string) error {
return c.userUpdateAttribute(name, "email", email)
}
func (c *Client) UserUpdateDisplayName(name string, displayName string) error {
return c.userUpdateAttribute(name, "displayname", displayName)
}
func (c *Client) UserUpdatePhone(name string, phone string) error {
return c.userUpdateAttribute(name, "phone", phone)
}
func (c *Client) UserUpdateAddress(name string, address string) error {
return c.userUpdateAttribute(name, "address", address)
}
func (c *Client) UserUpdateWebSite(name string, website string) error {
return c.userUpdateAttribute(name, "website", website)
}
func (c *Client) UserUpdateTwitter(name string, twitter string) error {
return c.userUpdateAttribute(name, "twitter", twitter)
}
func (c *Client) UserUpdatePassword(name string, password string) error {
return c.userUpdateAttribute(name, "password", password)
}
2018-07-24 18:26:12 +00:00
func (c *Client) UserUpdateQuota(name string, quota int) error {
return c.userUpdateAttribute(name, "quota", strconv.Itoa(quota))
}
2018-07-05 14:15:51 +00:00
func (c *Client) UserGroupList(name string) ([]string, error) {
if !c.loggedIn() {
return nil, unauthorized
}
u := c.baseURL.ResolveReference(routes.users)
u.Path = path.Join(u.Path, name, "groups")
res, err := c.session.Get(u.String(), nil)
if err != nil {
return nil, err
}
var r types.GroupListResponse
res.JSON(&r)
if r.Ocs.Meta.Statuscode != 100 {
2018-07-24 18:26:12 +00:00
e := types.ErrorFromMeta(r.Ocs.Meta)
return nil, &e
2018-07-05 14:15:51 +00:00
}
return r.Ocs.Data.Groups, nil
}
func (c *Client) UserGroupAdd(name string, group string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"groupid": group,
},
}
return c.userBaseRequest(name, "groups", ro, http.MethodPost)
}
func (c *Client) UserGroupRemove(name string, group string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"groupid": group,
},
}
return c.userBaseRequest(name, "groups", ro, http.MethodDelete)
}
func (c *Client) UserGroupPromote(name string, group string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"groupid": group,
},
}
return c.userBaseRequest(name, "subadmins", ro, http.MethodPost)
}
func (c *Client) UserGroupDemote(name string, group string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"groupid": group,
},
}
return c.userBaseRequest(name, "subadmins", ro, http.MethodDelete)
}
func (c *Client) UserGroupSubAdminList(name string) ([]string, error) {
if !c.loggedIn() {
return nil, unauthorized
}
u := c.baseURL.ResolveReference(routes.users)
u.Path = path.Join(u.Path, name, "subadmins")
res, err := c.session.Get(u.String(), nil)
if err != nil {
return nil, err
}
2018-07-09 10:53:53 +00:00
var r types.BaseResponse
2018-07-05 14:15:51 +00:00
res.JSON(&r)
if r.Ocs.Meta.Statuscode != 100 {
2018-07-24 18:26:12 +00:00
e := types.ErrorFromMeta(r.Ocs.Meta)
return nil, &e
2018-07-05 14:15:51 +00:00
}
return r.Ocs.Data, nil
}
func (c *Client) userUpdateAttribute(name string, key string, value string) error {
ro := &req.RequestOptions{
Data: map[string]string{
"key": key,
"value": value,
},
}
2018-07-05 13:22:56 +00:00
return c.userBaseRequest(name, "", ro, http.MethodPut)
}
func (c *Client) userBaseRequest(name string, route string, ro *req.RequestOptions, method string) error {
2018-07-09 10:53:53 +00:00
res, err := c.baseRequest(routes.users, name, route, ro, method)
if err != nil {
return err
}
2018-07-24 18:26:12 +00:00
var r types.UserResponse
res.JSON(&r)
if r.Ocs.Meta.Statuscode != 100 {
e := types.ErrorFromMeta(r.Ocs.Meta)
return &e
}
return nil
}