// Package adminschema provides access to the Dex Admin API. // // See http://github.com/coreos/dex // // Usage example: // // import "google.golang.org/api/adminschema/v1" // ... // adminschemaService, err := adminschema.New(oauthHttpClient) package adminschema import ( "bytes" "encoding/json" "errors" "fmt" "io" "net/http" "net/url" "strconv" "strings" "google.golang.org/api/googleapi" ) // Always reference these packages, just in case the auto-generated code // below doesn't. var _ = bytes.NewBuffer var _ = strconv.Itoa var _ = fmt.Sprintf var _ = json.NewDecoder var _ = io.Copy var _ = url.Parse var _ = googleapi.Version var _ = errors.New var _ = strings.Replace const apiId = "dex:v1" const apiName = "adminschema" const apiVersion = "v1" const basePath = "$ENDPOINT/api/v1/" func New(client *http.Client) (*Service, error) { if client == nil { return nil, errors.New("client is nil") } s := &Service{client: client, BasePath: basePath} s.Admin = NewAdminService(s) s.Client = NewClientService(s) s.State = NewStateService(s) return s, nil } type Service struct { client *http.Client BasePath string // API endpoint base URL Admin *AdminService Client *ClientService State *StateService } func NewAdminService(s *Service) *AdminService { rs := &AdminService{s: s} return rs } type AdminService struct { s *Service } func NewClientService(s *Service) *ClientService { rs := &ClientService{s: s} return rs } type ClientService struct { s *Service } func NewStateService(s *Service) *StateService { rs := &StateService{s: s} return rs } type StateService struct { s *Service } type Admin struct { Email string `json:"email,omitempty"` Id string `json:"id,omitempty"` Password string `json:"password,omitempty"` } type ClientCreateRequest struct { Client *ClientCreateRequestClient `json:"client,omitempty"` IsAdmin bool `json:"isAdmin,omitempty"` } type ClientCreateRequestClient struct { // Client_name: OPTIONAL. Name of the Client to be presented to the // End-User. If desired, representation of this Claim in different // languages and scripts is represented as described in Section 2.1 ( // Metadata Languages and Scripts ) . Client_name string `json:"client_name,omitempty"` // Client_uri: OPTIONAL. URL of the home page of the Client. The value // of this field MUST point to a valid Web page. If present, the server // SHOULD display this URL to the End-User in a followable fashion. If // desired, representation of this Claim in different languages and // scripts is represented as described in Section 2.1 ( Metadata // Languages and Scripts ) . Client_uri string `json:"client_uri,omitempty"` // Logo_uri: OPTIONAL. URL that references a logo for the Client // application. If present, the server SHOULD display this image to the // End-User during approval. The value of this field MUST point to a // valid image file. If desired, representation of this Claim in // different languages and scripts is represented as described in // Section 2.1 ( Metadata Languages and Scripts ) . Logo_uri string `json:"logo_uri,omitempty"` // Redirect_uris: REQUIRED. Array of Redirection URI values used by the // Client. One of these registered Redirection URI values MUST exactly // match the redirect_uri parameter value used in each Authorization // Request, with the matching performed as described in Section 6.2.1 of // [RFC3986] ( Berners-Lee, T., Fielding, R., and L. Masinter, // “Uniform Resource Identifier (URI): Generic Syntax,” January // 2005. ) (Simple String Comparison). Redirect_uris []string `json:"redirect_uris,omitempty"` } type ClientRegistrationResponse struct { Client_id string `json:"client_id,omitempty"` Client_secret string `json:"client_secret,omitempty"` } type State struct { AdminUserCreated bool `json:"AdminUserCreated,omitempty"` } // method id "dex.admin.Admin.Create": type AdminCreateCall struct { s *Service admin *Admin opt_ map[string]interface{} } // Create: Create a new admin user. func (r *AdminService) Create(admin *Admin) *AdminCreateCall { c := &AdminCreateCall{s: r.s, opt_: make(map[string]interface{})} c.admin = admin return c } // Fields allows partial responses to be retrieved. // See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse // for more information. func (c *AdminCreateCall) Fields(s ...googleapi.Field) *AdminCreateCall { c.opt_["fields"] = googleapi.CombineFields(s) return c } func (c *AdminCreateCall) Do() (*Admin, error) { var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.admin) if err != nil { return nil, err } ctype := "application/json" params := make(url.Values) params.Set("alt", "json") if v, ok := c.opt_["fields"]; ok { params.Set("fields", fmt.Sprintf("%v", v)) } urls := googleapi.ResolveRelative(c.s.BasePath, "admin") urls += "?" + params.Encode() req, _ := http.NewRequest("POST", urls, body) googleapi.SetOpaque(req.URL) req.Header.Set("Content-Type", ctype) req.Header.Set("User-Agent", "google-api-go-client/0.5") res, err := c.s.client.Do(req) if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, err } var ret *Admin if err := json.NewDecoder(res.Body).Decode(&ret); err != nil { return nil, err } return ret, nil // { // "description": "Create a new admin user.", // "httpMethod": "POST", // "id": "dex.admin.Admin.Create", // "path": "admin", // "request": { // "$ref": "Admin" // }, // "response": { // "$ref": "Admin" // } // } } // method id "dex.admin.Admin.Get": type AdminGetCall struct { s *Service id string opt_ map[string]interface{} } // Get: Retrieve information about an admin user. func (r *AdminService) Get(id string) *AdminGetCall { c := &AdminGetCall{s: r.s, opt_: make(map[string]interface{})} c.id = id return c } // Fields allows partial responses to be retrieved. // See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse // for more information. func (c *AdminGetCall) Fields(s ...googleapi.Field) *AdminGetCall { c.opt_["fields"] = googleapi.CombineFields(s) return c } func (c *AdminGetCall) Do() (*Admin, error) { var body io.Reader = nil params := make(url.Values) params.Set("alt", "json") if v, ok := c.opt_["fields"]; ok { params.Set("fields", fmt.Sprintf("%v", v)) } urls := googleapi.ResolveRelative(c.s.BasePath, "admin/{id}") urls += "?" + params.Encode() req, _ := http.NewRequest("GET", urls, body) googleapi.Expand(req.URL, map[string]string{ "id": c.id, }) req.Header.Set("User-Agent", "google-api-go-client/0.5") res, err := c.s.client.Do(req) if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, err } var ret *Admin if err := json.NewDecoder(res.Body).Decode(&ret); err != nil { return nil, err } return ret, nil // { // "description": "Retrieve information about an admin user.", // "httpMethod": "GET", // "id": "dex.admin.Admin.Get", // "parameterOrder": [ // "id" // ], // "parameters": { // "id": { // "location": "path", // "required": true, // "type": "string" // } // }, // "path": "admin/{id}", // "response": { // "$ref": "Admin" // } // } } // method id "dex.admin.Client.Create": type ClientCreateCall struct { s *Service clientcreaterequest *ClientCreateRequest opt_ map[string]interface{} } // Create: Register an OpenID Connect client. func (r *ClientService) Create(clientcreaterequest *ClientCreateRequest) *ClientCreateCall { c := &ClientCreateCall{s: r.s, opt_: make(map[string]interface{})} c.clientcreaterequest = clientcreaterequest return c } // Fields allows partial responses to be retrieved. // See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse // for more information. func (c *ClientCreateCall) Fields(s ...googleapi.Field) *ClientCreateCall { c.opt_["fields"] = googleapi.CombineFields(s) return c } func (c *ClientCreateCall) Do() (*ClientRegistrationResponse, error) { var body io.Reader = nil body, err := googleapi.WithoutDataWrapper.JSONReader(c.clientcreaterequest) if err != nil { return nil, err } ctype := "application/json" params := make(url.Values) params.Set("alt", "json") if v, ok := c.opt_["fields"]; ok { params.Set("fields", fmt.Sprintf("%v", v)) } urls := googleapi.ResolveRelative(c.s.BasePath, "client") urls += "?" + params.Encode() req, _ := http.NewRequest("POST", urls, body) googleapi.SetOpaque(req.URL) req.Header.Set("Content-Type", ctype) req.Header.Set("User-Agent", "google-api-go-client/0.5") res, err := c.s.client.Do(req) if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, err } var ret *ClientRegistrationResponse if err := json.NewDecoder(res.Body).Decode(&ret); err != nil { return nil, err } return ret, nil // { // "description": "Register an OpenID Connect client.", // "httpMethod": "POST", // "id": "dex.admin.Client.Create", // "path": "client", // "request": { // "$ref": "ClientCreateRequest" // }, // "response": { // "$ref": "ClientRegistrationResponse" // } // } } // method id "dex.admin.State.Get": type StateGetCall struct { s *Service opt_ map[string]interface{} } // Get: Get the state of the Dex DB func (r *StateService) Get() *StateGetCall { c := &StateGetCall{s: r.s, opt_: make(map[string]interface{})} return c } // Fields allows partial responses to be retrieved. // See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse // for more information. func (c *StateGetCall) Fields(s ...googleapi.Field) *StateGetCall { c.opt_["fields"] = googleapi.CombineFields(s) return c } func (c *StateGetCall) Do() (*State, error) { var body io.Reader = nil params := make(url.Values) params.Set("alt", "json") if v, ok := c.opt_["fields"]; ok { params.Set("fields", fmt.Sprintf("%v", v)) } urls := googleapi.ResolveRelative(c.s.BasePath, "state") urls += "?" + params.Encode() req, _ := http.NewRequest("GET", urls, body) googleapi.SetOpaque(req.URL) req.Header.Set("User-Agent", "google-api-go-client/0.5") res, err := c.s.client.Do(req) if err != nil { return nil, err } defer googleapi.CloseBody(res) if err := googleapi.CheckResponse(res); err != nil { return nil, err } var ret *State if err := json.NewDecoder(res.Body).Decode(&ret); err != nil { return nil, err } return ret, nil // { // "description": "Get the state of the Dex DB", // "httpMethod": "GET", // "id": "dex.admin.State.Get", // "path": "state", // "response": { // "$ref": "State" // } // } }