diff --git a/Makefile b/Makefile
index a930f81..5e89480 100644
--- a/Makefile
+++ b/Makefile
@@ -21,7 +21,8 @@ msan: dep ## Run memory sanitizer
coverage: ## Generate global code coverage report
@mkdir -p cover
- go tool cover -html=cover/gonextcloud.cov -o coverage.html
+ @touch cover/${PROJECT_NAME}cov
+ go tool cover -html=cover/${PROJECT_NAME}cov -o coverage.html
dep: ## Get the dependencies
@mkdir -p vendor
diff --git a/cover/gonextcloud.cov b/cover/gonextcloud.cov
deleted file mode 100644
index 9ee0594..0000000
--- a/cover/gonextcloud.cov
+++ /dev/null
@@ -1,128 +0,0 @@
-mode: count
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:15.47,18.16 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:21.2,23.30 3 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:18.16,20.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:26.57,27.16 1 13
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:30.2,31.16 2 12
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:34.2,38.55 4 11
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:41.2,41.25 1 11
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:27.16,29.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:31.16,33.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:38.55,40.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:44.62,49.16 3 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:52.2,54.30 3 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:49.16,51.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:57.87,64.71 2 4
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:67.2,67.17 1 3
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:70.2,70.27 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:64.71,66.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:67.17,69.3 1 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:73.48,75.2 1 3
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:77.48,82.2 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:84.49,89.2 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:91.58,93.2 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:95.53,99.19 4 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:113.2,113.12 1 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:117.2,117.35 1 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:99.19,100.50 1 22
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:100.50,102.38 2 12
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:102.38,104.87 2 12
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:104.87,109.6 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:113.12,116.3 2 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:120.67,122.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:124.79,126.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:128.67,130.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:132.71,134.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:136.71,138.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:140.71,142.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:144.73,146.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:148.64,150.2 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:152.63,154.16 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:157.2,159.31 3 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:154.16,156.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:162.64,169.2 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:171.67,178.2 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:180.68,187.2 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:189.67,196.2 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:198.71,199.19 1 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:202.2,205.16 4 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:208.2,210.24 3 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:199.19,201.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:205.16,207.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:213.83,221.2 2 20
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:223.106,226.2 2 32
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:228.40,230.25 2 44
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:235.2,235.14 1 24
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:230.25,231.15 1 180
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/users.go:231.15,233.4 1 20
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:13.138,14.19 1 52
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:17.2,18.16 2 51
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:21.2,21.20 1 51
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:24.2,28.30 2 51
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:37.2,37.16 1 51
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:41.2,44.34 4 50
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:48.2,48.17 1 48
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:14.19,16.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:18.16,20.3 1 42
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:21.20,23.3 1 7
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:28.30,30.3 1 17
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:30.8,30.38 1 34
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:30.38,32.3 1 7
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:32.8,32.37 1 27
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:32.37,34.3 1 22
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:34.8,34.40 1 5
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:34.40,36.3 1 5
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:37.16,39.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:44.34,47.3 2 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/utils.go:51.39,58.2 4 11
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:9.46,11.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:14.2,16.29 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:11.16,13.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:19.53,24.16 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:27.2,29.29 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:24.16,26.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:32.54,37.16 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:40.2,42.29 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:37.16,39.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:45.59,47.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:50.2,52.24 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:47.16,49.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:55.47,57.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:60.2,62.12 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:57.16,59.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:65.48,67.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:70.2,72.12 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:67.16,69.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/apps.go:75.106,78.2 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:11.64,22.16 7 3
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:25.2,30.19 4 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:34.2,34.12 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:22.16,24.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:30.19,33.3 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:37.33,43.2 4 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:45.34,47.27 1 57
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:50.2,50.45 1 56
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/auth.go:47.27,49.3 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/client.go:58.50,60.16 2 3
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/client.go:67.2,74.16 2 3
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/client.go:60.16,62.17 2 2
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/client.go:62.17,64.4 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:9.48,11.16 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:14.2,16.31 3 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:11.16,13.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:19.60,21.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:24.2,26.30 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:21.16,23.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:29.63,34.16 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:37.2,39.31 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:34.16,36.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:42.49,48.72 2 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:51.2,51.12 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:48.72,50.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:54.49,55.77 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:58.2,58.12 1 1
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:55.77,57.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:61.67,63.16 2 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:66.2,68.30 3 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:63.16,65.3 1 0
-gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/groups.go:71.107,74.2 2 2
diff --git a/cover/gonextcloudcov b/cover/gonextcloudcov
new file mode 100644
index 0000000..e69de29
diff --git a/coverage.html b/coverage.html
index 8eb2c7b..0a94f02 100644
--- a/coverage.html
+++ b/coverage.html
@@ -54,18 +54,6 @@
-
package gonextcloud
-
-import (
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
- "net/http"
-)
-
-func (c *Client) AppList() ([]string, error) {
- res, err := c.baseRequest(routes.apps, "", "", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.AppListResponse
- res.JSON(&r)
- return r.Ocs.Data.Apps, nil
-}
-
-func (c *Client) AppListEnabled() ([]string, error) {
- ro := &req.RequestOptions{
- Params: map[string]string{"filter": "enabled"},
- }
- res, err := c.baseRequest(routes.apps, "", "", ro, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.AppListResponse
- res.JSON(&r)
- return r.Ocs.Data.Apps, nil
-}
-
-func (c *Client) AppListDisabled() ([]string, error) {
- ro := &req.RequestOptions{
- Params: map[string]string{"filter": "disabled"},
- }
- res, err := c.baseRequest(routes.apps, "", "", ro, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.AppListResponse
- res.JSON(&r)
- return r.Ocs.Data.Apps, nil
-}
-
-func (c *Client) AppInfos(name string) (types.App, error) {
- res, err := c.baseRequest(routes.apps, name, "", nil, http.MethodGet)
- if err != nil {
- return types.App{}, err
- }
- var r types.AppResponse
- res.JSON(&r)
- return r.Ocs.Data, nil
-}
-
-func (c *Client) AppEnable(name string) error {
- res, err := c.baseRequest(routes.apps, name, "", nil, http.MethodPut)
- if err != nil {
- return err
- }
- var r types.BaseResponse
- res.JSON(&r)
- return nil
-}
-
-func (c *Client) AppDisable(name string) error {
- res, err := c.baseRequest(routes.apps, name, "", nil, http.MethodDelete)
- if err != nil {
- return err
- }
- var r types.BaseResponse
- res.JSON(&r)
- return nil
-}
-
-func (c *Client) appsBaseRequest(name string, route string, ro *req.RequestOptions, method string) error {
- _, err := c.baseRequest(routes.apps, name, route, ro, method)
- return err
-}
-
-
-
package gonextcloud
-
-import (
- "fmt"
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
-)
-
-var unauthorized = fmt.Errorf("login first")
-
-func (c *Client) Login(username string, password string) error {
- c.username = username
- c.password = password
- options := req.RequestOptions{
- Headers: c.headers,
- Auth: []string{c.username, c.password},
- }
- c.session = req.NewSession(&options)
- // TODO What to do with capabilities ? (other thant connection validation)
- u := c.baseURL.ResolveReference(routes.capabilities)
- res, err := c.session.Get(u.String(), nil)
- if err != nil {
- return err
- }
- var r types.CapabilitiesResponse
- res.JSON(&r)
- // No need to check for Ocs.Meta.StatusCode as capabilities are always returned
- c.capabilities = &r.Ocs.Data.Capabilities
- // Check if authentication failed
- if !c.loggedIn() {
- e := types.APIError{Message: "authentication failed"}
- return &e
- }
- return nil
-}
-
-func (c *Client) Logout() error {
- c.session.CloseIdleConnections()
- c.session.HTTPClient.Jar = nil
- // Clear capabilities as it is used to check for valid authentication
- c.capabilities = nil
- return nil
-}
-
-func (c *Client) loggedIn() bool {
- // When authentication failed, capabilities doesn't contains core information
- if c.capabilities == nil {
- return false
- }
- return c.capabilities.Core.WebdavRoot != ""
-}
-
-
-
/*
-Package client is a Go client for the Nextcloud Provisioning API.
-
-For more information about the Provisioning API, see the documentation:
-https://docs.nextcloud.com/server/13/admin_manual/configuration_user/user_provisioning_api.html
-
-Usage
-
-You use the library by creating a client object and calling methods on it.
-
-For example, to list all the Nextcloud's instance users:
-
- package main
-
- import (
- "fmt"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/client"
- )
-
- func main() {
- url := "https://www.mynextcloud.com"
- username := "admin"
- password := "password"
- c, err := client.NewClient(url)
- if err != nil {
- panic(err)
- }
- if err := c.Login(username, password); err != nil {
- panic(err)
- }
- defer c.Logout()
-
- users, err := c.UserList()
- if err != nil {
- panic(err)
- }
- fmt.Println("Users :", users)
- }
-*/
-
-package gonextcloud
-
-import (
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
- "net/url"
-)
-
-type Client struct {
- baseURL *url.URL
- username string
- password string
- session *req.Session
- headers map[string]string
- capabilities *types.Capabilities
-}
-
-func NewClient(hostname string) (*Client, error) {
- baseURL, err := url.ParseRequestURI(hostname)
- if err != nil {
- baseURL, err = url.ParseRequestURI("https://" + hostname)
- if err != nil {
- return nil, err
- }
- }
-
- c := Client{
- baseURL: baseURL,
- headers: map[string]string{
- "OCS-APIREQUEST": "true",
- "Accept": "application/json",
- },
- }
- return &c, nil
-}
-
-
-
package gonextcloud
-
-import (
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
- "net/http"
-)
-
-func (c *Client) GroupList() ([]string, error) {
- res, err := c.baseRequest(routes.groups, "", "", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.GroupListResponse
- res.JSON(&r)
- return r.Ocs.Data.Groups, nil
-}
-
-func (c *Client) GroupUsers(name string) ([]string, error) {
- res, err := c.baseRequest(routes.groups, name, "", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.UserListResponse
- res.JSON(&r)
- return r.Ocs.Data.Users, nil
-}
-
-func (c *Client) GroupSearch(search string) ([]string, error) {
- ro := &req.RequestOptions{
- Params: map[string]string{"search": search},
- }
- res, err := c.baseRequest(routes.groups, "", "", ro, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.GroupListResponse
- res.JSON(&r)
- return r.Ocs.Data.Groups, nil
-}
-
-func (c *Client) GroupCreate(name string) error {
- ro := &req.RequestOptions{
- Data: map[string]string{
- "groupid": name,
- },
- }
- if err := c.groupBaseRequest("", "", ro, http.MethodPost); err != nil {
- return err
- }
- return nil
-}
-
-func (c *Client) GroupDelete(name string) error {
- if err := c.groupBaseRequest(name, "", nil, http.MethodDelete); err != nil {
- return err
- }
- return nil
-}
-
-func (c *Client) GroupSubAdminList(name string) ([]string, error) {
- res, err := c.baseRequest(routes.groups, name, "subadmins", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.UserListResponse
- res.JSON(&r)
- return r.Ocs.Data.Users, nil
-}
-
-func (c *Client) groupBaseRequest(name string, route string, ro *req.RequestOptions, method string) error {
- _, err := c.baseRequest(routes.groups, name, route, ro, method)
- return err
-}
-
-
-
package gonextcloud
-
-import (
- "encoding/json"
- "github.com/fatih/structs"
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
- "net/http"
- "path"
- "strconv"
- "strings"
- "sync"
-)
-
-func (c *Client) UserList() ([]string, error) {
- res, err := c.baseRequest(routes.users, "", "", nil, http.MethodGet)
- //res, err := c.session.Get(u.String(), nil)
- if err != nil {
- return nil, err
- }
- var r types.UserListResponse
- res.JSON(&r)
- return r.Ocs.Data.Users, nil
-}
-
-func (c *Client) User(name string) (*types.User, error) {
- if name == "" {
- return nil, &types.APIError{Message: "name cannot be empty"}
- }
- res, err := c.baseRequest(routes.users, name, "", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- 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
- }
- return &r.Ocs.Data, nil
-}
-
-func (c *Client) UserSearch(search string) ([]string, error) {
- ro := &req.RequestOptions{
- Params: map[string]string{"search": search},
- }
- res, err := c.baseRequest(routes.users, "", "", ro, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.UserListResponse
- res.JSON(&r)
- return r.Ocs.Data.Users, nil
-}
-
-func (c *Client) UserCreate(username string, password string, user *types.User) error {
- ro := &req.RequestOptions{
- Data: map[string]string{
- "userid": username,
- "password": password,
- },
- }
- if err := c.userBaseRequest("", "", ro, http.MethodPost); err != nil {
- return err
- }
- if user == nil {
- return nil
- }
- return c.UserUpdate(user)
-}
-
-func (c *Client) UserDelete(name string) error {
- return c.userBaseRequest(name, "", nil, http.MethodDelete)
-}
-
-func (c *Client) UserEnable(name string) error {
- ro := &req.RequestOptions{
- Data: map[string]string{},
- }
- return c.userBaseRequest(name, "enable", ro, http.MethodPut)
-}
-
-func (c *Client) UserDisable(name string) error {
- ro := &req.RequestOptions{
- Data: map[string]string{},
- }
- return c.userBaseRequest(name, "disable", ro, http.MethodPut)
-}
-
-func (c *Client) UserSendWelcomeEmail(name string) error {
- return c.userBaseRequest(name, "welcome", nil, http.MethodPost)
-}
-
-func (c *Client) UserUpdate(user *types.User) error {
- m := structs.Map(user)
- errs := make(chan types.UpdateError)
- var wg sync.WaitGroup
- for k := range m {
- if !ignoredUserField(k) && m[k].(string) != "" {
- wg.Add(1)
- go func(key string, value string) {
- defer wg.Done()
- if err := c.userUpdateAttribute(user.ID, strings.ToLower(key), value); err != nil {
- errs <- types.UpdateError{
- Field: key,
- Error: err,
- }
- }
- }(k, m[k].(string))
- }
- }
- go func() {
- wg.Wait()
- close(errs)
- }()
- return types.NewUpdateError(errs)
-}
-
-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 int) error {
- return c.userUpdateAttribute(name, "quota", strconv.Itoa(quota))
-}
-
-func (c *Client) UserGroupList(name string) ([]string, error) {
- res, err := c.baseRequest(routes.users, name, "groups", nil, http.MethodGet)
- if err != nil {
- return nil, err
- }
- var r types.GroupListResponse
- res.JSON(&r)
- 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
- }
- var r types.BaseResponse
- res.JSON(&r)
- 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,
- },
- }
- return c.userBaseRequest(name, "", ro, http.MethodPut)
-}
-
-func (c *Client) userBaseRequest(name string, route string, ro *req.RequestOptions, method string) error {
- _, err := c.baseRequest(routes.users, name, route, ro, method)
- return err
-}
-
-func ignoredUserField(key string) bool {
- keys := []string{"ID", "Quota", "Enabled", "Groups", "Language"}
- for _, k := range keys {
- if key == k {
- return true
- }
- }
- return false
-}
-
-
-
package gonextcloud
-
-import (
- "encoding/json"
- req "github.com/levigross/grequests"
- "gitlab.adphi.fr/partitio/Nextcloud-Partitio/gonextcloud/types"
- "net/http"
- "net/url"
- "path"
- "strings"
-)
-
-func (c *Client) baseRequest(route *url.URL, name string, subroute string, ro *req.RequestOptions, method string) (*req.Response, error) {
- if !c.loggedIn() {
- return nil, unauthorized
- }
- u := c.baseURL.ResolveReference(route)
- if name != "" {
- u.Path = path.Join(u.Path, name)
- }
- if subroute != "" {
- u.Path = path.Join(u.Path, subroute)
- }
- var (
- res *req.Response
- err error
- )
- if method == http.MethodGet {
- res, err = c.session.Get(u.String(), ro)
- } else if method == http.MethodPost {
- res, err = c.session.Post(u.String(), ro)
- } else if method == http.MethodPut {
- res, err = c.session.Put(u.String(), ro)
- } else if method == http.MethodDelete {
- res, err = c.session.Delete(u.String(), ro)
- }
- if err != nil {
- return nil, err
- }
- // As we cannot read the ReaderCloser twice, we use the string content
- js := res.String()
- var r types.BaseResponse
- json.Unmarshal([]byte(js), &r)
- if r.Ocs.Meta.Statuscode != 100 {
- err := types.ErrorFromMeta(r.Ocs.Meta)
- return nil, err
- }
- return res, nil
-}
-
-func reformatJSON(json string) string {
- // Nextcloud encode boolean as string
- json = strings.Replace(json, "\"true\"", "true", -1)
- json = strings.Replace(json, "\"false\"", "false", -1)
- // Nextcloud encode quota as an empty array for never connected users
- json = strings.Replace(json, "\"quota\":[],", "", -1)
- return json
-}
-
-