mirror of
				https://gitlab.bertha.cloud/partitio/Nextcloud-Partitio/gonextcloud
				synced 2025-11-04 06:21:45 +00:00 
			
		
		
		
	Add user update/enable/disable/welcome-mail
This commit is contained in:
		
							
								
								
									
										34
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								README.md
									
									
									
									
									
								
							@@ -11,17 +11,17 @@ A simple Client for Nextcloud's API in Go.
 | 
				
			|||||||
  - ~~list~~
 | 
					  - ~~list~~
 | 
				
			||||||
  - ~~get infos~~
 | 
					  - ~~get infos~~
 | 
				
			||||||
  - ~~create~~
 | 
					  - ~~create~~
 | 
				
			||||||
  - update
 | 
					  - ~~update~~
 | 
				
			||||||
  - ~~delete~~
 | 
					  - ~~delete~~
 | 
				
			||||||
  - enable
 | 
					  - ~~enable~~
 | 
				
			||||||
  - disable
 | 
					  - ~~disable~~
 | 
				
			||||||
  - get groups
 | 
					  - get groups
 | 
				
			||||||
  - add to group
 | 
					  - add to group
 | 
				
			||||||
  - remove from group
 | 
					  - remove from group
 | 
				
			||||||
  - get subadmin group
 | 
					  - get subadmin group
 | 
				
			||||||
  - promote subadmin
 | 
					  - promote subadmin
 | 
				
			||||||
  - demote subadmin
 | 
					  - demote subadmin
 | 
				
			||||||
  - send welcome mail
 | 
					  - ~~send welcome mail~~ 
 | 
				
			||||||
- [Groups](#groups)
 | 
					- [Groups](#groups)
 | 
				
			||||||
  - create
 | 
					  - create
 | 
				
			||||||
  - delete
 | 
					  - delete
 | 
				
			||||||
@@ -78,6 +78,32 @@ Delete
 | 
				
			|||||||
```go
 | 
					```go
 | 
				
			||||||
func (c *Client) UserDelete(name string) error 
 | 
					func (c *Client) UserDelete(name string) error 
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					Enable
 | 
				
			||||||
 | 
					```go
 | 
				
			||||||
 | 
					func (c *Client) UserEnable(name string) error 
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Disable
 | 
				
			||||||
 | 
					```go
 | 
				
			||||||
 | 
					func (c *Client) UserDisable(name string) error 
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Update
 | 
				
			||||||
 | 
					```go
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateEmail(name string, email string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateDisplayName(name string, displayName string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdatePhone(name string, phone string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateAddress(name string, address string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateWebSite(name string, website string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateTwitter(name string, twitter string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdatePassword(name string, password string) error
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateQuota(name string, quota string) error
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
## Groups
 | 
					## Groups
 | 
				
			||||||
TODO
 | 
					TODO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										118
									
								
								client/users.go
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								client/users.go
									
									
									
									
									
								
							@@ -74,7 +74,6 @@ func (c *Client) UserCreate(username string, password string) error {
 | 
				
			|||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	fmt.Println(res.String())
 | 
					 | 
				
			||||||
	var r types.UserResponse
 | 
						var r types.UserResponse
 | 
				
			||||||
	res.JSON(&r)
 | 
						res.JSON(&r)
 | 
				
			||||||
	if r.Ocs.Meta.Statuscode != 100 {
 | 
						if r.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
@@ -94,7 +93,122 @@ func (c *Client) UserDelete(name string) error {
 | 
				
			|||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	var ur types.UserResponse
 | 
						var ur types.UserResponse
 | 
				
			||||||
	fmt.Println(res.String())
 | 
						res.JSON(&ur)
 | 
				
			||||||
 | 
						if ur.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
 | 
							return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserEnable(name string) error {
 | 
				
			||||||
 | 
						if !c.loggedIn() {
 | 
				
			||||||
 | 
							return unauthorized
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						u := c.baseURL.ResolveReference(routes.users)
 | 
				
			||||||
 | 
						u.Path = path.Join(u.Path, name, "enable")
 | 
				
			||||||
 | 
						ro := &req.RequestOptions{
 | 
				
			||||||
 | 
							Data: map[string]string{},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						res, err := c.session.Put(u.String(), ro)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						var ur types.UserResponse
 | 
				
			||||||
 | 
						res.JSON(&ur)
 | 
				
			||||||
 | 
						if ur.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
 | 
							return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserDisable(name string) error {
 | 
				
			||||||
 | 
						if !c.loggedIn() {
 | 
				
			||||||
 | 
							return unauthorized
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						u := c.baseURL.ResolveReference(routes.users)
 | 
				
			||||||
 | 
						u.Path = path.Join(u.Path, name, "disable")
 | 
				
			||||||
 | 
						ro := &req.RequestOptions{
 | 
				
			||||||
 | 
							Data: map[string]string{},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						res, err := c.session.Put(u.String(), ro)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						var ur types.UserResponse
 | 
				
			||||||
 | 
						res.JSON(&ur)
 | 
				
			||||||
 | 
						if ur.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
 | 
							return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserSendWelcomeEmail(name string) error {
 | 
				
			||||||
 | 
						if !c.loggedIn() {
 | 
				
			||||||
 | 
							return unauthorized
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						u := c.baseURL.ResolveReference(routes.users)
 | 
				
			||||||
 | 
						u.Path = path.Join(u.Path, name, "welcome")
 | 
				
			||||||
 | 
						res, err := c.session.Post(u.String(), nil)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						var ur types.UserResponse
 | 
				
			||||||
 | 
						res.JSON(&ur)
 | 
				
			||||||
 | 
						if ur.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
 | 
							return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) UserUpdateQuota(name string, quota string) error {
 | 
				
			||||||
 | 
						return c.userUpdateAttribute(name, "quota", quota)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (c *Client) userUpdateAttribute(name string, key string, value string) error {
 | 
				
			||||||
 | 
						if !c.loggedIn() {
 | 
				
			||||||
 | 
							return unauthorized
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						u := c.baseURL.ResolveReference(routes.users)
 | 
				
			||||||
 | 
						u.Path = path.Join(u.Path, name)
 | 
				
			||||||
 | 
						ro := &req.RequestOptions{
 | 
				
			||||||
 | 
							Data: map[string]string{
 | 
				
			||||||
 | 
								"key":   key,
 | 
				
			||||||
 | 
								"value": value,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						res, err := c.session.Put(u.String(), ro)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							return err
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						var ur types.UserResponse
 | 
				
			||||||
	res.JSON(&ur)
 | 
						res.JSON(&ur)
 | 
				
			||||||
	if ur.Ocs.Meta.Statuscode != 100 {
 | 
						if ur.Ocs.Meta.Statuscode != 100 {
 | 
				
			||||||
		return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
							return fmt.Errorf(ur.Ocs.Meta.Message)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user