| package roles |
| |
| import ( |
| "gerrit.mcp.mirantis.net/debian/gophercloud.git" |
| "gerrit.mcp.mirantis.net/debian/gophercloud.git/pagination" |
| ) |
| |
| // ListAssignmentsOptsBuilder allows extensions to add additional parameters to |
| // the ListAssignments request. |
| type ListAssignmentsOptsBuilder interface { |
| ToRolesListAssignmentsQuery() (string, error) |
| } |
| |
| // ListAssignmentsOpts allows you to query the ListAssignments method. |
| // Specify one of or a combination of GroupId, RoleId, ScopeDomainId, ScopeProjectId, |
| // and/or UserId to search for roles assigned to corresponding entities. |
| // Effective lists effective assignments at the user, project, and domain level, |
| // allowing for the effects of group membership. |
| type ListAssignmentsOpts struct { |
| GroupID string `q:"group.id"` |
| RoleID string `q:"role.id"` |
| ScopeDomainID string `q:"scope.domain.id"` |
| ScopeProjectID string `q:"scope.project.id"` |
| UserID string `q:"user.id"` |
| Effective *bool `q:"effective"` |
| } |
| |
| // ToRolesListAssignmentsQuery formats a ListAssignmentsOpts into a query string. |
| func (opts ListAssignmentsOpts) ToRolesListAssignmentsQuery() (string, error) { |
| q, err := gophercloud.BuildQueryString(opts) |
| return q.String(), err |
| } |
| |
| // ListAssignments enumerates the roles assigned to a specified resource. |
| func ListAssignments(client *gophercloud.ServiceClient, opts ListAssignmentsOptsBuilder) pagination.Pager { |
| url := listAssignmentsURL(client) |
| if opts != nil { |
| query, err := opts.ToRolesListAssignmentsQuery() |
| if err != nil { |
| return pagination.Pager{Err: err} |
| } |
| url += query |
| } |
| return pagination.NewPager(client, url, func(r pagination.PageResult) pagination.Page { |
| return RoleAssignmentPage{pagination.LinkedPageBase{PageResult: r}} |
| }) |
| } |