From d6c8f206b29406027a4b25225310c2a12dbeb053 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 11:05:28 -0500 Subject: [PATCH 01/32] ddl for organizations and memberships (#537) --- .../postgresql/030_v0_4_45_organizations.sql | 27 +++++++++++++++++++ .../sql/sqlite3/030_v0_4_45_organizations.sql | 27 +++++++++++++++++++ 2 files changed, 54 insertions(+) create mode 100644 controller/store/sql/postgresql/030_v0_4_45_organizations.sql create mode 100644 controller/store/sql/sqlite3/030_v0_4_45_organizations.sql diff --git a/controller/store/sql/postgresql/030_v0_4_45_organizations.sql b/controller/store/sql/postgresql/030_v0_4_45_organizations.sql new file mode 100644 index 00000000..6f6e8470 --- /dev/null +++ b/controller/store/sql/postgresql/030_v0_4_45_organizations.sql @@ -0,0 +1,27 @@ +-- +migrate Up + +create table organizations ( + id serial primary key, + + token varchar(32) not null, + description varchar(128), + + created_at timestamptz not null default(current_timestamp), + updated_at timestamptz not null default(current_timestamp), + deleted boolean not null default(false) +); + +create index organizations_token_idx on organizations(token); + +create table organization_members ( + id serial primary key, + + organization_id integer references organizations(id) not null, + account_id integer references accounts(id) not null, + admin boolean not null default(false), + + created_at timestamptz not null default(current_timestamp), + updated_at timestamptz not null default(current_timestamp) +); + +create index organization_members_account_id_idx on organization_members(account_id); \ No newline at end of file diff --git a/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql b/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql new file mode 100644 index 00000000..67975605 --- /dev/null +++ b/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql @@ -0,0 +1,27 @@ +-- +migrate Up + +create table organizations ( + id serial primary key, + + token varchar(32) not null, + description varchar(128), + + created_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + updated_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + deleted boolean not null default(false) +); + +create index organization_token_idx on organizations(token); + +create table organization_members ( + id serial primary key, + + organization_id integer references organizations(id) not null, + account_id integer references accounts(id) not null, + admin boolean not null default(false), + + created_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')), + updated_at datetime not null default(strftime('%Y-%m-%d %H:%M:%f', 'now')) +); + +create index organization_members_account_id_idx on organization_members(account_id); \ No newline at end of file From 842f3e8c201f4f1d7cc792f28d93d13e67e30921 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 11:46:13 -0500 Subject: [PATCH 02/32] roughed in store implementation for organizations and memberships (#537) --- controller/store/frontend.go | 1 - controller/store/organization.go | 36 +++++++++++++++++ controller/store/organizationMember.go | 54 ++++++++++++++++++++++++++ 3 files changed, 90 insertions(+), 1 deletion(-) create mode 100644 controller/store/organization.go create mode 100644 controller/store/organizationMember.go diff --git a/controller/store/frontend.go b/controller/store/frontend.go index d4b55faf..8086b468 100644 --- a/controller/store/frontend.go +++ b/controller/store/frontend.go @@ -135,7 +135,6 @@ func (str *Store) UpdateFrontend(fe *Frontend, tx *sqlx.Tx) error { } func (str *Store) DeleteFrontend(id int, tx *sqlx.Tx) error { - stmt, err := tx.Prepare("update frontends set updated_at = current_timestamp, deleted = true where id = $1") if err != nil { return errors.Wrap(err, "error preparing frontends delete statement") diff --git a/controller/store/organization.go b/controller/store/organization.go new file mode 100644 index 00000000..98dda7b0 --- /dev/null +++ b/controller/store/organization.go @@ -0,0 +1,36 @@ +package store + +import ( + "github.com/jmoiron/sqlx" + "github.com/pkg/errors" +) + +type Organization struct { + Model + Token string + Description string +} + +func (str *Store) CreateOrganization(org *Organization, trx *sqlx.Tx) (int, error) { + stmt, err := trx.Prepare("insert into organizations (token, description) values ($1, $2) returning id") + if err != nil { + return 0, errors.Wrap(err, "error preparing organizations insert statement") + } + var id int + if err := stmt.QueryRow(org.Token, org.Description).Scan(&id); err != nil { + return 0, errors.Wrap(err, "error executing organizations insert statement") + } + return id, nil +} + +func (str *Store) DeleteOrganization(id int, trx *sqlx.Tx) error { + stmt, err := trx.Prepare("update organizations set updated_at = current_timestamp, deleted = true where id = $1") + if err != nil { + return errors.Wrap(err, "error preparing organizations delete statement") + } + _, err = stmt.Exec(id) + if err != nil { + return errors.Wrap(err, "error executing organizations delete statement") + } + return nil +} diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go new file mode 100644 index 00000000..f61896ea --- /dev/null +++ b/controller/store/organizationMember.go @@ -0,0 +1,54 @@ +package store + +import ( + "github.com/jmoiron/sqlx" + "github.com/pkg/errors" +) + +func (str *Store) AddAccountToOrganization(acctId, orgId int, trx *sqlx.Tx) error { + stmt, err := trx.Prepare("insert into organization_members (organization_id, account_id) values ($1, $2)") + if err != nil { + return errors.Wrap(err, "error preparing organization_members insert statement") + } + _, err = stmt.Exec(acctId, orgId) + if err != nil { + return errors.Wrap(err, "error executing organization_members insert statement") + } + return nil +} + +func (str *Store) IsAccountInOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { + stmt, err := trx.Prepare("select count(0) from organization_members where organization_id = $1 and account_id = $2") + if err != nil { + return false, errors.Wrap(err, "error preparing organization_members count statement") + } + var count int + if err := stmt.QueryRow(acctId, orgId).Scan(&count); err != nil { + return false, errors.Wrap(err, "error executing organization_members count statement") + } + return count > 0, nil +} + +func (str *Store) IsAccountAdminOfOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { + stmt, err := trx.Prepare("select count(0) from organization_members where organization_id = $1 and account_id = $2 and admin") + if err != nil { + return false, errors.Wrap(err, "error preparing organization_members count statement") + } + var count int + if err := stmt.QueryRow(acctId, orgId).Scan(&count); err != nil { + return false, errors.Wrap(err, "error executing organization_members count statement") + } + return count > 0, nil +} + +func (str *Store) RemoveAccountFromOrganization(acctId, orgId int, trx *sqlx.Tx) error { + stmt, err := trx.Prepare("delete from organization_members where organization_id = $1 and account_id = $2") + if err != nil { + return errors.Wrap(err, "error preparing organization_members delete statement") + } + _, err = stmt.Exec(acctId, orgId) + if err != nil { + return errors.Wrap(err, "error executing organization_members delete statement") + } + return nil +} From 38b32d15d01a5c52ec20d349ea191e07d54b07cc Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 12:56:57 -0500 Subject: [PATCH 03/32] initial cut at admin api operations (#537) --- .../add_organization_member_parameters.go | 146 ++++++ .../add_organization_member_responses.go | 252 ++++++++++ rest_client_zrok/admin/admin_client.go | 205 ++++++++ .../admin/create_organization_parameters.go | 146 ++++++ .../admin/create_organization_responses.go | 303 ++++++++++++ .../admin/delete_organization_parameters.go | 146 ++++++ .../admin/delete_organization_responses.go | 252 ++++++++++ .../list_organization_members_parameters.go | 146 ++++++ .../list_organization_members_responses.go | 412 ++++++++++++++++ .../remove_organization_member_parameters.go | 146 ++++++ .../remove_organization_member_responses.go | 252 ++++++++++ rest_server_zrok/embedded_spec.go | 411 ++++++++++++++++ .../admin/add_organization_member.go | 111 +++++ .../add_organization_member_parameters.go | 74 +++ .../add_organization_member_responses.go | 87 ++++ .../add_organization_member_urlbuilder.go | 87 ++++ .../operations/admin/create_organization.go | 148 ++++++ .../admin/create_organization_parameters.go | 74 +++ .../admin/create_organization_responses.go | 107 +++++ .../admin/create_organization_urlbuilder.go | 87 ++++ .../operations/admin/delete_organization.go | 111 +++++ .../admin/delete_organization_parameters.go | 74 +++ .../admin/delete_organization_responses.go | 87 ++++ .../admin/delete_organization_urlbuilder.go | 87 ++++ .../admin/list_organization_members.go | 256 ++++++++++ .../list_organization_members_parameters.go | 74 +++ .../list_organization_members_responses.go | 107 +++++ .../list_organization_members_urlbuilder.go | 87 ++++ .../admin/remove_organization_member.go | 111 +++++ .../remove_organization_member_parameters.go | 74 +++ .../remove_organization_member_responses.go | 87 ++++ .../remove_organization_member_urlbuilder.go | 87 ++++ rest_server_zrok/operations/zrok_api.go | 60 +++ .../sdk/src/zrok/api/.openapi-generator/FILES | 2 + sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 308 ++++++++++++ .../api/model/createOrganizationRequest.ts | 31 ++ .../listOrganizationMembers200Response.ts | 32 ++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 6 + sdk/python/sdk/zrok/zrok_api/__init__.py | 6 + sdk/python/sdk/zrok/zrok_api/api/admin_api.py | 453 ++++++++++++++++++ .../sdk/zrok/zrok_api/models/__init__.py | 6 + .../zrok_api/models/inline_response2001.py | 110 +++++ .../zrok_api/models/organization_add_body.py | 110 +++++ .../zrok/zrok_api/models/organization_body.py | 110 +++++ .../zrok_api/models/organization_body1.py | 110 +++++ .../models/organization_members_body.py | 110 +++++ .../models/organization_remove_body.py | 110 +++++ specs/zrok.yml | 121 +++++ ui/src/api/admin.js | 130 +++++ 49 files changed, 6649 insertions(+) create mode 100644 rest_client_zrok/admin/add_organization_member_parameters.go create mode 100644 rest_client_zrok/admin/add_organization_member_responses.go create mode 100644 rest_client_zrok/admin/create_organization_parameters.go create mode 100644 rest_client_zrok/admin/create_organization_responses.go create mode 100644 rest_client_zrok/admin/delete_organization_parameters.go create mode 100644 rest_client_zrok/admin/delete_organization_responses.go create mode 100644 rest_client_zrok/admin/list_organization_members_parameters.go create mode 100644 rest_client_zrok/admin/list_organization_members_responses.go create mode 100644 rest_client_zrok/admin/remove_organization_member_parameters.go create mode 100644 rest_client_zrok/admin/remove_organization_member_responses.go create mode 100644 rest_server_zrok/operations/admin/add_organization_member.go create mode 100644 rest_server_zrok/operations/admin/add_organization_member_parameters.go create mode 100644 rest_server_zrok/operations/admin/add_organization_member_responses.go create mode 100644 rest_server_zrok/operations/admin/add_organization_member_urlbuilder.go create mode 100644 rest_server_zrok/operations/admin/create_organization.go create mode 100644 rest_server_zrok/operations/admin/create_organization_parameters.go create mode 100644 rest_server_zrok/operations/admin/create_organization_responses.go create mode 100644 rest_server_zrok/operations/admin/create_organization_urlbuilder.go create mode 100644 rest_server_zrok/operations/admin/delete_organization.go create mode 100644 rest_server_zrok/operations/admin/delete_organization_parameters.go create mode 100644 rest_server_zrok/operations/admin/delete_organization_responses.go create mode 100644 rest_server_zrok/operations/admin/delete_organization_urlbuilder.go create mode 100644 rest_server_zrok/operations/admin/list_organization_members.go create mode 100644 rest_server_zrok/operations/admin/list_organization_members_parameters.go create mode 100644 rest_server_zrok/operations/admin/list_organization_members_responses.go create mode 100644 rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go create mode 100644 rest_server_zrok/operations/admin/remove_organization_member.go create mode 100644 rest_server_zrok/operations/admin/remove_organization_member_parameters.go create mode 100644 rest_server_zrok/operations/admin/remove_organization_member_responses.go create mode 100644 rest_server_zrok/operations/admin/remove_organization_member_urlbuilder.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/createOrganizationRequest.ts create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_body.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_body1.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_members_body.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py diff --git a/rest_client_zrok/admin/add_organization_member_parameters.go b/rest_client_zrok/admin/add_organization_member_parameters.go new file mode 100644 index 00000000..4424895a --- /dev/null +++ b/rest_client_zrok/admin/add_organization_member_parameters.go @@ -0,0 +1,146 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewAddOrganizationMemberParams creates a new AddOrganizationMemberParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewAddOrganizationMemberParams() *AddOrganizationMemberParams { + return &AddOrganizationMemberParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewAddOrganizationMemberParamsWithTimeout creates a new AddOrganizationMemberParams object +// with the ability to set a timeout on a request. +func NewAddOrganizationMemberParamsWithTimeout(timeout time.Duration) *AddOrganizationMemberParams { + return &AddOrganizationMemberParams{ + timeout: timeout, + } +} + +// NewAddOrganizationMemberParamsWithContext creates a new AddOrganizationMemberParams object +// with the ability to set a context for a request. +func NewAddOrganizationMemberParamsWithContext(ctx context.Context) *AddOrganizationMemberParams { + return &AddOrganizationMemberParams{ + Context: ctx, + } +} + +// NewAddOrganizationMemberParamsWithHTTPClient creates a new AddOrganizationMemberParams object +// with the ability to set a custom HTTPClient for a request. +func NewAddOrganizationMemberParamsWithHTTPClient(client *http.Client) *AddOrganizationMemberParams { + return &AddOrganizationMemberParams{ + HTTPClient: client, + } +} + +/* +AddOrganizationMemberParams contains all the parameters to send to the API endpoint + + for the add organization member operation. + + Typically these are written to a http.Request. +*/ +type AddOrganizationMemberParams struct { + + // Body. + Body AddOrganizationMemberBody + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the add organization member params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *AddOrganizationMemberParams) WithDefaults() *AddOrganizationMemberParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the add organization member params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *AddOrganizationMemberParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the add organization member params +func (o *AddOrganizationMemberParams) WithTimeout(timeout time.Duration) *AddOrganizationMemberParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the add organization member params +func (o *AddOrganizationMemberParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the add organization member params +func (o *AddOrganizationMemberParams) WithContext(ctx context.Context) *AddOrganizationMemberParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the add organization member params +func (o *AddOrganizationMemberParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the add organization member params +func (o *AddOrganizationMemberParams) WithHTTPClient(client *http.Client) *AddOrganizationMemberParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the add organization member params +func (o *AddOrganizationMemberParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithBody adds the body to the add organization member params +func (o *AddOrganizationMemberParams) WithBody(body AddOrganizationMemberBody) *AddOrganizationMemberParams { + o.SetBody(body) + return o +} + +// SetBody adds the body to the add organization member params +func (o *AddOrganizationMemberParams) SetBody(body AddOrganizationMemberBody) { + o.Body = body +} + +// WriteToRequest writes these params to a swagger request +func (o *AddOrganizationMemberParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + if err := r.SetBodyParam(o.Body); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/add_organization_member_responses.go b/rest_client_zrok/admin/add_organization_member_responses.go new file mode 100644 index 00000000..beca97f8 --- /dev/null +++ b/rest_client_zrok/admin/add_organization_member_responses.go @@ -0,0 +1,252 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// AddOrganizationMemberReader is a Reader for the AddOrganizationMember structure. +type AddOrganizationMemberReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *AddOrganizationMemberReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 201: + result := NewAddOrganizationMemberCreated() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewAddOrganizationMemberUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewAddOrganizationMemberInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[POST /organization/add] addOrganizationMember", response, response.Code()) + } +} + +// NewAddOrganizationMemberCreated creates a AddOrganizationMemberCreated with default headers values +func NewAddOrganizationMemberCreated() *AddOrganizationMemberCreated { + return &AddOrganizationMemberCreated{} +} + +/* +AddOrganizationMemberCreated describes a response with status code 201, with default header values. + +member added +*/ +type AddOrganizationMemberCreated struct { +} + +// IsSuccess returns true when this add organization member created response has a 2xx status code +func (o *AddOrganizationMemberCreated) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this add organization member created response has a 3xx status code +func (o *AddOrganizationMemberCreated) IsRedirect() bool { + return false +} + +// IsClientError returns true when this add organization member created response has a 4xx status code +func (o *AddOrganizationMemberCreated) IsClientError() bool { + return false +} + +// IsServerError returns true when this add organization member created response has a 5xx status code +func (o *AddOrganizationMemberCreated) IsServerError() bool { + return false +} + +// IsCode returns true when this add organization member created response a status code equal to that given +func (o *AddOrganizationMemberCreated) IsCode(code int) bool { + return code == 201 +} + +// Code gets the status code for the add organization member created response +func (o *AddOrganizationMemberCreated) Code() int { + return 201 +} + +func (o *AddOrganizationMemberCreated) Error() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberCreated ", 201) +} + +func (o *AddOrganizationMemberCreated) String() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberCreated ", 201) +} + +func (o *AddOrganizationMemberCreated) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewAddOrganizationMemberUnauthorized creates a AddOrganizationMemberUnauthorized with default headers values +func NewAddOrganizationMemberUnauthorized() *AddOrganizationMemberUnauthorized { + return &AddOrganizationMemberUnauthorized{} +} + +/* +AddOrganizationMemberUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type AddOrganizationMemberUnauthorized struct { +} + +// IsSuccess returns true when this add organization member unauthorized response has a 2xx status code +func (o *AddOrganizationMemberUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this add organization member unauthorized response has a 3xx status code +func (o *AddOrganizationMemberUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this add organization member unauthorized response has a 4xx status code +func (o *AddOrganizationMemberUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this add organization member unauthorized response has a 5xx status code +func (o *AddOrganizationMemberUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this add organization member unauthorized response a status code equal to that given +func (o *AddOrganizationMemberUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the add organization member unauthorized response +func (o *AddOrganizationMemberUnauthorized) Code() int { + return 401 +} + +func (o *AddOrganizationMemberUnauthorized) Error() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberUnauthorized ", 401) +} + +func (o *AddOrganizationMemberUnauthorized) String() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberUnauthorized ", 401) +} + +func (o *AddOrganizationMemberUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewAddOrganizationMemberInternalServerError creates a AddOrganizationMemberInternalServerError with default headers values +func NewAddOrganizationMemberInternalServerError() *AddOrganizationMemberInternalServerError { + return &AddOrganizationMemberInternalServerError{} +} + +/* +AddOrganizationMemberInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type AddOrganizationMemberInternalServerError struct { +} + +// IsSuccess returns true when this add organization member internal server error response has a 2xx status code +func (o *AddOrganizationMemberInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this add organization member internal server error response has a 3xx status code +func (o *AddOrganizationMemberInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this add organization member internal server error response has a 4xx status code +func (o *AddOrganizationMemberInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this add organization member internal server error response has a 5xx status code +func (o *AddOrganizationMemberInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this add organization member internal server error response a status code equal to that given +func (o *AddOrganizationMemberInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the add organization member internal server error response +func (o *AddOrganizationMemberInternalServerError) Code() int { + return 500 +} + +func (o *AddOrganizationMemberInternalServerError) Error() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberInternalServerError ", 500) +} + +func (o *AddOrganizationMemberInternalServerError) String() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberInternalServerError ", 500) +} + +func (o *AddOrganizationMemberInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +AddOrganizationMemberBody add organization member body +swagger:model AddOrganizationMemberBody +*/ +type AddOrganizationMemberBody struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this add organization member body +func (o *AddOrganizationMemberBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this add organization member body based on context it is used +func (o *AddOrganizationMemberBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *AddOrganizationMemberBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *AddOrganizationMemberBody) UnmarshalBinary(b []byte) error { + var res AddOrganizationMemberBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/admin/admin_client.go b/rest_client_zrok/admin/admin_client.go index 2f37aa4e..72944f41 100644 --- a/rest_client_zrok/admin/admin_client.go +++ b/rest_client_zrok/admin/admin_client.go @@ -30,25 +30,74 @@ type ClientOption func(*runtime.ClientOperation) // ClientService is the interface for Client methods type ClientService interface { + AddOrganizationMember(params *AddOrganizationMemberParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*AddOrganizationMemberCreated, error) + CreateAccount(params *CreateAccountParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*CreateAccountCreated, error) CreateFrontend(params *CreateFrontendParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*CreateFrontendCreated, error) CreateIdentity(params *CreateIdentityParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*CreateIdentityCreated, error) + CreateOrganization(params *CreateOrganizationParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*CreateOrganizationCreated, error) + DeleteFrontend(params *DeleteFrontendParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*DeleteFrontendOK, error) + DeleteOrganization(params *DeleteOrganizationParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*DeleteOrganizationOK, error) + Grants(params *GrantsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*GrantsOK, error) InviteTokenGenerate(params *InviteTokenGenerateParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*InviteTokenGenerateCreated, error) ListFrontends(params *ListFrontendsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListFrontendsOK, error) + ListOrganizationMembers(params *ListOrganizationMembersParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrganizationMembersOK, error) + + RemoveOrganizationMember(params *RemoveOrganizationMemberParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*RemoveOrganizationMemberOK, error) + UpdateFrontend(params *UpdateFrontendParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*UpdateFrontendOK, error) SetTransport(transport runtime.ClientTransport) } +/* +AddOrganizationMember add organization member API +*/ +func (a *Client) AddOrganizationMember(params *AddOrganizationMemberParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*AddOrganizationMemberCreated, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewAddOrganizationMemberParams() + } + op := &runtime.ClientOperation{ + ID: "addOrganizationMember", + Method: "POST", + PathPattern: "/organization/add", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &AddOrganizationMemberReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*AddOrganizationMemberCreated) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for addOrganizationMember: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* CreateAccount create account API */ @@ -166,6 +215,45 @@ func (a *Client) CreateIdentity(params *CreateIdentityParams, authInfo runtime.C panic(msg) } +/* +CreateOrganization create organization API +*/ +func (a *Client) CreateOrganization(params *CreateOrganizationParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*CreateOrganizationCreated, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewCreateOrganizationParams() + } + op := &runtime.ClientOperation{ + ID: "createOrganization", + Method: "POST", + PathPattern: "/organization", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &CreateOrganizationReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*CreateOrganizationCreated) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for createOrganization: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* DeleteFrontend delete frontend API */ @@ -205,6 +293,45 @@ func (a *Client) DeleteFrontend(params *DeleteFrontendParams, authInfo runtime.C panic(msg) } +/* +DeleteOrganization delete organization API +*/ +func (a *Client) DeleteOrganization(params *DeleteOrganizationParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*DeleteOrganizationOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewDeleteOrganizationParams() + } + op := &runtime.ClientOperation{ + ID: "deleteOrganization", + Method: "DELETE", + PathPattern: "/organization", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &DeleteOrganizationReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*DeleteOrganizationOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for deleteOrganization: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* Grants grants API */ @@ -322,6 +449,84 @@ func (a *Client) ListFrontends(params *ListFrontendsParams, authInfo runtime.Cli panic(msg) } +/* +ListOrganizationMembers list organization members API +*/ +func (a *Client) ListOrganizationMembers(params *ListOrganizationMembersParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrganizationMembersOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewListOrganizationMembersParams() + } + op := &runtime.ClientOperation{ + ID: "listOrganizationMembers", + Method: "POST", + PathPattern: "/organization/members", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &ListOrganizationMembersReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*ListOrganizationMembersOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for listOrganizationMembers: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + +/* +RemoveOrganizationMember remove organization member API +*/ +func (a *Client) RemoveOrganizationMember(params *RemoveOrganizationMemberParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*RemoveOrganizationMemberOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewRemoveOrganizationMemberParams() + } + op := &runtime.ClientOperation{ + ID: "removeOrganizationMember", + Method: "POST", + PathPattern: "/organization/remove", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &RemoveOrganizationMemberReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*RemoveOrganizationMemberOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for removeOrganizationMember: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* UpdateFrontend update frontend API */ diff --git a/rest_client_zrok/admin/create_organization_parameters.go b/rest_client_zrok/admin/create_organization_parameters.go new file mode 100644 index 00000000..e46ebd97 --- /dev/null +++ b/rest_client_zrok/admin/create_organization_parameters.go @@ -0,0 +1,146 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewCreateOrganizationParams creates a new CreateOrganizationParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewCreateOrganizationParams() *CreateOrganizationParams { + return &CreateOrganizationParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewCreateOrganizationParamsWithTimeout creates a new CreateOrganizationParams object +// with the ability to set a timeout on a request. +func NewCreateOrganizationParamsWithTimeout(timeout time.Duration) *CreateOrganizationParams { + return &CreateOrganizationParams{ + timeout: timeout, + } +} + +// NewCreateOrganizationParamsWithContext creates a new CreateOrganizationParams object +// with the ability to set a context for a request. +func NewCreateOrganizationParamsWithContext(ctx context.Context) *CreateOrganizationParams { + return &CreateOrganizationParams{ + Context: ctx, + } +} + +// NewCreateOrganizationParamsWithHTTPClient creates a new CreateOrganizationParams object +// with the ability to set a custom HTTPClient for a request. +func NewCreateOrganizationParamsWithHTTPClient(client *http.Client) *CreateOrganizationParams { + return &CreateOrganizationParams{ + HTTPClient: client, + } +} + +/* +CreateOrganizationParams contains all the parameters to send to the API endpoint + + for the create organization operation. + + Typically these are written to a http.Request. +*/ +type CreateOrganizationParams struct { + + // Body. + Body CreateOrganizationBody + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the create organization params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *CreateOrganizationParams) WithDefaults() *CreateOrganizationParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the create organization params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *CreateOrganizationParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the create organization params +func (o *CreateOrganizationParams) WithTimeout(timeout time.Duration) *CreateOrganizationParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the create organization params +func (o *CreateOrganizationParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the create organization params +func (o *CreateOrganizationParams) WithContext(ctx context.Context) *CreateOrganizationParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the create organization params +func (o *CreateOrganizationParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the create organization params +func (o *CreateOrganizationParams) WithHTTPClient(client *http.Client) *CreateOrganizationParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the create organization params +func (o *CreateOrganizationParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithBody adds the body to the create organization params +func (o *CreateOrganizationParams) WithBody(body CreateOrganizationBody) *CreateOrganizationParams { + o.SetBody(body) + return o +} + +// SetBody adds the body to the create organization params +func (o *CreateOrganizationParams) SetBody(body CreateOrganizationBody) { + o.Body = body +} + +// WriteToRequest writes these params to a swagger request +func (o *CreateOrganizationParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + if err := r.SetBodyParam(o.Body); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/create_organization_responses.go b/rest_client_zrok/admin/create_organization_responses.go new file mode 100644 index 00000000..2459593d --- /dev/null +++ b/rest_client_zrok/admin/create_organization_responses.go @@ -0,0 +1,303 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// CreateOrganizationReader is a Reader for the CreateOrganization structure. +type CreateOrganizationReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *CreateOrganizationReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 201: + result := NewCreateOrganizationCreated() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewCreateOrganizationUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewCreateOrganizationInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[POST /organization] createOrganization", response, response.Code()) + } +} + +// NewCreateOrganizationCreated creates a CreateOrganizationCreated with default headers values +func NewCreateOrganizationCreated() *CreateOrganizationCreated { + return &CreateOrganizationCreated{} +} + +/* +CreateOrganizationCreated describes a response with status code 201, with default header values. + +organization created +*/ +type CreateOrganizationCreated struct { + Payload *CreateOrganizationCreatedBody +} + +// IsSuccess returns true when this create organization created response has a 2xx status code +func (o *CreateOrganizationCreated) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this create organization created response has a 3xx status code +func (o *CreateOrganizationCreated) IsRedirect() bool { + return false +} + +// IsClientError returns true when this create organization created response has a 4xx status code +func (o *CreateOrganizationCreated) IsClientError() bool { + return false +} + +// IsServerError returns true when this create organization created response has a 5xx status code +func (o *CreateOrganizationCreated) IsServerError() bool { + return false +} + +// IsCode returns true when this create organization created response a status code equal to that given +func (o *CreateOrganizationCreated) IsCode(code int) bool { + return code == 201 +} + +// Code gets the status code for the create organization created response +func (o *CreateOrganizationCreated) Code() int { + return 201 +} + +func (o *CreateOrganizationCreated) Error() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationCreated %+v", 201, o.Payload) +} + +func (o *CreateOrganizationCreated) String() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationCreated %+v", 201, o.Payload) +} + +func (o *CreateOrganizationCreated) GetPayload() *CreateOrganizationCreatedBody { + return o.Payload +} + +func (o *CreateOrganizationCreated) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(CreateOrganizationCreatedBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewCreateOrganizationUnauthorized creates a CreateOrganizationUnauthorized with default headers values +func NewCreateOrganizationUnauthorized() *CreateOrganizationUnauthorized { + return &CreateOrganizationUnauthorized{} +} + +/* +CreateOrganizationUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type CreateOrganizationUnauthorized struct { +} + +// IsSuccess returns true when this create organization unauthorized response has a 2xx status code +func (o *CreateOrganizationUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this create organization unauthorized response has a 3xx status code +func (o *CreateOrganizationUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this create organization unauthorized response has a 4xx status code +func (o *CreateOrganizationUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this create organization unauthorized response has a 5xx status code +func (o *CreateOrganizationUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this create organization unauthorized response a status code equal to that given +func (o *CreateOrganizationUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the create organization unauthorized response +func (o *CreateOrganizationUnauthorized) Code() int { + return 401 +} + +func (o *CreateOrganizationUnauthorized) Error() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationUnauthorized ", 401) +} + +func (o *CreateOrganizationUnauthorized) String() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationUnauthorized ", 401) +} + +func (o *CreateOrganizationUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewCreateOrganizationInternalServerError creates a CreateOrganizationInternalServerError with default headers values +func NewCreateOrganizationInternalServerError() *CreateOrganizationInternalServerError { + return &CreateOrganizationInternalServerError{} +} + +/* +CreateOrganizationInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type CreateOrganizationInternalServerError struct { +} + +// IsSuccess returns true when this create organization internal server error response has a 2xx status code +func (o *CreateOrganizationInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this create organization internal server error response has a 3xx status code +func (o *CreateOrganizationInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this create organization internal server error response has a 4xx status code +func (o *CreateOrganizationInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this create organization internal server error response has a 5xx status code +func (o *CreateOrganizationInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this create organization internal server error response a status code equal to that given +func (o *CreateOrganizationInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the create organization internal server error response +func (o *CreateOrganizationInternalServerError) Code() int { + return 500 +} + +func (o *CreateOrganizationInternalServerError) Error() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationInternalServerError ", 500) +} + +func (o *CreateOrganizationInternalServerError) String() string { + return fmt.Sprintf("[POST /organization][%d] createOrganizationInternalServerError ", 500) +} + +func (o *CreateOrganizationInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +CreateOrganizationBody create organization body +swagger:model CreateOrganizationBody +*/ +type CreateOrganizationBody struct { + + // description + Description string `json:"description,omitempty"` +} + +// Validate validates this create organization body +func (o *CreateOrganizationBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this create organization body based on context it is used +func (o *CreateOrganizationBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *CreateOrganizationBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *CreateOrganizationBody) UnmarshalBinary(b []byte) error { + var res CreateOrganizationBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +CreateOrganizationCreatedBody create organization created body +swagger:model CreateOrganizationCreatedBody +*/ +type CreateOrganizationCreatedBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this create organization created body +func (o *CreateOrganizationCreatedBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this create organization created body based on context it is used +func (o *CreateOrganizationCreatedBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *CreateOrganizationCreatedBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *CreateOrganizationCreatedBody) UnmarshalBinary(b []byte) error { + var res CreateOrganizationCreatedBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/admin/delete_organization_parameters.go b/rest_client_zrok/admin/delete_organization_parameters.go new file mode 100644 index 00000000..11746d17 --- /dev/null +++ b/rest_client_zrok/admin/delete_organization_parameters.go @@ -0,0 +1,146 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewDeleteOrganizationParams creates a new DeleteOrganizationParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewDeleteOrganizationParams() *DeleteOrganizationParams { + return &DeleteOrganizationParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewDeleteOrganizationParamsWithTimeout creates a new DeleteOrganizationParams object +// with the ability to set a timeout on a request. +func NewDeleteOrganizationParamsWithTimeout(timeout time.Duration) *DeleteOrganizationParams { + return &DeleteOrganizationParams{ + timeout: timeout, + } +} + +// NewDeleteOrganizationParamsWithContext creates a new DeleteOrganizationParams object +// with the ability to set a context for a request. +func NewDeleteOrganizationParamsWithContext(ctx context.Context) *DeleteOrganizationParams { + return &DeleteOrganizationParams{ + Context: ctx, + } +} + +// NewDeleteOrganizationParamsWithHTTPClient creates a new DeleteOrganizationParams object +// with the ability to set a custom HTTPClient for a request. +func NewDeleteOrganizationParamsWithHTTPClient(client *http.Client) *DeleteOrganizationParams { + return &DeleteOrganizationParams{ + HTTPClient: client, + } +} + +/* +DeleteOrganizationParams contains all the parameters to send to the API endpoint + + for the delete organization operation. + + Typically these are written to a http.Request. +*/ +type DeleteOrganizationParams struct { + + // Body. + Body DeleteOrganizationBody + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the delete organization params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *DeleteOrganizationParams) WithDefaults() *DeleteOrganizationParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the delete organization params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *DeleteOrganizationParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the delete organization params +func (o *DeleteOrganizationParams) WithTimeout(timeout time.Duration) *DeleteOrganizationParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the delete organization params +func (o *DeleteOrganizationParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the delete organization params +func (o *DeleteOrganizationParams) WithContext(ctx context.Context) *DeleteOrganizationParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the delete organization params +func (o *DeleteOrganizationParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the delete organization params +func (o *DeleteOrganizationParams) WithHTTPClient(client *http.Client) *DeleteOrganizationParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the delete organization params +func (o *DeleteOrganizationParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithBody adds the body to the delete organization params +func (o *DeleteOrganizationParams) WithBody(body DeleteOrganizationBody) *DeleteOrganizationParams { + o.SetBody(body) + return o +} + +// SetBody adds the body to the delete organization params +func (o *DeleteOrganizationParams) SetBody(body DeleteOrganizationBody) { + o.Body = body +} + +// WriteToRequest writes these params to a swagger request +func (o *DeleteOrganizationParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + if err := r.SetBodyParam(o.Body); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/delete_organization_responses.go b/rest_client_zrok/admin/delete_organization_responses.go new file mode 100644 index 00000000..579aac8f --- /dev/null +++ b/rest_client_zrok/admin/delete_organization_responses.go @@ -0,0 +1,252 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// DeleteOrganizationReader is a Reader for the DeleteOrganization structure. +type DeleteOrganizationReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *DeleteOrganizationReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewDeleteOrganizationOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewDeleteOrganizationUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewDeleteOrganizationInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[DELETE /organization] deleteOrganization", response, response.Code()) + } +} + +// NewDeleteOrganizationOK creates a DeleteOrganizationOK with default headers values +func NewDeleteOrganizationOK() *DeleteOrganizationOK { + return &DeleteOrganizationOK{} +} + +/* +DeleteOrganizationOK describes a response with status code 200, with default header values. + +organization deleted +*/ +type DeleteOrganizationOK struct { +} + +// IsSuccess returns true when this delete organization o k response has a 2xx status code +func (o *DeleteOrganizationOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this delete organization o k response has a 3xx status code +func (o *DeleteOrganizationOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this delete organization o k response has a 4xx status code +func (o *DeleteOrganizationOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this delete organization o k response has a 5xx status code +func (o *DeleteOrganizationOK) IsServerError() bool { + return false +} + +// IsCode returns true when this delete organization o k response a status code equal to that given +func (o *DeleteOrganizationOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the delete organization o k response +func (o *DeleteOrganizationOK) Code() int { + return 200 +} + +func (o *DeleteOrganizationOK) Error() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationOK ", 200) +} + +func (o *DeleteOrganizationOK) String() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationOK ", 200) +} + +func (o *DeleteOrganizationOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewDeleteOrganizationUnauthorized creates a DeleteOrganizationUnauthorized with default headers values +func NewDeleteOrganizationUnauthorized() *DeleteOrganizationUnauthorized { + return &DeleteOrganizationUnauthorized{} +} + +/* +DeleteOrganizationUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type DeleteOrganizationUnauthorized struct { +} + +// IsSuccess returns true when this delete organization unauthorized response has a 2xx status code +func (o *DeleteOrganizationUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this delete organization unauthorized response has a 3xx status code +func (o *DeleteOrganizationUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this delete organization unauthorized response has a 4xx status code +func (o *DeleteOrganizationUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this delete organization unauthorized response has a 5xx status code +func (o *DeleteOrganizationUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this delete organization unauthorized response a status code equal to that given +func (o *DeleteOrganizationUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the delete organization unauthorized response +func (o *DeleteOrganizationUnauthorized) Code() int { + return 401 +} + +func (o *DeleteOrganizationUnauthorized) Error() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationUnauthorized ", 401) +} + +func (o *DeleteOrganizationUnauthorized) String() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationUnauthorized ", 401) +} + +func (o *DeleteOrganizationUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewDeleteOrganizationInternalServerError creates a DeleteOrganizationInternalServerError with default headers values +func NewDeleteOrganizationInternalServerError() *DeleteOrganizationInternalServerError { + return &DeleteOrganizationInternalServerError{} +} + +/* +DeleteOrganizationInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type DeleteOrganizationInternalServerError struct { +} + +// IsSuccess returns true when this delete organization internal server error response has a 2xx status code +func (o *DeleteOrganizationInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this delete organization internal server error response has a 3xx status code +func (o *DeleteOrganizationInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this delete organization internal server error response has a 4xx status code +func (o *DeleteOrganizationInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this delete organization internal server error response has a 5xx status code +func (o *DeleteOrganizationInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this delete organization internal server error response a status code equal to that given +func (o *DeleteOrganizationInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the delete organization internal server error response +func (o *DeleteOrganizationInternalServerError) Code() int { + return 500 +} + +func (o *DeleteOrganizationInternalServerError) Error() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationInternalServerError ", 500) +} + +func (o *DeleteOrganizationInternalServerError) String() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationInternalServerError ", 500) +} + +func (o *DeleteOrganizationInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +DeleteOrganizationBody delete organization body +swagger:model DeleteOrganizationBody +*/ +type DeleteOrganizationBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this delete organization body +func (o *DeleteOrganizationBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this delete organization body based on context it is used +func (o *DeleteOrganizationBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *DeleteOrganizationBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *DeleteOrganizationBody) UnmarshalBinary(b []byte) error { + var res DeleteOrganizationBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/admin/list_organization_members_parameters.go b/rest_client_zrok/admin/list_organization_members_parameters.go new file mode 100644 index 00000000..feb9fe7d --- /dev/null +++ b/rest_client_zrok/admin/list_organization_members_parameters.go @@ -0,0 +1,146 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewListOrganizationMembersParams creates a new ListOrganizationMembersParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewListOrganizationMembersParams() *ListOrganizationMembersParams { + return &ListOrganizationMembersParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewListOrganizationMembersParamsWithTimeout creates a new ListOrganizationMembersParams object +// with the ability to set a timeout on a request. +func NewListOrganizationMembersParamsWithTimeout(timeout time.Duration) *ListOrganizationMembersParams { + return &ListOrganizationMembersParams{ + timeout: timeout, + } +} + +// NewListOrganizationMembersParamsWithContext creates a new ListOrganizationMembersParams object +// with the ability to set a context for a request. +func NewListOrganizationMembersParamsWithContext(ctx context.Context) *ListOrganizationMembersParams { + return &ListOrganizationMembersParams{ + Context: ctx, + } +} + +// NewListOrganizationMembersParamsWithHTTPClient creates a new ListOrganizationMembersParams object +// with the ability to set a custom HTTPClient for a request. +func NewListOrganizationMembersParamsWithHTTPClient(client *http.Client) *ListOrganizationMembersParams { + return &ListOrganizationMembersParams{ + HTTPClient: client, + } +} + +/* +ListOrganizationMembersParams contains all the parameters to send to the API endpoint + + for the list organization members operation. + + Typically these are written to a http.Request. +*/ +type ListOrganizationMembersParams struct { + + // Body. + Body ListOrganizationMembersBody + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the list organization members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrganizationMembersParams) WithDefaults() *ListOrganizationMembersParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the list organization members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrganizationMembersParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the list organization members params +func (o *ListOrganizationMembersParams) WithTimeout(timeout time.Duration) *ListOrganizationMembersParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the list organization members params +func (o *ListOrganizationMembersParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the list organization members params +func (o *ListOrganizationMembersParams) WithContext(ctx context.Context) *ListOrganizationMembersParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the list organization members params +func (o *ListOrganizationMembersParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the list organization members params +func (o *ListOrganizationMembersParams) WithHTTPClient(client *http.Client) *ListOrganizationMembersParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the list organization members params +func (o *ListOrganizationMembersParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithBody adds the body to the list organization members params +func (o *ListOrganizationMembersParams) WithBody(body ListOrganizationMembersBody) *ListOrganizationMembersParams { + o.SetBody(body) + return o +} + +// SetBody adds the body to the list organization members params +func (o *ListOrganizationMembersParams) SetBody(body ListOrganizationMembersBody) { + o.Body = body +} + +// WriteToRequest writes these params to a swagger request +func (o *ListOrganizationMembersParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + if err := r.SetBodyParam(o.Body); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/list_organization_members_responses.go b/rest_client_zrok/admin/list_organization_members_responses.go new file mode 100644 index 00000000..736b3d40 --- /dev/null +++ b/rest_client_zrok/admin/list_organization_members_responses.go @@ -0,0 +1,412 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// ListOrganizationMembersReader is a Reader for the ListOrganizationMembers structure. +type ListOrganizationMembersReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *ListOrganizationMembersReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewListOrganizationMembersOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewListOrganizationMembersUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewListOrganizationMembersInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[POST /organization/members] listOrganizationMembers", response, response.Code()) + } +} + +// NewListOrganizationMembersOK creates a ListOrganizationMembersOK with default headers values +func NewListOrganizationMembersOK() *ListOrganizationMembersOK { + return &ListOrganizationMembersOK{} +} + +/* +ListOrganizationMembersOK describes a response with status code 200, with default header values. + +list organization members +*/ +type ListOrganizationMembersOK struct { + Payload *ListOrganizationMembersOKBody +} + +// IsSuccess returns true when this list organization members o k response has a 2xx status code +func (o *ListOrganizationMembersOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this list organization members o k response has a 3xx status code +func (o *ListOrganizationMembersOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organization members o k response has a 4xx status code +func (o *ListOrganizationMembersOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this list organization members o k response has a 5xx status code +func (o *ListOrganizationMembersOK) IsServerError() bool { + return false +} + +// IsCode returns true when this list organization members o k response a status code equal to that given +func (o *ListOrganizationMembersOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the list organization members o k response +func (o *ListOrganizationMembersOK) Code() int { + return 200 +} + +func (o *ListOrganizationMembersOK) Error() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersOK %+v", 200, o.Payload) +} + +func (o *ListOrganizationMembersOK) String() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersOK %+v", 200, o.Payload) +} + +func (o *ListOrganizationMembersOK) GetPayload() *ListOrganizationMembersOKBody { + return o.Payload +} + +func (o *ListOrganizationMembersOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(ListOrganizationMembersOKBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewListOrganizationMembersUnauthorized creates a ListOrganizationMembersUnauthorized with default headers values +func NewListOrganizationMembersUnauthorized() *ListOrganizationMembersUnauthorized { + return &ListOrganizationMembersUnauthorized{} +} + +/* +ListOrganizationMembersUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type ListOrganizationMembersUnauthorized struct { +} + +// IsSuccess returns true when this list organization members unauthorized response has a 2xx status code +func (o *ListOrganizationMembersUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list organization members unauthorized response has a 3xx status code +func (o *ListOrganizationMembersUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organization members unauthorized response has a 4xx status code +func (o *ListOrganizationMembersUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this list organization members unauthorized response has a 5xx status code +func (o *ListOrganizationMembersUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this list organization members unauthorized response a status code equal to that given +func (o *ListOrganizationMembersUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the list organization members unauthorized response +func (o *ListOrganizationMembersUnauthorized) Code() int { + return 401 +} + +func (o *ListOrganizationMembersUnauthorized) Error() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersUnauthorized ", 401) +} + +func (o *ListOrganizationMembersUnauthorized) String() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersUnauthorized ", 401) +} + +func (o *ListOrganizationMembersUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewListOrganizationMembersInternalServerError creates a ListOrganizationMembersInternalServerError with default headers values +func NewListOrganizationMembersInternalServerError() *ListOrganizationMembersInternalServerError { + return &ListOrganizationMembersInternalServerError{} +} + +/* +ListOrganizationMembersInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type ListOrganizationMembersInternalServerError struct { +} + +// IsSuccess returns true when this list organization members internal server error response has a 2xx status code +func (o *ListOrganizationMembersInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list organization members internal server error response has a 3xx status code +func (o *ListOrganizationMembersInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organization members internal server error response has a 4xx status code +func (o *ListOrganizationMembersInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this list organization members internal server error response has a 5xx status code +func (o *ListOrganizationMembersInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this list organization members internal server error response a status code equal to that given +func (o *ListOrganizationMembersInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the list organization members internal server error response +func (o *ListOrganizationMembersInternalServerError) Code() int { + return 500 +} + +func (o *ListOrganizationMembersInternalServerError) Error() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersInternalServerError ", 500) +} + +func (o *ListOrganizationMembersInternalServerError) String() string { + return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersInternalServerError ", 500) +} + +func (o *ListOrganizationMembersInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +ListOrganizationMembersBody list organization members body +swagger:model ListOrganizationMembersBody +*/ +type ListOrganizationMembersBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list organization members body +func (o *ListOrganizationMembersBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organization members body based on context it is used +func (o *ListOrganizationMembersBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListOrganizationMembersOKBody list organization members o k body +swagger:model ListOrganizationMembersOKBody +*/ +type ListOrganizationMembersOKBody struct { + + // members + Members []*ListOrganizationMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list organization members o k body +func (o *ListOrganizationMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list organization members o k body based on the context it is used +func (o *ListOrganizationMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListOrganizationMembersOKBodyMembersItems0 list organization members o k body members items0 +swagger:model ListOrganizationMembersOKBodyMembersItems0 +*/ +type ListOrganizationMembersOKBodyMembersItems0 struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list organization members o k body members items0 +func (o *ListOrganizationMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organization members o k body members items0 based on context it is used +func (o *ListOrganizationMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/admin/remove_organization_member_parameters.go b/rest_client_zrok/admin/remove_organization_member_parameters.go new file mode 100644 index 00000000..e59f18f1 --- /dev/null +++ b/rest_client_zrok/admin/remove_organization_member_parameters.go @@ -0,0 +1,146 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewRemoveOrganizationMemberParams creates a new RemoveOrganizationMemberParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewRemoveOrganizationMemberParams() *RemoveOrganizationMemberParams { + return &RemoveOrganizationMemberParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewRemoveOrganizationMemberParamsWithTimeout creates a new RemoveOrganizationMemberParams object +// with the ability to set a timeout on a request. +func NewRemoveOrganizationMemberParamsWithTimeout(timeout time.Duration) *RemoveOrganizationMemberParams { + return &RemoveOrganizationMemberParams{ + timeout: timeout, + } +} + +// NewRemoveOrganizationMemberParamsWithContext creates a new RemoveOrganizationMemberParams object +// with the ability to set a context for a request. +func NewRemoveOrganizationMemberParamsWithContext(ctx context.Context) *RemoveOrganizationMemberParams { + return &RemoveOrganizationMemberParams{ + Context: ctx, + } +} + +// NewRemoveOrganizationMemberParamsWithHTTPClient creates a new RemoveOrganizationMemberParams object +// with the ability to set a custom HTTPClient for a request. +func NewRemoveOrganizationMemberParamsWithHTTPClient(client *http.Client) *RemoveOrganizationMemberParams { + return &RemoveOrganizationMemberParams{ + HTTPClient: client, + } +} + +/* +RemoveOrganizationMemberParams contains all the parameters to send to the API endpoint + + for the remove organization member operation. + + Typically these are written to a http.Request. +*/ +type RemoveOrganizationMemberParams struct { + + // Body. + Body RemoveOrganizationMemberBody + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the remove organization member params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *RemoveOrganizationMemberParams) WithDefaults() *RemoveOrganizationMemberParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the remove organization member params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *RemoveOrganizationMemberParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the remove organization member params +func (o *RemoveOrganizationMemberParams) WithTimeout(timeout time.Duration) *RemoveOrganizationMemberParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the remove organization member params +func (o *RemoveOrganizationMemberParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the remove organization member params +func (o *RemoveOrganizationMemberParams) WithContext(ctx context.Context) *RemoveOrganizationMemberParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the remove organization member params +func (o *RemoveOrganizationMemberParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the remove organization member params +func (o *RemoveOrganizationMemberParams) WithHTTPClient(client *http.Client) *RemoveOrganizationMemberParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the remove organization member params +func (o *RemoveOrganizationMemberParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithBody adds the body to the remove organization member params +func (o *RemoveOrganizationMemberParams) WithBody(body RemoveOrganizationMemberBody) *RemoveOrganizationMemberParams { + o.SetBody(body) + return o +} + +// SetBody adds the body to the remove organization member params +func (o *RemoveOrganizationMemberParams) SetBody(body RemoveOrganizationMemberBody) { + o.Body = body +} + +// WriteToRequest writes these params to a swagger request +func (o *RemoveOrganizationMemberParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + if err := r.SetBodyParam(o.Body); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/remove_organization_member_responses.go b/rest_client_zrok/admin/remove_organization_member_responses.go new file mode 100644 index 00000000..ec471b2b --- /dev/null +++ b/rest_client_zrok/admin/remove_organization_member_responses.go @@ -0,0 +1,252 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// RemoveOrganizationMemberReader is a Reader for the RemoveOrganizationMember structure. +type RemoveOrganizationMemberReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *RemoveOrganizationMemberReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewRemoveOrganizationMemberOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewRemoveOrganizationMemberUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewRemoveOrganizationMemberInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[POST /organization/remove] removeOrganizationMember", response, response.Code()) + } +} + +// NewRemoveOrganizationMemberOK creates a RemoveOrganizationMemberOK with default headers values +func NewRemoveOrganizationMemberOK() *RemoveOrganizationMemberOK { + return &RemoveOrganizationMemberOK{} +} + +/* +RemoveOrganizationMemberOK describes a response with status code 200, with default header values. + +member removed +*/ +type RemoveOrganizationMemberOK struct { +} + +// IsSuccess returns true when this remove organization member o k response has a 2xx status code +func (o *RemoveOrganizationMemberOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this remove organization member o k response has a 3xx status code +func (o *RemoveOrganizationMemberOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this remove organization member o k response has a 4xx status code +func (o *RemoveOrganizationMemberOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this remove organization member o k response has a 5xx status code +func (o *RemoveOrganizationMemberOK) IsServerError() bool { + return false +} + +// IsCode returns true when this remove organization member o k response a status code equal to that given +func (o *RemoveOrganizationMemberOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the remove organization member o k response +func (o *RemoveOrganizationMemberOK) Code() int { + return 200 +} + +func (o *RemoveOrganizationMemberOK) Error() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberOK ", 200) +} + +func (o *RemoveOrganizationMemberOK) String() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberOK ", 200) +} + +func (o *RemoveOrganizationMemberOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewRemoveOrganizationMemberUnauthorized creates a RemoveOrganizationMemberUnauthorized with default headers values +func NewRemoveOrganizationMemberUnauthorized() *RemoveOrganizationMemberUnauthorized { + return &RemoveOrganizationMemberUnauthorized{} +} + +/* +RemoveOrganizationMemberUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type RemoveOrganizationMemberUnauthorized struct { +} + +// IsSuccess returns true when this remove organization member unauthorized response has a 2xx status code +func (o *RemoveOrganizationMemberUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this remove organization member unauthorized response has a 3xx status code +func (o *RemoveOrganizationMemberUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this remove organization member unauthorized response has a 4xx status code +func (o *RemoveOrganizationMemberUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this remove organization member unauthorized response has a 5xx status code +func (o *RemoveOrganizationMemberUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this remove organization member unauthorized response a status code equal to that given +func (o *RemoveOrganizationMemberUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the remove organization member unauthorized response +func (o *RemoveOrganizationMemberUnauthorized) Code() int { + return 401 +} + +func (o *RemoveOrganizationMemberUnauthorized) Error() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberUnauthorized ", 401) +} + +func (o *RemoveOrganizationMemberUnauthorized) String() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberUnauthorized ", 401) +} + +func (o *RemoveOrganizationMemberUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewRemoveOrganizationMemberInternalServerError creates a RemoveOrganizationMemberInternalServerError with default headers values +func NewRemoveOrganizationMemberInternalServerError() *RemoveOrganizationMemberInternalServerError { + return &RemoveOrganizationMemberInternalServerError{} +} + +/* +RemoveOrganizationMemberInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type RemoveOrganizationMemberInternalServerError struct { +} + +// IsSuccess returns true when this remove organization member internal server error response has a 2xx status code +func (o *RemoveOrganizationMemberInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this remove organization member internal server error response has a 3xx status code +func (o *RemoveOrganizationMemberInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this remove organization member internal server error response has a 4xx status code +func (o *RemoveOrganizationMemberInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this remove organization member internal server error response has a 5xx status code +func (o *RemoveOrganizationMemberInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this remove organization member internal server error response a status code equal to that given +func (o *RemoveOrganizationMemberInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the remove organization member internal server error response +func (o *RemoveOrganizationMemberInternalServerError) Code() int { + return 500 +} + +func (o *RemoveOrganizationMemberInternalServerError) Error() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberInternalServerError ", 500) +} + +func (o *RemoveOrganizationMemberInternalServerError) String() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberInternalServerError ", 500) +} + +func (o *RemoveOrganizationMemberInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +RemoveOrganizationMemberBody remove organization member body +swagger:model RemoveOrganizationMemberBody +*/ +type RemoveOrganizationMemberBody struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this remove organization member body +func (o *RemoveOrganizationMemberBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this remove organization member body based on context it is used +func (o *RemoveOrganizationMemberBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *RemoveOrganizationMemberBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *RemoveOrganizationMemberBody) UnmarshalBinary(b []byte) error { + var res RemoveOrganizationMemberBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index efc2bb0c..4ba5c434 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -831,6 +831,210 @@ func init() { } } }, + "/organization": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "createOrganization", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "description": { + "type": "string" + } + } + } + } + ], + "responses": { + "201": { + "description": "organization created", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + }, + "delete": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "deleteOrganization", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "organization deleted" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/add": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "addOrganizationMember", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "email": { + "type": "string" + } + } + } + } + ], + "responses": { + "201": { + "description": "member added" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/members": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "listOrganizationMembers", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "list organization members", + "schema": { + "properties": { + "members": { + "type": "array", + "items": { + "properties": { + "email": { + "type": "string" + } + } + } + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/remove": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "removeOrganizationMember", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "email": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "member removed" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/overview": { "get": { "security": [ @@ -2681,6 +2885,206 @@ func init() { } } }, + "/organization": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "createOrganization", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "description": { + "type": "string" + } + } + } + } + ], + "responses": { + "201": { + "description": "organization created", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + }, + "delete": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "deleteOrganization", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "organization deleted" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/add": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "addOrganizationMember", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "email": { + "type": "string" + } + } + } + } + ], + "responses": { + "201": { + "description": "member added" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/members": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "listOrganizationMembers", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "token": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "list organization members", + "schema": { + "properties": { + "members": { + "type": "array", + "items": { + "$ref": "#/definitions/MembersItems0" + } + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, + "/organization/remove": { + "post": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "removeOrganizationMember", + "parameters": [ + { + "name": "body", + "in": "body", + "schema": { + "properties": { + "email": { + "type": "string" + } + } + } + } + ], + "responses": { + "200": { + "description": "member removed" + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/overview": { "get": { "security": [ @@ -3064,6 +3468,13 @@ func init() { } }, "definitions": { + "MembersItems0": { + "properties": { + "email": { + "type": "string" + } + } + }, "accessRequest": { "type": "object", "properties": { diff --git a/rest_server_zrok/operations/admin/add_organization_member.go b/rest_server_zrok/operations/admin/add_organization_member.go new file mode 100644 index 00000000..3182bd45 --- /dev/null +++ b/rest_server_zrok/operations/admin/add_organization_member.go @@ -0,0 +1,111 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// AddOrganizationMemberHandlerFunc turns a function with the right signature into a add organization member handler +type AddOrganizationMemberHandlerFunc func(AddOrganizationMemberParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn AddOrganizationMemberHandlerFunc) Handle(params AddOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// AddOrganizationMemberHandler interface for that can handle valid add organization member params +type AddOrganizationMemberHandler interface { + Handle(AddOrganizationMemberParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewAddOrganizationMember creates a new http.Handler for the add organization member operation +func NewAddOrganizationMember(ctx *middleware.Context, handler AddOrganizationMemberHandler) *AddOrganizationMember { + return &AddOrganizationMember{Context: ctx, Handler: handler} +} + +/* + AddOrganizationMember swagger:route POST /organization/add admin addOrganizationMember + +AddOrganizationMember add organization member API +*/ +type AddOrganizationMember struct { + Context *middleware.Context + Handler AddOrganizationMemberHandler +} + +func (o *AddOrganizationMember) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewAddOrganizationMemberParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// AddOrganizationMemberBody add organization member body +// +// swagger:model AddOrganizationMemberBody +type AddOrganizationMemberBody struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this add organization member body +func (o *AddOrganizationMemberBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this add organization member body based on context it is used +func (o *AddOrganizationMemberBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *AddOrganizationMemberBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *AddOrganizationMemberBody) UnmarshalBinary(b []byte) error { + var res AddOrganizationMemberBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/add_organization_member_parameters.go b/rest_server_zrok/operations/admin/add_organization_member_parameters.go new file mode 100644 index 00000000..ed844182 --- /dev/null +++ b/rest_server_zrok/operations/admin/add_organization_member_parameters.go @@ -0,0 +1,74 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/validate" +) + +// NewAddOrganizationMemberParams creates a new AddOrganizationMemberParams object +// +// There are no default values defined in the spec. +func NewAddOrganizationMemberParams() AddOrganizationMemberParams { + + return AddOrganizationMemberParams{} +} + +// AddOrganizationMemberParams contains all the bound params for the add organization member operation +// typically these are obtained from a http.Request +// +// swagger:parameters addOrganizationMember +type AddOrganizationMemberParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + In: body + */ + Body AddOrganizationMemberBody +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewAddOrganizationMemberParams() beforehand. +func (o *AddOrganizationMemberParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if runtime.HasBody(r) { + defer r.Body.Close() + var body AddOrganizationMemberBody + if err := route.Consumer.Consume(r.Body, &body); err != nil { + res = append(res, errors.NewParseError("body", "body", "", err)) + } else { + // validate body object + if err := body.Validate(route.Formats); err != nil { + res = append(res, err) + } + + ctx := validate.WithOperationRequest(r.Context()) + if err := body.ContextValidate(ctx, route.Formats); err != nil { + res = append(res, err) + } + + if len(res) == 0 { + o.Body = body + } + } + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/add_organization_member_responses.go b/rest_server_zrok/operations/admin/add_organization_member_responses.go new file mode 100644 index 00000000..334c62d0 --- /dev/null +++ b/rest_server_zrok/operations/admin/add_organization_member_responses.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// AddOrganizationMemberCreatedCode is the HTTP code returned for type AddOrganizationMemberCreated +const AddOrganizationMemberCreatedCode int = 201 + +/* +AddOrganizationMemberCreated member added + +swagger:response addOrganizationMemberCreated +*/ +type AddOrganizationMemberCreated struct { +} + +// NewAddOrganizationMemberCreated creates AddOrganizationMemberCreated with default headers values +func NewAddOrganizationMemberCreated() *AddOrganizationMemberCreated { + + return &AddOrganizationMemberCreated{} +} + +// WriteResponse to the client +func (o *AddOrganizationMemberCreated) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(201) +} + +// AddOrganizationMemberUnauthorizedCode is the HTTP code returned for type AddOrganizationMemberUnauthorized +const AddOrganizationMemberUnauthorizedCode int = 401 + +/* +AddOrganizationMemberUnauthorized unauthorized + +swagger:response addOrganizationMemberUnauthorized +*/ +type AddOrganizationMemberUnauthorized struct { +} + +// NewAddOrganizationMemberUnauthorized creates AddOrganizationMemberUnauthorized with default headers values +func NewAddOrganizationMemberUnauthorized() *AddOrganizationMemberUnauthorized { + + return &AddOrganizationMemberUnauthorized{} +} + +// WriteResponse to the client +func (o *AddOrganizationMemberUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// AddOrganizationMemberInternalServerErrorCode is the HTTP code returned for type AddOrganizationMemberInternalServerError +const AddOrganizationMemberInternalServerErrorCode int = 500 + +/* +AddOrganizationMemberInternalServerError internal server error + +swagger:response addOrganizationMemberInternalServerError +*/ +type AddOrganizationMemberInternalServerError struct { +} + +// NewAddOrganizationMemberInternalServerError creates AddOrganizationMemberInternalServerError with default headers values +func NewAddOrganizationMemberInternalServerError() *AddOrganizationMemberInternalServerError { + + return &AddOrganizationMemberInternalServerError{} +} + +// WriteResponse to the client +func (o *AddOrganizationMemberInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/add_organization_member_urlbuilder.go b/rest_server_zrok/operations/admin/add_organization_member_urlbuilder.go new file mode 100644 index 00000000..d326578f --- /dev/null +++ b/rest_server_zrok/operations/admin/add_organization_member_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// AddOrganizationMemberURL generates an URL for the add organization member operation +type AddOrganizationMemberURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *AddOrganizationMemberURL) WithBasePath(bp string) *AddOrganizationMemberURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *AddOrganizationMemberURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *AddOrganizationMemberURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organization/add" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *AddOrganizationMemberURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *AddOrganizationMemberURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *AddOrganizationMemberURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on AddOrganizationMemberURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on AddOrganizationMemberURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *AddOrganizationMemberURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/admin/create_organization.go b/rest_server_zrok/operations/admin/create_organization.go new file mode 100644 index 00000000..6e92d316 --- /dev/null +++ b/rest_server_zrok/operations/admin/create_organization.go @@ -0,0 +1,148 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// CreateOrganizationHandlerFunc turns a function with the right signature into a create organization handler +type CreateOrganizationHandlerFunc func(CreateOrganizationParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn CreateOrganizationHandlerFunc) Handle(params CreateOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// CreateOrganizationHandler interface for that can handle valid create organization params +type CreateOrganizationHandler interface { + Handle(CreateOrganizationParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewCreateOrganization creates a new http.Handler for the create organization operation +func NewCreateOrganization(ctx *middleware.Context, handler CreateOrganizationHandler) *CreateOrganization { + return &CreateOrganization{Context: ctx, Handler: handler} +} + +/* + CreateOrganization swagger:route POST /organization admin createOrganization + +CreateOrganization create organization API +*/ +type CreateOrganization struct { + Context *middleware.Context + Handler CreateOrganizationHandler +} + +func (o *CreateOrganization) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewCreateOrganizationParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// CreateOrganizationBody create organization body +// +// swagger:model CreateOrganizationBody +type CreateOrganizationBody struct { + + // description + Description string `json:"description,omitempty"` +} + +// Validate validates this create organization body +func (o *CreateOrganizationBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this create organization body based on context it is used +func (o *CreateOrganizationBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *CreateOrganizationBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *CreateOrganizationBody) UnmarshalBinary(b []byte) error { + var res CreateOrganizationBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// CreateOrganizationCreatedBody create organization created body +// +// swagger:model CreateOrganizationCreatedBody +type CreateOrganizationCreatedBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this create organization created body +func (o *CreateOrganizationCreatedBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this create organization created body based on context it is used +func (o *CreateOrganizationCreatedBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *CreateOrganizationCreatedBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *CreateOrganizationCreatedBody) UnmarshalBinary(b []byte) error { + var res CreateOrganizationCreatedBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/create_organization_parameters.go b/rest_server_zrok/operations/admin/create_organization_parameters.go new file mode 100644 index 00000000..5d0a3007 --- /dev/null +++ b/rest_server_zrok/operations/admin/create_organization_parameters.go @@ -0,0 +1,74 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/validate" +) + +// NewCreateOrganizationParams creates a new CreateOrganizationParams object +// +// There are no default values defined in the spec. +func NewCreateOrganizationParams() CreateOrganizationParams { + + return CreateOrganizationParams{} +} + +// CreateOrganizationParams contains all the bound params for the create organization operation +// typically these are obtained from a http.Request +// +// swagger:parameters createOrganization +type CreateOrganizationParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + In: body + */ + Body CreateOrganizationBody +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewCreateOrganizationParams() beforehand. +func (o *CreateOrganizationParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if runtime.HasBody(r) { + defer r.Body.Close() + var body CreateOrganizationBody + if err := route.Consumer.Consume(r.Body, &body); err != nil { + res = append(res, errors.NewParseError("body", "body", "", err)) + } else { + // validate body object + if err := body.Validate(route.Formats); err != nil { + res = append(res, err) + } + + ctx := validate.WithOperationRequest(r.Context()) + if err := body.ContextValidate(ctx, route.Formats); err != nil { + res = append(res, err) + } + + if len(res) == 0 { + o.Body = body + } + } + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/create_organization_responses.go b/rest_server_zrok/operations/admin/create_organization_responses.go new file mode 100644 index 00000000..dbd239d9 --- /dev/null +++ b/rest_server_zrok/operations/admin/create_organization_responses.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// CreateOrganizationCreatedCode is the HTTP code returned for type CreateOrganizationCreated +const CreateOrganizationCreatedCode int = 201 + +/* +CreateOrganizationCreated organization created + +swagger:response createOrganizationCreated +*/ +type CreateOrganizationCreated struct { + + /* + In: Body + */ + Payload *CreateOrganizationCreatedBody `json:"body,omitempty"` +} + +// NewCreateOrganizationCreated creates CreateOrganizationCreated with default headers values +func NewCreateOrganizationCreated() *CreateOrganizationCreated { + + return &CreateOrganizationCreated{} +} + +// WithPayload adds the payload to the create organization created response +func (o *CreateOrganizationCreated) WithPayload(payload *CreateOrganizationCreatedBody) *CreateOrganizationCreated { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the create organization created response +func (o *CreateOrganizationCreated) SetPayload(payload *CreateOrganizationCreatedBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *CreateOrganizationCreated) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(201) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// CreateOrganizationUnauthorizedCode is the HTTP code returned for type CreateOrganizationUnauthorized +const CreateOrganizationUnauthorizedCode int = 401 + +/* +CreateOrganizationUnauthorized unauthorized + +swagger:response createOrganizationUnauthorized +*/ +type CreateOrganizationUnauthorized struct { +} + +// NewCreateOrganizationUnauthorized creates CreateOrganizationUnauthorized with default headers values +func NewCreateOrganizationUnauthorized() *CreateOrganizationUnauthorized { + + return &CreateOrganizationUnauthorized{} +} + +// WriteResponse to the client +func (o *CreateOrganizationUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// CreateOrganizationInternalServerErrorCode is the HTTP code returned for type CreateOrganizationInternalServerError +const CreateOrganizationInternalServerErrorCode int = 500 + +/* +CreateOrganizationInternalServerError internal server error + +swagger:response createOrganizationInternalServerError +*/ +type CreateOrganizationInternalServerError struct { +} + +// NewCreateOrganizationInternalServerError creates CreateOrganizationInternalServerError with default headers values +func NewCreateOrganizationInternalServerError() *CreateOrganizationInternalServerError { + + return &CreateOrganizationInternalServerError{} +} + +// WriteResponse to the client +func (o *CreateOrganizationInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/create_organization_urlbuilder.go b/rest_server_zrok/operations/admin/create_organization_urlbuilder.go new file mode 100644 index 00000000..aeaf39bb --- /dev/null +++ b/rest_server_zrok/operations/admin/create_organization_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// CreateOrganizationURL generates an URL for the create organization operation +type CreateOrganizationURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *CreateOrganizationURL) WithBasePath(bp string) *CreateOrganizationURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *CreateOrganizationURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *CreateOrganizationURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organization" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *CreateOrganizationURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *CreateOrganizationURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *CreateOrganizationURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on CreateOrganizationURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on CreateOrganizationURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *CreateOrganizationURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/admin/delete_organization.go b/rest_server_zrok/operations/admin/delete_organization.go new file mode 100644 index 00000000..8868d5c0 --- /dev/null +++ b/rest_server_zrok/operations/admin/delete_organization.go @@ -0,0 +1,111 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// DeleteOrganizationHandlerFunc turns a function with the right signature into a delete organization handler +type DeleteOrganizationHandlerFunc func(DeleteOrganizationParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn DeleteOrganizationHandlerFunc) Handle(params DeleteOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// DeleteOrganizationHandler interface for that can handle valid delete organization params +type DeleteOrganizationHandler interface { + Handle(DeleteOrganizationParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewDeleteOrganization creates a new http.Handler for the delete organization operation +func NewDeleteOrganization(ctx *middleware.Context, handler DeleteOrganizationHandler) *DeleteOrganization { + return &DeleteOrganization{Context: ctx, Handler: handler} +} + +/* + DeleteOrganization swagger:route DELETE /organization admin deleteOrganization + +DeleteOrganization delete organization API +*/ +type DeleteOrganization struct { + Context *middleware.Context + Handler DeleteOrganizationHandler +} + +func (o *DeleteOrganization) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewDeleteOrganizationParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// DeleteOrganizationBody delete organization body +// +// swagger:model DeleteOrganizationBody +type DeleteOrganizationBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this delete organization body +func (o *DeleteOrganizationBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this delete organization body based on context it is used +func (o *DeleteOrganizationBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *DeleteOrganizationBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *DeleteOrganizationBody) UnmarshalBinary(b []byte) error { + var res DeleteOrganizationBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/delete_organization_parameters.go b/rest_server_zrok/operations/admin/delete_organization_parameters.go new file mode 100644 index 00000000..4e8503b2 --- /dev/null +++ b/rest_server_zrok/operations/admin/delete_organization_parameters.go @@ -0,0 +1,74 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/validate" +) + +// NewDeleteOrganizationParams creates a new DeleteOrganizationParams object +// +// There are no default values defined in the spec. +func NewDeleteOrganizationParams() DeleteOrganizationParams { + + return DeleteOrganizationParams{} +} + +// DeleteOrganizationParams contains all the bound params for the delete organization operation +// typically these are obtained from a http.Request +// +// swagger:parameters deleteOrganization +type DeleteOrganizationParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + In: body + */ + Body DeleteOrganizationBody +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewDeleteOrganizationParams() beforehand. +func (o *DeleteOrganizationParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if runtime.HasBody(r) { + defer r.Body.Close() + var body DeleteOrganizationBody + if err := route.Consumer.Consume(r.Body, &body); err != nil { + res = append(res, errors.NewParseError("body", "body", "", err)) + } else { + // validate body object + if err := body.Validate(route.Formats); err != nil { + res = append(res, err) + } + + ctx := validate.WithOperationRequest(r.Context()) + if err := body.ContextValidate(ctx, route.Formats); err != nil { + res = append(res, err) + } + + if len(res) == 0 { + o.Body = body + } + } + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/delete_organization_responses.go b/rest_server_zrok/operations/admin/delete_organization_responses.go new file mode 100644 index 00000000..87776872 --- /dev/null +++ b/rest_server_zrok/operations/admin/delete_organization_responses.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// DeleteOrganizationOKCode is the HTTP code returned for type DeleteOrganizationOK +const DeleteOrganizationOKCode int = 200 + +/* +DeleteOrganizationOK organization deleted + +swagger:response deleteOrganizationOK +*/ +type DeleteOrganizationOK struct { +} + +// NewDeleteOrganizationOK creates DeleteOrganizationOK with default headers values +func NewDeleteOrganizationOK() *DeleteOrganizationOK { + + return &DeleteOrganizationOK{} +} + +// WriteResponse to the client +func (o *DeleteOrganizationOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(200) +} + +// DeleteOrganizationUnauthorizedCode is the HTTP code returned for type DeleteOrganizationUnauthorized +const DeleteOrganizationUnauthorizedCode int = 401 + +/* +DeleteOrganizationUnauthorized unauthorized + +swagger:response deleteOrganizationUnauthorized +*/ +type DeleteOrganizationUnauthorized struct { +} + +// NewDeleteOrganizationUnauthorized creates DeleteOrganizationUnauthorized with default headers values +func NewDeleteOrganizationUnauthorized() *DeleteOrganizationUnauthorized { + + return &DeleteOrganizationUnauthorized{} +} + +// WriteResponse to the client +func (o *DeleteOrganizationUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// DeleteOrganizationInternalServerErrorCode is the HTTP code returned for type DeleteOrganizationInternalServerError +const DeleteOrganizationInternalServerErrorCode int = 500 + +/* +DeleteOrganizationInternalServerError internal server error + +swagger:response deleteOrganizationInternalServerError +*/ +type DeleteOrganizationInternalServerError struct { +} + +// NewDeleteOrganizationInternalServerError creates DeleteOrganizationInternalServerError with default headers values +func NewDeleteOrganizationInternalServerError() *DeleteOrganizationInternalServerError { + + return &DeleteOrganizationInternalServerError{} +} + +// WriteResponse to the client +func (o *DeleteOrganizationInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/delete_organization_urlbuilder.go b/rest_server_zrok/operations/admin/delete_organization_urlbuilder.go new file mode 100644 index 00000000..ec6a6274 --- /dev/null +++ b/rest_server_zrok/operations/admin/delete_organization_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// DeleteOrganizationURL generates an URL for the delete organization operation +type DeleteOrganizationURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *DeleteOrganizationURL) WithBasePath(bp string) *DeleteOrganizationURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *DeleteOrganizationURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *DeleteOrganizationURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organization" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *DeleteOrganizationURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *DeleteOrganizationURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *DeleteOrganizationURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on DeleteOrganizationURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on DeleteOrganizationURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *DeleteOrganizationURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/admin/list_organization_members.go b/rest_server_zrok/operations/admin/list_organization_members.go new file mode 100644 index 00000000..d5d0c5bd --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organization_members.go @@ -0,0 +1,256 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// ListOrganizationMembersHandlerFunc turns a function with the right signature into a list organization members handler +type ListOrganizationMembersHandlerFunc func(ListOrganizationMembersParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn ListOrganizationMembersHandlerFunc) Handle(params ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// ListOrganizationMembersHandler interface for that can handle valid list organization members params +type ListOrganizationMembersHandler interface { + Handle(ListOrganizationMembersParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewListOrganizationMembers creates a new http.Handler for the list organization members operation +func NewListOrganizationMembers(ctx *middleware.Context, handler ListOrganizationMembersHandler) *ListOrganizationMembers { + return &ListOrganizationMembers{Context: ctx, Handler: handler} +} + +/* + ListOrganizationMembers swagger:route POST /organization/members admin listOrganizationMembers + +ListOrganizationMembers list organization members API +*/ +type ListOrganizationMembers struct { + Context *middleware.Context + Handler ListOrganizationMembersHandler +} + +func (o *ListOrganizationMembers) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewListOrganizationMembersParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// ListOrganizationMembersBody list organization members body +// +// swagger:model ListOrganizationMembersBody +type ListOrganizationMembersBody struct { + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list organization members body +func (o *ListOrganizationMembersBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organization members body based on context it is used +func (o *ListOrganizationMembersBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListOrganizationMembersOKBody list organization members o k body +// +// swagger:model ListOrganizationMembersOKBody +type ListOrganizationMembersOKBody struct { + + // members + Members []*ListOrganizationMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list organization members o k body +func (o *ListOrganizationMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list organization members o k body based on the context it is used +func (o *ListOrganizationMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListOrganizationMembersOKBodyMembersItems0 list organization members o k body members items0 +// +// swagger:model ListOrganizationMembersOKBodyMembersItems0 +type ListOrganizationMembersOKBodyMembersItems0 struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list organization members o k body members items0 +func (o *ListOrganizationMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organization members o k body members items0 based on context it is used +func (o *ListOrganizationMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListOrganizationMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/list_organization_members_parameters.go b/rest_server_zrok/operations/admin/list_organization_members_parameters.go new file mode 100644 index 00000000..fa7c87ed --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organization_members_parameters.go @@ -0,0 +1,74 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/validate" +) + +// NewListOrganizationMembersParams creates a new ListOrganizationMembersParams object +// +// There are no default values defined in the spec. +func NewListOrganizationMembersParams() ListOrganizationMembersParams { + + return ListOrganizationMembersParams{} +} + +// ListOrganizationMembersParams contains all the bound params for the list organization members operation +// typically these are obtained from a http.Request +// +// swagger:parameters listOrganizationMembers +type ListOrganizationMembersParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + In: body + */ + Body ListOrganizationMembersBody +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewListOrganizationMembersParams() beforehand. +func (o *ListOrganizationMembersParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if runtime.HasBody(r) { + defer r.Body.Close() + var body ListOrganizationMembersBody + if err := route.Consumer.Consume(r.Body, &body); err != nil { + res = append(res, errors.NewParseError("body", "body", "", err)) + } else { + // validate body object + if err := body.Validate(route.Formats); err != nil { + res = append(res, err) + } + + ctx := validate.WithOperationRequest(r.Context()) + if err := body.ContextValidate(ctx, route.Formats); err != nil { + res = append(res, err) + } + + if len(res) == 0 { + o.Body = body + } + } + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/list_organization_members_responses.go b/rest_server_zrok/operations/admin/list_organization_members_responses.go new file mode 100644 index 00000000..615e5417 --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organization_members_responses.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// ListOrganizationMembersOKCode is the HTTP code returned for type ListOrganizationMembersOK +const ListOrganizationMembersOKCode int = 200 + +/* +ListOrganizationMembersOK list organization members + +swagger:response listOrganizationMembersOK +*/ +type ListOrganizationMembersOK struct { + + /* + In: Body + */ + Payload *ListOrganizationMembersOKBody `json:"body,omitempty"` +} + +// NewListOrganizationMembersOK creates ListOrganizationMembersOK with default headers values +func NewListOrganizationMembersOK() *ListOrganizationMembersOK { + + return &ListOrganizationMembersOK{} +} + +// WithPayload adds the payload to the list organization members o k response +func (o *ListOrganizationMembersOK) WithPayload(payload *ListOrganizationMembersOKBody) *ListOrganizationMembersOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the list organization members o k response +func (o *ListOrganizationMembersOK) SetPayload(payload *ListOrganizationMembersOKBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *ListOrganizationMembersOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// ListOrganizationMembersUnauthorizedCode is the HTTP code returned for type ListOrganizationMembersUnauthorized +const ListOrganizationMembersUnauthorizedCode int = 401 + +/* +ListOrganizationMembersUnauthorized unauthorized + +swagger:response listOrganizationMembersUnauthorized +*/ +type ListOrganizationMembersUnauthorized struct { +} + +// NewListOrganizationMembersUnauthorized creates ListOrganizationMembersUnauthorized with default headers values +func NewListOrganizationMembersUnauthorized() *ListOrganizationMembersUnauthorized { + + return &ListOrganizationMembersUnauthorized{} +} + +// WriteResponse to the client +func (o *ListOrganizationMembersUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// ListOrganizationMembersInternalServerErrorCode is the HTTP code returned for type ListOrganizationMembersInternalServerError +const ListOrganizationMembersInternalServerErrorCode int = 500 + +/* +ListOrganizationMembersInternalServerError internal server error + +swagger:response listOrganizationMembersInternalServerError +*/ +type ListOrganizationMembersInternalServerError struct { +} + +// NewListOrganizationMembersInternalServerError creates ListOrganizationMembersInternalServerError with default headers values +func NewListOrganizationMembersInternalServerError() *ListOrganizationMembersInternalServerError { + + return &ListOrganizationMembersInternalServerError{} +} + +// WriteResponse to the client +func (o *ListOrganizationMembersInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go b/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go new file mode 100644 index 00000000..62423a6a --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// ListOrganizationMembersURL generates an URL for the list organization members operation +type ListOrganizationMembersURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrganizationMembersURL) WithBasePath(bp string) *ListOrganizationMembersURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrganizationMembersURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *ListOrganizationMembersURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organization/members" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *ListOrganizationMembersURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *ListOrganizationMembersURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *ListOrganizationMembersURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on ListOrganizationMembersURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on ListOrganizationMembersURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *ListOrganizationMembersURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/admin/remove_organization_member.go b/rest_server_zrok/operations/admin/remove_organization_member.go new file mode 100644 index 00000000..087d8f74 --- /dev/null +++ b/rest_server_zrok/operations/admin/remove_organization_member.go @@ -0,0 +1,111 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// RemoveOrganizationMemberHandlerFunc turns a function with the right signature into a remove organization member handler +type RemoveOrganizationMemberHandlerFunc func(RemoveOrganizationMemberParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn RemoveOrganizationMemberHandlerFunc) Handle(params RemoveOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// RemoveOrganizationMemberHandler interface for that can handle valid remove organization member params +type RemoveOrganizationMemberHandler interface { + Handle(RemoveOrganizationMemberParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewRemoveOrganizationMember creates a new http.Handler for the remove organization member operation +func NewRemoveOrganizationMember(ctx *middleware.Context, handler RemoveOrganizationMemberHandler) *RemoveOrganizationMember { + return &RemoveOrganizationMember{Context: ctx, Handler: handler} +} + +/* + RemoveOrganizationMember swagger:route POST /organization/remove admin removeOrganizationMember + +RemoveOrganizationMember remove organization member API +*/ +type RemoveOrganizationMember struct { + Context *middleware.Context + Handler RemoveOrganizationMemberHandler +} + +func (o *RemoveOrganizationMember) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewRemoveOrganizationMemberParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// RemoveOrganizationMemberBody remove organization member body +// +// swagger:model RemoveOrganizationMemberBody +type RemoveOrganizationMemberBody struct { + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this remove organization member body +func (o *RemoveOrganizationMemberBody) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this remove organization member body based on context it is used +func (o *RemoveOrganizationMemberBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *RemoveOrganizationMemberBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *RemoveOrganizationMemberBody) UnmarshalBinary(b []byte) error { + var res RemoveOrganizationMemberBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/remove_organization_member_parameters.go b/rest_server_zrok/operations/admin/remove_organization_member_parameters.go new file mode 100644 index 00000000..50ee2514 --- /dev/null +++ b/rest_server_zrok/operations/admin/remove_organization_member_parameters.go @@ -0,0 +1,74 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/validate" +) + +// NewRemoveOrganizationMemberParams creates a new RemoveOrganizationMemberParams object +// +// There are no default values defined in the spec. +func NewRemoveOrganizationMemberParams() RemoveOrganizationMemberParams { + + return RemoveOrganizationMemberParams{} +} + +// RemoveOrganizationMemberParams contains all the bound params for the remove organization member operation +// typically these are obtained from a http.Request +// +// swagger:parameters removeOrganizationMember +type RemoveOrganizationMemberParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + In: body + */ + Body RemoveOrganizationMemberBody +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewRemoveOrganizationMemberParams() beforehand. +func (o *RemoveOrganizationMemberParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if runtime.HasBody(r) { + defer r.Body.Close() + var body RemoveOrganizationMemberBody + if err := route.Consumer.Consume(r.Body, &body); err != nil { + res = append(res, errors.NewParseError("body", "body", "", err)) + } else { + // validate body object + if err := body.Validate(route.Formats); err != nil { + res = append(res, err) + } + + ctx := validate.WithOperationRequest(r.Context()) + if err := body.ContextValidate(ctx, route.Formats); err != nil { + res = append(res, err) + } + + if len(res) == 0 { + o.Body = body + } + } + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/remove_organization_member_responses.go b/rest_server_zrok/operations/admin/remove_organization_member_responses.go new file mode 100644 index 00000000..4164a95e --- /dev/null +++ b/rest_server_zrok/operations/admin/remove_organization_member_responses.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// RemoveOrganizationMemberOKCode is the HTTP code returned for type RemoveOrganizationMemberOK +const RemoveOrganizationMemberOKCode int = 200 + +/* +RemoveOrganizationMemberOK member removed + +swagger:response removeOrganizationMemberOK +*/ +type RemoveOrganizationMemberOK struct { +} + +// NewRemoveOrganizationMemberOK creates RemoveOrganizationMemberOK with default headers values +func NewRemoveOrganizationMemberOK() *RemoveOrganizationMemberOK { + + return &RemoveOrganizationMemberOK{} +} + +// WriteResponse to the client +func (o *RemoveOrganizationMemberOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(200) +} + +// RemoveOrganizationMemberUnauthorizedCode is the HTTP code returned for type RemoveOrganizationMemberUnauthorized +const RemoveOrganizationMemberUnauthorizedCode int = 401 + +/* +RemoveOrganizationMemberUnauthorized unauthorized + +swagger:response removeOrganizationMemberUnauthorized +*/ +type RemoveOrganizationMemberUnauthorized struct { +} + +// NewRemoveOrganizationMemberUnauthorized creates RemoveOrganizationMemberUnauthorized with default headers values +func NewRemoveOrganizationMemberUnauthorized() *RemoveOrganizationMemberUnauthorized { + + return &RemoveOrganizationMemberUnauthorized{} +} + +// WriteResponse to the client +func (o *RemoveOrganizationMemberUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// RemoveOrganizationMemberInternalServerErrorCode is the HTTP code returned for type RemoveOrganizationMemberInternalServerError +const RemoveOrganizationMemberInternalServerErrorCode int = 500 + +/* +RemoveOrganizationMemberInternalServerError internal server error + +swagger:response removeOrganizationMemberInternalServerError +*/ +type RemoveOrganizationMemberInternalServerError struct { +} + +// NewRemoveOrganizationMemberInternalServerError creates RemoveOrganizationMemberInternalServerError with default headers values +func NewRemoveOrganizationMemberInternalServerError() *RemoveOrganizationMemberInternalServerError { + + return &RemoveOrganizationMemberInternalServerError{} +} + +// WriteResponse to the client +func (o *RemoveOrganizationMemberInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/remove_organization_member_urlbuilder.go b/rest_server_zrok/operations/admin/remove_organization_member_urlbuilder.go new file mode 100644 index 00000000..e31f697a --- /dev/null +++ b/rest_server_zrok/operations/admin/remove_organization_member_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// RemoveOrganizationMemberURL generates an URL for the remove organization member operation +type RemoveOrganizationMemberURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *RemoveOrganizationMemberURL) WithBasePath(bp string) *RemoveOrganizationMemberURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *RemoveOrganizationMemberURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *RemoveOrganizationMemberURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organization/remove" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *RemoveOrganizationMemberURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *RemoveOrganizationMemberURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *RemoveOrganizationMemberURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on RemoveOrganizationMemberURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on RemoveOrganizationMemberURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *RemoveOrganizationMemberURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index 9c86bfd6..0baf6e08 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -52,6 +52,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { ShareAccessHandler: share.AccessHandlerFunc(func(params share.AccessParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation share.Access has not yet been implemented") }), + AdminAddOrganizationMemberHandler: admin.AddOrganizationMemberHandlerFunc(func(params admin.AddOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.AddOrganizationMember has not yet been implemented") + }), AccountChangePasswordHandler: account.ChangePasswordHandlerFunc(func(params account.ChangePasswordParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation account.ChangePassword has not yet been implemented") }), @@ -67,9 +70,15 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AdminCreateIdentityHandler: admin.CreateIdentityHandlerFunc(func(params admin.CreateIdentityParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.CreateIdentity has not yet been implemented") }), + AdminCreateOrganizationHandler: admin.CreateOrganizationHandlerFunc(func(params admin.CreateOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.CreateOrganization has not yet been implemented") + }), AdminDeleteFrontendHandler: admin.DeleteFrontendHandlerFunc(func(params admin.DeleteFrontendParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.DeleteFrontend has not yet been implemented") }), + AdminDeleteOrganizationHandler: admin.DeleteOrganizationHandlerFunc(func(params admin.DeleteOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.DeleteOrganization has not yet been implemented") + }), EnvironmentDisableHandler: environment.DisableHandlerFunc(func(params environment.DisableParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation environment.Disable has not yet been implemented") }), @@ -109,6 +118,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AdminListFrontendsHandler: admin.ListFrontendsHandlerFunc(func(params admin.ListFrontendsParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.ListFrontends has not yet been implemented") }), + AdminListOrganizationMembersHandler: admin.ListOrganizationMembersHandlerFunc(func(params admin.ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.ListOrganizationMembers has not yet been implemented") + }), AccountLoginHandler: account.LoginHandlerFunc(func(params account.LoginParams) middleware.Responder { return middleware.NotImplemented("operation account.Login has not yet been implemented") }), @@ -121,6 +133,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AccountRegisterHandler: account.RegisterHandlerFunc(func(params account.RegisterParams) middleware.Responder { return middleware.NotImplemented("operation account.Register has not yet been implemented") }), + AdminRemoveOrganizationMemberHandler: admin.RemoveOrganizationMemberHandlerFunc(func(params admin.RemoveOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.RemoveOrganizationMember has not yet been implemented") + }), AccountResetPasswordHandler: account.ResetPasswordHandlerFunc(func(params account.ResetPasswordParams) middleware.Responder { return middleware.NotImplemented("operation account.ResetPassword has not yet been implemented") }), @@ -200,6 +215,8 @@ type ZrokAPI struct { // ShareAccessHandler sets the operation handler for the access operation ShareAccessHandler share.AccessHandler + // AdminAddOrganizationMemberHandler sets the operation handler for the add organization member operation + AdminAddOrganizationMemberHandler admin.AddOrganizationMemberHandler // AccountChangePasswordHandler sets the operation handler for the change password operation AccountChangePasswordHandler account.ChangePasswordHandler // MetadataConfigurationHandler sets the operation handler for the configuration operation @@ -210,8 +227,12 @@ type ZrokAPI struct { AdminCreateFrontendHandler admin.CreateFrontendHandler // AdminCreateIdentityHandler sets the operation handler for the create identity operation AdminCreateIdentityHandler admin.CreateIdentityHandler + // AdminCreateOrganizationHandler sets the operation handler for the create organization operation + AdminCreateOrganizationHandler admin.CreateOrganizationHandler // AdminDeleteFrontendHandler sets the operation handler for the delete frontend operation AdminDeleteFrontendHandler admin.DeleteFrontendHandler + // AdminDeleteOrganizationHandler sets the operation handler for the delete organization operation + AdminDeleteOrganizationHandler admin.DeleteOrganizationHandler // EnvironmentDisableHandler sets the operation handler for the disable operation EnvironmentDisableHandler environment.DisableHandler // EnvironmentEnableHandler sets the operation handler for the enable operation @@ -238,6 +259,8 @@ type ZrokAPI struct { AdminInviteTokenGenerateHandler admin.InviteTokenGenerateHandler // AdminListFrontendsHandler sets the operation handler for the list frontends operation AdminListFrontendsHandler admin.ListFrontendsHandler + // AdminListOrganizationMembersHandler sets the operation handler for the list organization members operation + AdminListOrganizationMembersHandler admin.ListOrganizationMembersHandler // AccountLoginHandler sets the operation handler for the login operation AccountLoginHandler account.LoginHandler // MetadataOverviewHandler sets the operation handler for the overview operation @@ -246,6 +269,8 @@ type ZrokAPI struct { AccountRegenerateTokenHandler account.RegenerateTokenHandler // AccountRegisterHandler sets the operation handler for the register operation AccountRegisterHandler account.RegisterHandler + // AdminRemoveOrganizationMemberHandler sets the operation handler for the remove organization member operation + AdminRemoveOrganizationMemberHandler admin.RemoveOrganizationMemberHandler // AccountResetPasswordHandler sets the operation handler for the reset password operation AccountResetPasswordHandler account.ResetPasswordHandler // AccountResetPasswordRequestHandler sets the operation handler for the reset password request operation @@ -348,6 +373,9 @@ func (o *ZrokAPI) Validate() error { if o.ShareAccessHandler == nil { unregistered = append(unregistered, "share.AccessHandler") } + if o.AdminAddOrganizationMemberHandler == nil { + unregistered = append(unregistered, "admin.AddOrganizationMemberHandler") + } if o.AccountChangePasswordHandler == nil { unregistered = append(unregistered, "account.ChangePasswordHandler") } @@ -363,9 +391,15 @@ func (o *ZrokAPI) Validate() error { if o.AdminCreateIdentityHandler == nil { unregistered = append(unregistered, "admin.CreateIdentityHandler") } + if o.AdminCreateOrganizationHandler == nil { + unregistered = append(unregistered, "admin.CreateOrganizationHandler") + } if o.AdminDeleteFrontendHandler == nil { unregistered = append(unregistered, "admin.DeleteFrontendHandler") } + if o.AdminDeleteOrganizationHandler == nil { + unregistered = append(unregistered, "admin.DeleteOrganizationHandler") + } if o.EnvironmentDisableHandler == nil { unregistered = append(unregistered, "environment.DisableHandler") } @@ -405,6 +439,9 @@ func (o *ZrokAPI) Validate() error { if o.AdminListFrontendsHandler == nil { unregistered = append(unregistered, "admin.ListFrontendsHandler") } + if o.AdminListOrganizationMembersHandler == nil { + unregistered = append(unregistered, "admin.ListOrganizationMembersHandler") + } if o.AccountLoginHandler == nil { unregistered = append(unregistered, "account.LoginHandler") } @@ -417,6 +454,9 @@ func (o *ZrokAPI) Validate() error { if o.AccountRegisterHandler == nil { unregistered = append(unregistered, "account.RegisterHandler") } + if o.AdminRemoveOrganizationMemberHandler == nil { + unregistered = append(unregistered, "admin.RemoveOrganizationMemberHandler") + } if o.AccountResetPasswordHandler == nil { unregistered = append(unregistered, "account.ResetPasswordHandler") } @@ -550,6 +590,10 @@ func (o *ZrokAPI) initHandlerCache() { if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } + o.handlers["POST"]["/organization/add"] = admin.NewAddOrganizationMember(o.context, o.AdminAddOrganizationMemberHandler) + if o.handlers["POST"] == nil { + o.handlers["POST"] = make(map[string]http.Handler) + } o.handlers["POST"]["/changePassword"] = account.NewChangePassword(o.context, o.AccountChangePasswordHandler) if o.handlers["GET"] == nil { o.handlers["GET"] = make(map[string]http.Handler) @@ -567,10 +611,18 @@ func (o *ZrokAPI) initHandlerCache() { o.handlers["POST"] = make(map[string]http.Handler) } o.handlers["POST"]["/identity"] = admin.NewCreateIdentity(o.context, o.AdminCreateIdentityHandler) + if o.handlers["POST"] == nil { + o.handlers["POST"] = make(map[string]http.Handler) + } + o.handlers["POST"]["/organization"] = admin.NewCreateOrganization(o.context, o.AdminCreateOrganizationHandler) if o.handlers["DELETE"] == nil { o.handlers["DELETE"] = make(map[string]http.Handler) } o.handlers["DELETE"]["/frontend"] = admin.NewDeleteFrontend(o.context, o.AdminDeleteFrontendHandler) + if o.handlers["DELETE"] == nil { + o.handlers["DELETE"] = make(map[string]http.Handler) + } + o.handlers["DELETE"]["/organization"] = admin.NewDeleteOrganization(o.context, o.AdminDeleteOrganizationHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } @@ -626,6 +678,10 @@ func (o *ZrokAPI) initHandlerCache() { if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } + o.handlers["POST"]["/organization/members"] = admin.NewListOrganizationMembers(o.context, o.AdminListOrganizationMembersHandler) + if o.handlers["POST"] == nil { + o.handlers["POST"] = make(map[string]http.Handler) + } o.handlers["POST"]["/login"] = account.NewLogin(o.context, o.AccountLoginHandler) if o.handlers["GET"] == nil { o.handlers["GET"] = make(map[string]http.Handler) @@ -642,6 +698,10 @@ func (o *ZrokAPI) initHandlerCache() { if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } + o.handlers["POST"]["/organization/remove"] = admin.NewRemoveOrganizationMember(o.context, o.AdminRemoveOrganizationMemberHandler) + if o.handlers["POST"] == nil { + o.handlers["POST"] = make(map[string]http.Handler) + } o.handlers["POST"]["/resetPassword"] = account.NewResetPassword(o.context, o.AccountResetPasswordHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index db21b7d1..55aacd91 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -16,6 +16,7 @@ model/createFrontendRequest.ts model/createFrontendResponse.ts model/createIdentity201Response.ts model/createIdentityRequest.ts +model/createOrganizationRequest.ts model/deleteFrontendRequest.ts model/disableRequest.ts model/enableRequest.ts @@ -26,6 +27,7 @@ model/frontend.ts model/grantsRequest.ts model/inviteRequest.ts model/inviteTokenGenerateRequest.ts +model/listOrganizationMembers200Response.ts model/loginRequest.ts model/metrics.ts model/metricsSample.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index 591bfdde..b0f0f752 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -20,9 +20,11 @@ import { CreateFrontendRequest } from '../model/createFrontendRequest'; import { CreateFrontendResponse } from '../model/createFrontendResponse'; import { CreateIdentity201Response } from '../model/createIdentity201Response'; import { CreateIdentityRequest } from '../model/createIdentityRequest'; +import { CreateOrganizationRequest } from '../model/createOrganizationRequest'; import { DeleteFrontendRequest } from '../model/deleteFrontendRequest'; import { GrantsRequest } from '../model/grantsRequest'; import { InviteTokenGenerateRequest } from '../model/inviteTokenGenerateRequest'; +import { ListOrganizationMembers200Response } from '../model/listOrganizationMembers200Response'; import { PublicFrontend } from '../model/publicFrontend'; import { RegenerateToken200Response } from '../model/regenerateToken200Response'; import { UpdateFrontendRequest } from '../model/updateFrontendRequest'; @@ -99,6 +101,64 @@ export class AdminApi { this.interceptors.push(interceptor); } + /** + * + * @param body + */ + public async addOrganizationMember (body?: GrantsRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + const localVarPath = this.basePath + '/organization/add'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'POST', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + body: ObjectSerializer.serialize(body, "GrantsRequest") + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body?: any; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param body @@ -297,6 +357,72 @@ export class AdminApi { }); }); } + /** + * + * @param body + */ + public async createOrganization (body?: CreateOrganizationRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: RegenerateToken200Response; }> { + const localVarPath = this.basePath + '/organization'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'POST', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + body: ObjectSerializer.serialize(body, "CreateOrganizationRequest") + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: RegenerateToken200Response; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "RegenerateToken200Response"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param body @@ -355,6 +481,64 @@ export class AdminApi { }); }); } + /** + * + * @param body + */ + public async deleteOrganization (body?: RegenerateToken200Response, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + const localVarPath = this.basePath + '/organization'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'DELETE', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + body: ObjectSerializer.serialize(body, "RegenerateToken200Response") + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body?: any; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param body @@ -535,6 +719,130 @@ export class AdminApi { }); }); } + /** + * + * @param body + */ + public async listOrganizationMembers (body?: RegenerateToken200Response, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: ListOrganizationMembers200Response; }> { + const localVarPath = this.basePath + '/organization/members'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'POST', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + body: ObjectSerializer.serialize(body, "RegenerateToken200Response") + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: ListOrganizationMembers200Response; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "ListOrganizationMembers200Response"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } + /** + * + * @param body + */ + public async removeOrganizationMember (body?: GrantsRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + const localVarPath = this.basePath + '/organization/remove'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'POST', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + body: ObjectSerializer.serialize(body, "GrantsRequest") + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body?: any; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param body diff --git a/sdk/nodejs/sdk/src/zrok/api/model/createOrganizationRequest.ts b/sdk/nodejs/sdk/src/zrok/api/model/createOrganizationRequest.ts new file mode 100644 index 00000000..6b3d737a --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/createOrganizationRequest.ts @@ -0,0 +1,31 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class CreateOrganizationRequest { + 'description'?: string; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "description", + "baseName": "description", + "type": "string" + } ]; + + static getAttributeTypeMap() { + return CreateOrganizationRequest.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts new file mode 100644 index 00000000..5e180b79 --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts @@ -0,0 +1,32 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; +import { GrantsRequest } from './grantsRequest'; + +export class ListOrganizationMembers200Response { + 'members'?: Array; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "members", + "baseName": "members", + "type": "Array" + } ]; + + static getAttributeTypeMap() { + return ListOrganizationMembers200Response.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index f2a3e3ca..62d0b052 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -10,6 +10,7 @@ export * from './createFrontendRequest'; export * from './createFrontendResponse'; export * from './createIdentity201Response'; export * from './createIdentityRequest'; +export * from './createOrganizationRequest'; export * from './deleteFrontendRequest'; export * from './disableRequest'; export * from './enableRequest'; @@ -20,6 +21,7 @@ export * from './frontend'; export * from './grantsRequest'; export * from './inviteRequest'; export * from './inviteTokenGenerateRequest'; +export * from './listOrganizationMembers200Response'; export * from './loginRequest'; export * from './metrics'; export * from './metricsSample'; @@ -66,6 +68,7 @@ import { CreateFrontendRequest } from './createFrontendRequest'; import { CreateFrontendResponse } from './createFrontendResponse'; import { CreateIdentity201Response } from './createIdentity201Response'; import { CreateIdentityRequest } from './createIdentityRequest'; +import { CreateOrganizationRequest } from './createOrganizationRequest'; import { DeleteFrontendRequest } from './deleteFrontendRequest'; import { DisableRequest } from './disableRequest'; import { EnableRequest } from './enableRequest'; @@ -76,6 +79,7 @@ import { Frontend } from './frontend'; import { GrantsRequest } from './grantsRequest'; import { InviteRequest } from './inviteRequest'; import { InviteTokenGenerateRequest } from './inviteTokenGenerateRequest'; +import { ListOrganizationMembers200Response } from './listOrganizationMembers200Response'; import { LoginRequest } from './loginRequest'; import { Metrics } from './metrics'; import { MetricsSample } from './metricsSample'; @@ -130,6 +134,7 @@ let typeMap: {[index: string]: any} = { "CreateFrontendResponse": CreateFrontendResponse, "CreateIdentity201Response": CreateIdentity201Response, "CreateIdentityRequest": CreateIdentityRequest, + "CreateOrganizationRequest": CreateOrganizationRequest, "DeleteFrontendRequest": DeleteFrontendRequest, "DisableRequest": DisableRequest, "EnableRequest": EnableRequest, @@ -140,6 +145,7 @@ let typeMap: {[index: string]: any} = { "GrantsRequest": GrantsRequest, "InviteRequest": InviteRequest, "InviteTokenGenerateRequest": InviteTokenGenerateRequest, + "ListOrganizationMembers200Response": ListOrganizationMembers200Response, "LoginRequest": LoginRequest, "Metrics": Metrics, "MetricsSample": MetricsSample, diff --git a/sdk/python/sdk/zrok/zrok_api/__init__.py b/sdk/python/sdk/zrok/zrok_api/__init__.py index dcf61c55..cab88172 100644 --- a/sdk/python/sdk/zrok/zrok_api/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/__init__.py @@ -45,6 +45,7 @@ from zrok_api.models.frontends import Frontends from zrok_api.models.grants_body import GrantsBody from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 +from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest @@ -52,6 +53,11 @@ from zrok_api.models.login_request import LoginRequest from zrok_api.models.login_response import LoginResponse from zrok_api.models.metrics import Metrics from zrok_api.models.metrics_sample import MetricsSample +from zrok_api.models.organization_add_body import OrganizationAddBody +from zrok_api.models.organization_body import OrganizationBody +from zrok_api.models.organization_body1 import OrganizationBody1 +from zrok_api.models.organization_members_body import OrganizationMembersBody +from zrok_api.models.organization_remove_body import OrganizationRemoveBody from zrok_api.models.overview import Overview from zrok_api.models.password_requirements import PasswordRequirements from zrok_api.models.principal import Principal diff --git a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py index 8ea807e3..9007e022 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py @@ -32,6 +32,95 @@ class AdminApi(object): api_client = ApiClient() self.api_client = api_client + def add_organization_member(self, **kwargs): # noqa: E501 + """add_organization_member # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.add_organization_member(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationAddBody body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.add_organization_member_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.add_organization_member_with_http_info(**kwargs) # noqa: E501 + return data + + def add_organization_member_with_http_info(self, **kwargs): # noqa: E501 + """add_organization_member # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.add_organization_member_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationAddBody body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['body'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method add_organization_member" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + if 'body' in params: + body_params = params['body'] + # HTTP header `Content-Type` + header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501 + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organization/add', 'POST', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type=None, # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def create_account(self, **kwargs): # noqa: E501 """create_account # noqa: E501 @@ -311,6 +400,99 @@ class AdminApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def create_organization(self, **kwargs): # noqa: E501 + """create_organization # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.create_organization(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationBody body: + :return: InlineResponse200 + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.create_organization_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.create_organization_with_http_info(**kwargs) # noqa: E501 + return data + + def create_organization_with_http_info(self, **kwargs): # noqa: E501 + """create_organization # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.create_organization_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationBody body: + :return: InlineResponse200 + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['body'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method create_organization" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + if 'body' in params: + body_params = params['body'] + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # HTTP header `Content-Type` + header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501 + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organization', 'POST', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='InlineResponse200', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def delete_frontend(self, **kwargs): # noqa: E501 """delete_frontend # noqa: E501 @@ -400,6 +582,95 @@ class AdminApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def delete_organization(self, **kwargs): # noqa: E501 + """delete_organization # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.delete_organization(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationBody1 body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.delete_organization_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.delete_organization_with_http_info(**kwargs) # noqa: E501 + return data + + def delete_organization_with_http_info(self, **kwargs): # noqa: E501 + """delete_organization # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.delete_organization_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationBody1 body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['body'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method delete_organization" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + if 'body' in params: + body_params = params['body'] + # HTTP header `Content-Type` + header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501 + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organization', 'DELETE', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type=None, # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def grants(self, **kwargs): # noqa: E501 """grants # noqa: E501 @@ -663,6 +934,188 @@ class AdminApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def list_organization_members(self, **kwargs): # noqa: E501 + """list_organization_members # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_organization_members(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationMembersBody body: + :return: InlineResponse2001 + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.list_organization_members_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.list_organization_members_with_http_info(**kwargs) # noqa: E501 + return data + + def list_organization_members_with_http_info(self, **kwargs): # noqa: E501 + """list_organization_members # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_organization_members_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationMembersBody body: + :return: InlineResponse2001 + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['body'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method list_organization_members" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + if 'body' in params: + body_params = params['body'] + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # HTTP header `Content-Type` + header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501 + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organization/members', 'POST', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='InlineResponse2001', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + + def remove_organization_member(self, **kwargs): # noqa: E501 + """remove_organization_member # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.remove_organization_member(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationRemoveBody body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.remove_organization_member_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.remove_organization_member_with_http_info(**kwargs) # noqa: E501 + return data + + def remove_organization_member_with_http_info(self, **kwargs): # noqa: E501 + """remove_organization_member # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.remove_organization_member_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :param OrganizationRemoveBody body: + :return: None + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['body'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method remove_organization_member" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + if 'body' in params: + body_params = params['body'] + # HTTP header `Content-Type` + header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501 + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organization/remove', 'POST', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type=None, # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def update_frontend(self, **kwargs): # noqa: E501 """update_frontend # noqa: E501 diff --git a/sdk/python/sdk/zrok/zrok_api/models/__init__.py b/sdk/python/sdk/zrok/zrok_api/models/__init__.py index 6707a220..b987cf91 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/models/__init__.py @@ -35,6 +35,7 @@ from zrok_api.models.frontends import Frontends from zrok_api.models.grants_body import GrantsBody from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 +from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest @@ -42,6 +43,11 @@ from zrok_api.models.login_request import LoginRequest from zrok_api.models.login_response import LoginResponse from zrok_api.models.metrics import Metrics from zrok_api.models.metrics_sample import MetricsSample +from zrok_api.models.organization_add_body import OrganizationAddBody +from zrok_api.models.organization_body import OrganizationBody +from zrok_api.models.organization_body1 import OrganizationBody1 +from zrok_api.models.organization_members_body import OrganizationMembersBody +from zrok_api.models.organization_remove_body import OrganizationRemoveBody from zrok_api.models.overview import Overview from zrok_api.models.password_requirements import PasswordRequirements from zrok_api.models.principal import Principal diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py new file mode 100644 index 00000000..95f369b4 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2001(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'members': 'list[OrganizationRemoveBody]' + } + + attribute_map = { + 'members': 'members' + } + + def __init__(self, members=None): # noqa: E501 + """InlineResponse2001 - a model defined in Swagger""" # noqa: E501 + self._members = None + self.discriminator = None + if members is not None: + self.members = members + + @property + def members(self): + """Gets the members of this InlineResponse2001. # noqa: E501 + + + :return: The members of this InlineResponse2001. # noqa: E501 + :rtype: list[OrganizationRemoveBody] + """ + return self._members + + @members.setter + def members(self, members): + """Sets the members of this InlineResponse2001. + + + :param members: The members of this InlineResponse2001. # noqa: E501 + :type: list[OrganizationRemoveBody] + """ + + self._members = members + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2001, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2001): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py new file mode 100644 index 00000000..025f2e73 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationAddBody(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'email': 'str' + } + + attribute_map = { + 'email': 'email' + } + + def __init__(self, email=None): # noqa: E501 + """OrganizationAddBody - a model defined in Swagger""" # noqa: E501 + self._email = None + self.discriminator = None + if email is not None: + self.email = email + + @property + def email(self): + """Gets the email of this OrganizationAddBody. # noqa: E501 + + + :return: The email of this OrganizationAddBody. # noqa: E501 + :rtype: str + """ + return self._email + + @email.setter + def email(self, email): + """Sets the email of this OrganizationAddBody. + + + :param email: The email of this OrganizationAddBody. # noqa: E501 + :type: str + """ + + self._email = email + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationAddBody, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationAddBody): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_body.py new file mode 100644 index 00000000..0875eadb --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_body.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationBody(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'description': 'str' + } + + attribute_map = { + 'description': 'description' + } + + def __init__(self, description=None): # noqa: E501 + """OrganizationBody - a model defined in Swagger""" # noqa: E501 + self._description = None + self.discriminator = None + if description is not None: + self.description = description + + @property + def description(self): + """Gets the description of this OrganizationBody. # noqa: E501 + + + :return: The description of this OrganizationBody. # noqa: E501 + :rtype: str + """ + return self._description + + @description.setter + def description(self, description): + """Sets the description of this OrganizationBody. + + + :param description: The description of this OrganizationBody. # noqa: E501 + :type: str + """ + + self._description = description + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationBody, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationBody): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_body1.py b/sdk/python/sdk/zrok/zrok_api/models/organization_body1.py new file mode 100644 index 00000000..a605af16 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_body1.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationBody1(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str' + } + + attribute_map = { + 'token': 'token' + } + + def __init__(self, token=None): # noqa: E501 + """OrganizationBody1 - a model defined in Swagger""" # noqa: E501 + self._token = None + self.discriminator = None + if token is not None: + self.token = token + + @property + def token(self): + """Gets the token of this OrganizationBody1. # noqa: E501 + + + :return: The token of this OrganizationBody1. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationBody1. + + + :param token: The token of this OrganizationBody1. # noqa: E501 + :type: str + """ + + self._token = token + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationBody1, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationBody1): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_members_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_members_body.py new file mode 100644 index 00000000..354d3f46 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_members_body.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationMembersBody(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str' + } + + attribute_map = { + 'token': 'token' + } + + def __init__(self, token=None): # noqa: E501 + """OrganizationMembersBody - a model defined in Swagger""" # noqa: E501 + self._token = None + self.discriminator = None + if token is not None: + self.token = token + + @property + def token(self): + """Gets the token of this OrganizationMembersBody. # noqa: E501 + + + :return: The token of this OrganizationMembersBody. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationMembersBody. + + + :param token: The token of this OrganizationMembersBody. # noqa: E501 + :type: str + """ + + self._token = token + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationMembersBody, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationMembersBody): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py new file mode 100644 index 00000000..aa35221c --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationRemoveBody(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'email': 'str' + } + + attribute_map = { + 'email': 'email' + } + + def __init__(self, email=None): # noqa: E501 + """OrganizationRemoveBody - a model defined in Swagger""" # noqa: E501 + self._email = None + self.discriminator = None + if email is not None: + self.email = email + + @property + def email(self): + """Gets the email of this OrganizationRemoveBody. # noqa: E501 + + + :return: The email of this OrganizationRemoveBody. # noqa: E501 + :rtype: str + """ + return self._email + + @email.setter + def email(self, email): + """Sets the email of this OrganizationRemoveBody. + + + :param email: The email of this OrganizationRemoveBody. # noqa: E501 + :type: str + """ + + self._email = email + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationRemoveBody, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationRemoveBody): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/specs/zrok.yml b/specs/zrok.yml index 853d1059..531eef6c 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -381,6 +381,127 @@ paths: description: unauthorized 500: description: internal server error + + /organization: + post: + tags: + - admin + security: + - key: [] + operationId: createOrganization + parameters: + - name: body + in: body + schema: + properties: + description: + type: string + responses: + 201: + description: organization created + schema: + properties: + token: + type: string + 401: + description: unauthorized + 500: + description: internal server error + delete: + tags: + - admin + security: + - key: [] + operationId: deleteOrganization + parameters: + - name: body + in: body + schema: + properties: + token: + type: string + responses: + 200: + description: organization deleted + 401: + description: unauthorized + 500: + description: internal server error + + /organization/add: + post: + tags: + - admin + security: + - key: [] + operationId: addOrganizationMember + parameters: + - name: body + in: body + schema: + properties: + email: + type: string + responses: + 201: + description: member added + 401: + description: unauthorized + 500: + description: internal server error + + /organization/members: + post: + tags: + - admin + security: + - key: [] + operationId: listOrganizationMembers + parameters: + - name: body + in: body + schema: + properties: + token: + type: string + responses: + 200: + description: list organization members + schema: + properties: + members: + type: array + items: + properties: + email: + type: string + 401: + description: unauthorized + 500: + description: internal server error + + /organization/remove: + post: + tags: + - admin + security: + - key: [] + operationId: removeOrganizationMember + parameters: + - name: body + in: body + schema: + properties: + email: + type: string + responses: + 200: + description: member removed + 401: + description: unauthorized + 500: + description: internal server error + # # environment # diff --git a/ui/src/api/admin.js b/ui/src/api/admin.js index 67bf11ad..d1f882df 100644 --- a/ui/src/api/admin.js +++ b/ui/src/api/admin.js @@ -113,6 +113,81 @@ export function inviteTokenGenerate(options) { return gateway.request(inviteTokenGenerateOperation, parameters) } +/** + * @param {object} options Optional options + * @param {object} [options.body] + * @return {Promise} organization created + */ +export function createOrganization(options) { + if (!options) options = {} + const parameters = { + body: { + body: options.body + } + } + return gateway.request(createOrganizationOperation, parameters) +} + +/** + * @param {object} options Optional options + * @param {object} [options.body] + * @return {Promise} organization deleted + */ +export function deleteOrganization(options) { + if (!options) options = {} + const parameters = { + body: { + body: options.body + } + } + return gateway.request(deleteOrganizationOperation, parameters) +} + +/** + * @param {object} options Optional options + * @param {object} [options.body] + * @return {Promise} member added + */ +export function addOrganizationMember(options) { + if (!options) options = {} + const parameters = { + body: { + body: options.body + } + } + return gateway.request(addOrganizationMemberOperation, parameters) +} + +/** + * @param {object} options Optional options + * @param {object} [options.body] + * @return {Promise} list organization members + */ +export function listOrganizationMembers(options) { + if (!options) options = {} + const parameters = { + body: { + body: options.body + } + } + return gateway.request(listOrganizationMembersOperation, parameters) +} + +/** + * @param {object} options Optional options + * @param {object} [options.body] + * @return {Promise} member removed + */ +export function removeOrganizationMember(options) { + if (!options) options = {} + const parameters = { + body: { + body: options.body + } + } + return gateway.request(removeOrganizationMemberOperation, parameters) +} + const createAccountOperation = { path: '/account', contentTypes: ['application/zrok.v1+json'], @@ -199,3 +274,58 @@ const inviteTokenGenerateOperation = { } ] } + +const createOrganizationOperation = { + path: '/organization', + contentTypes: ['application/zrok.v1+json'], + method: 'post', + security: [ + { + id: 'key' + } + ] +} + +const deleteOrganizationOperation = { + path: '/organization', + contentTypes: ['application/zrok.v1+json'], + method: 'delete', + security: [ + { + id: 'key' + } + ] +} + +const addOrganizationMemberOperation = { + path: '/organization/add', + contentTypes: ['application/zrok.v1+json'], + method: 'post', + security: [ + { + id: 'key' + } + ] +} + +const listOrganizationMembersOperation = { + path: '/organization/members', + contentTypes: ['application/zrok.v1+json'], + method: 'post', + security: [ + { + id: 'key' + } + ] +} + +const removeOrganizationMemberOperation = { + path: '/organization/remove', + contentTypes: ['application/zrok.v1+json'], + method: 'post', + security: [ + { + id: 'key' + } + ] +} From c98aaa8e00709e15d338b06c632e0f5318d30bad Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 13:30:45 -0500 Subject: [PATCH 04/32] create/delete organization handlers (#537) --- controller/controller.go | 2 + controller/createOrganization.go | 53 ++++++++++++++++ controller/deleteOrganization.go | 42 +++++++++++++ controller/store/organization.go | 8 +++ .../admin/delete_organization_responses.go | 62 +++++++++++++++++++ rest_server_zrok/embedded_spec.go | 6 ++ .../admin/delete_organization_responses.go | 25 ++++++++ specs/zrok.yml | 2 + 8 files changed, 200 insertions(+) create mode 100644 controller/createOrganization.go create mode 100644 controller/deleteOrganization.go diff --git a/controller/controller.go b/controller/controller.go index 7b210a98..852dc08a 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -54,7 +54,9 @@ func Run(inCfg *config.Config) error { api.AdminCreateAccountHandler = newCreateAccountHandler() api.AdminCreateFrontendHandler = newCreateFrontendHandler() api.AdminCreateIdentityHandler = newCreateIdentityHandler() + api.AdminCreateOrganizationHandler = newCreateOrganizationHandler() api.AdminDeleteFrontendHandler = newDeleteFrontendHandler() + api.AdminDeleteOrganizationHandler = newDeleteOrganizationHandler() api.AdminGrantsHandler = newGrantsHandler() api.AdminInviteTokenGenerateHandler = newInviteTokenGenerateHandler() api.AdminListFrontendsHandler = newListFrontendsHandler() diff --git a/controller/createOrganization.go b/controller/createOrganization.go new file mode 100644 index 00000000..a3b60ce2 --- /dev/null +++ b/controller/createOrganization.go @@ -0,0 +1,53 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/controller/store" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type createOrganizationHandler struct{} + +func newCreateOrganizationHandler() *createOrganizationHandler { + return &createOrganizationHandler{} +} + +func (h *createOrganizationHandler) Handle(params admin.CreateOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Errorf("invalid admin principal") + return admin.NewCreateOrganizationUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewCreateOrganizationInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + orgToken, err := CreateToken() + if err != nil { + logrus.Errorf("error creating organization token: %v", err) + return admin.NewCreateOrganizationInternalServerError() + } + + org := &store.Organization{ + Token: orgToken, + Description: params.Body.Description, + } + if _, err := str.CreateOrganization(org, trx); err != nil { + logrus.Errorf("error creating organization: %v", err) + return admin.NewCreateOrganizationInternalServerError() + } + + if err := trx.Commit(); err != nil { + logrus.Errorf("error committing organization: %v", err) + return admin.NewCreateOrganizationInternalServerError() + } + + logrus.Infof("added organzation '%v' with description '%v'", org.Token, org.Description) + + return admin.NewCreateOrganizationCreated().WithPayload(&admin.CreateOrganizationCreatedBody{Token: org.Token}) +} diff --git a/controller/deleteOrganization.go b/controller/deleteOrganization.go new file mode 100644 index 00000000..deed01b6 --- /dev/null +++ b/controller/deleteOrganization.go @@ -0,0 +1,42 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type deleteOrganizationHandler struct{} + +func newDeleteOrganizationHandler() *deleteOrganizationHandler { + return &deleteOrganizationHandler{} +} + +func (h *deleteOrganizationHandler) Handle(params admin.DeleteOrganizationParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Errorf("invalid admin principal") + return admin.NewDeleteOrganizationUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewDeleteOrganizationInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + org, err := str.FindOrganizationByToken(params.Body.Token, trx) + if err != nil { + logrus.Errorf("error finding organization by token: %v", err) + return admin.NewDeleteOrganizationNotFound() + } + + err = str.DeleteOrganization(org.Id, trx) + if err != nil { + logrus.Errorf("error deleting organization: %v", err) + return admin.NewDeleteOrganizationInternalServerError() + } + + return admin.NewDeleteOrganizationOK() +} diff --git a/controller/store/organization.go b/controller/store/organization.go index 98dda7b0..e5dc0fbf 100644 --- a/controller/store/organization.go +++ b/controller/store/organization.go @@ -23,6 +23,14 @@ func (str *Store) CreateOrganization(org *Organization, trx *sqlx.Tx) (int, erro return id, nil } +func (str *Store) FindOrganizationByToken(token string, trx *sqlx.Tx) (*Organization, error) { + org := &Organization{} + if err := trx.QueryRowx("select * from organizations where token = $1", token).StructScan(org); err != nil { + return nil, errors.Wrap(err, "error selecting frontend by token") + } + return org, nil +} + func (str *Store) DeleteOrganization(id int, trx *sqlx.Tx) error { stmt, err := trx.Prepare("update organizations set updated_at = current_timestamp, deleted = true where id = $1") if err != nil { diff --git a/rest_client_zrok/admin/delete_organization_responses.go b/rest_client_zrok/admin/delete_organization_responses.go index 579aac8f..2eab36fd 100644 --- a/rest_client_zrok/admin/delete_organization_responses.go +++ b/rest_client_zrok/admin/delete_organization_responses.go @@ -34,6 +34,12 @@ func (o *DeleteOrganizationReader) ReadResponse(response runtime.ClientResponse, return nil, err } return nil, result + case 404: + result := NewDeleteOrganizationNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result case 500: result := NewDeleteOrganizationInternalServerError() if err := result.readResponse(response, consumer, o.formats); err != nil { @@ -157,6 +163,62 @@ func (o *DeleteOrganizationUnauthorized) readResponse(response runtime.ClientRes return nil } +// NewDeleteOrganizationNotFound creates a DeleteOrganizationNotFound with default headers values +func NewDeleteOrganizationNotFound() *DeleteOrganizationNotFound { + return &DeleteOrganizationNotFound{} +} + +/* +DeleteOrganizationNotFound describes a response with status code 404, with default header values. + +organization not found +*/ +type DeleteOrganizationNotFound struct { +} + +// IsSuccess returns true when this delete organization not found response has a 2xx status code +func (o *DeleteOrganizationNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this delete organization not found response has a 3xx status code +func (o *DeleteOrganizationNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this delete organization not found response has a 4xx status code +func (o *DeleteOrganizationNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this delete organization not found response has a 5xx status code +func (o *DeleteOrganizationNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this delete organization not found response a status code equal to that given +func (o *DeleteOrganizationNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the delete organization not found response +func (o *DeleteOrganizationNotFound) Code() int { + return 404 +} + +func (o *DeleteOrganizationNotFound) Error() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationNotFound ", 404) +} + +func (o *DeleteOrganizationNotFound) String() string { + return fmt.Sprintf("[DELETE /organization][%d] deleteOrganizationNotFound ", 404) +} + +func (o *DeleteOrganizationNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + // NewDeleteOrganizationInternalServerError creates a DeleteOrganizationInternalServerError with default headers values func NewDeleteOrganizationInternalServerError() *DeleteOrganizationInternalServerError { return &DeleteOrganizationInternalServerError{} diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 4ba5c434..38fe5bd6 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -904,6 +904,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "organization not found" + }, "500": { "description": "internal server error" } @@ -2958,6 +2961,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "organization not found" + }, "500": { "description": "internal server error" } diff --git a/rest_server_zrok/operations/admin/delete_organization_responses.go b/rest_server_zrok/operations/admin/delete_organization_responses.go index 87776872..4e8f3dcd 100644 --- a/rest_server_zrok/operations/admin/delete_organization_responses.go +++ b/rest_server_zrok/operations/admin/delete_organization_responses.go @@ -61,6 +61,31 @@ func (o *DeleteOrganizationUnauthorized) WriteResponse(rw http.ResponseWriter, p rw.WriteHeader(401) } +// DeleteOrganizationNotFoundCode is the HTTP code returned for type DeleteOrganizationNotFound +const DeleteOrganizationNotFoundCode int = 404 + +/* +DeleteOrganizationNotFound organization not found + +swagger:response deleteOrganizationNotFound +*/ +type DeleteOrganizationNotFound struct { +} + +// NewDeleteOrganizationNotFound creates DeleteOrganizationNotFound with default headers values +func NewDeleteOrganizationNotFound() *DeleteOrganizationNotFound { + + return &DeleteOrganizationNotFound{} +} + +// WriteResponse to the client +func (o *DeleteOrganizationNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + // DeleteOrganizationInternalServerErrorCode is the HTTP code returned for type DeleteOrganizationInternalServerError const DeleteOrganizationInternalServerErrorCode int = 500 diff --git a/specs/zrok.yml b/specs/zrok.yml index 531eef6c..ff16f13a 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -425,6 +425,8 @@ paths: description: organization deleted 401: description: unauthorized + 404: + description: organization not found 500: description: internal server error From 4473571b37dc7538e942d9364b4d0a297edea281 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 13:44:56 -0500 Subject: [PATCH 05/32] add/delete org plumbed through to CLI (#537) --- cmd/zrok/adminCreateOrganization.go | 52 +++++++++++++++++++++++++++++ cmd/zrok/adminDeleteOrganization.go | 50 +++++++++++++++++++++++++++ controller/deleteOrganization.go | 5 +++ controller/store/organization.go | 2 +- 4 files changed, 108 insertions(+), 1 deletion(-) create mode 100644 cmd/zrok/adminCreateOrganization.go create mode 100644 cmd/zrok/adminDeleteOrganization.go diff --git a/cmd/zrok/adminCreateOrganization.go b/cmd/zrok/adminCreateOrganization.go new file mode 100644 index 00000000..da7b5944 --- /dev/null +++ b/cmd/zrok/adminCreateOrganization.go @@ -0,0 +1,52 @@ +package main + +import ( + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/sirupsen/logrus" + "github.com/spf13/cobra" +) + +func init() { + adminCreateCmd.AddCommand(newAdminCreateOrganizationCommand().cmd) +} + +type adminCreateOrganizationCommand struct { + cmd *cobra.Command + description string +} + +func newAdminCreateOrganizationCommand() *adminCreateOrganizationCommand { + cmd := &cobra.Command{ + Use: "organization", + Aliases: []string{"org"}, + Short: "Create a new organization", + Args: cobra.NoArgs, + } + command := &adminCreateOrganizationCommand{cmd: cmd} + cmd.Flags().StringVarP(&command.description, "description", "d", "", "Organization description") + cmd.Run = command.run + return command +} + +func (cmd *adminCreateOrganizationCommand) run(_ *cobra.Command, _ []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewCreateOrganizationParams() + req.Body = admin.CreateOrganizationBody{Description: cmd.description} + + resp, err := zrok.Admin.CreateOrganization(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + logrus.Infof("created new organization with token '%v'", resp.Payload.Token) +} diff --git a/cmd/zrok/adminDeleteOrganization.go b/cmd/zrok/adminDeleteOrganization.go new file mode 100644 index 00000000..cb3ec6e2 --- /dev/null +++ b/cmd/zrok/adminDeleteOrganization.go @@ -0,0 +1,50 @@ +package main + +import ( + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/sirupsen/logrus" + "github.com/spf13/cobra" +) + +func init() { + adminDeleteCmd.AddCommand(newAdminDeleteOrganizationCommand().cmd) +} + +type adminDeleteOrganizationCommand struct { + cmd *cobra.Command +} + +func newAdminDeleteOrganizationCommand() *adminDeleteOrganizationCommand { + cmd := &cobra.Command{ + Use: "organization ", + Aliases: []string{"org"}, + Short: "Delete an organization", + Args: cobra.ExactArgs(1), + } + command := &adminDeleteOrganizationCommand{cmd: cmd} + cmd.Run = command.run + return command +} + +func (cmd *adminDeleteOrganizationCommand) run(_ *cobra.Command, args []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewDeleteOrganizationParams() + req.Body.Token = args[0] + + _, err = zrok.Admin.DeleteOrganization(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + logrus.Infof("deleted organization with token '%v'", args[0]) +} diff --git a/controller/deleteOrganization.go b/controller/deleteOrganization.go index deed01b6..70df1d5c 100644 --- a/controller/deleteOrganization.go +++ b/controller/deleteOrganization.go @@ -38,5 +38,10 @@ func (h *deleteOrganizationHandler) Handle(params admin.DeleteOrganizationParams return admin.NewDeleteOrganizationInternalServerError() } + if err := trx.Commit(); err != nil { + logrus.Errorf("error committing transaction: %v", err) + return admin.NewDeleteOrganizationInternalServerError() + } + return admin.NewDeleteOrganizationOK() } diff --git a/controller/store/organization.go b/controller/store/organization.go index e5dc0fbf..22dd710c 100644 --- a/controller/store/organization.go +++ b/controller/store/organization.go @@ -25,7 +25,7 @@ func (str *Store) CreateOrganization(org *Organization, trx *sqlx.Tx) (int, erro func (str *Store) FindOrganizationByToken(token string, trx *sqlx.Tx) (*Organization, error) { org := &Organization{} - if err := trx.QueryRowx("select * from organizations where token = $1", token).StructScan(org); err != nil { + if err := trx.QueryRowx("select * from organizations where token = $1 and not deleted", token).StructScan(org); err != nil { return nil, errors.Wrap(err, "error selecting frontend by token") } return org, nil From 6fb69c59d25920a0e3b685a375161ef3abd07e9e Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 14:21:49 -0500 Subject: [PATCH 06/32] list members of organization handler (#537) --- controller/controller.go | 1 + controller/listFrontends.go | 2 +- controller/listOrganizationMembers.go | 50 ++++++++ controller/store/organizationMember.go | 4 + rest_client_zrok/admin/admin_client.go | 2 +- .../list_organization_members_responses.go | 76 ++++++++++-- rest_server_zrok/embedded_spec.go | 10 +- .../admin/list_organization_members.go | 2 +- .../list_organization_members_responses.go | 25 ++++ .../list_organization_members_urlbuilder.go | 2 +- rest_server_zrok/operations/zrok_api.go | 2 +- sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 2 +- sdk/python/sdk/zrok/zrok_api/__init__.py | 2 +- sdk/python/sdk/zrok/zrok_api/api/admin_api.py | 6 +- .../sdk/zrok/zrok_api/models/__init__.py | 2 +- .../zrok_api/models/organization_list_body.py | 110 ++++++++++++++++++ specs/zrok.yml | 4 +- ui/src/api/admin.js | 2 +- 18 files changed, 282 insertions(+), 22 deletions(-) create mode 100644 controller/listOrganizationMembers.go create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organization_list_body.py diff --git a/controller/controller.go b/controller/controller.go index 852dc08a..584703db 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -60,6 +60,7 @@ func Run(inCfg *config.Config) error { api.AdminGrantsHandler = newGrantsHandler() api.AdminInviteTokenGenerateHandler = newInviteTokenGenerateHandler() api.AdminListFrontendsHandler = newListFrontendsHandler() + api.AdminListOrganizationMembersHandler = newListOrganizationMembersHandler() api.AdminUpdateFrontendHandler = newUpdateFrontendHandler() api.EnvironmentEnableHandler = newEnableHandler() api.EnvironmentDisableHandler = newDisableHandler() diff --git a/controller/listFrontends.go b/controller/listFrontends.go index 640b340d..00623ee8 100644 --- a/controller/listFrontends.go +++ b/controller/listFrontends.go @@ -15,7 +15,7 @@ func newListFrontendsHandler() *listFrontendsHandler { func (h *listFrontendsHandler) Handle(params admin.ListFrontendsParams, principal *rest_model_zrok.Principal) middleware.Responder { if !principal.Admin { - logrus.Errorf("invalid admin principal") + logrus.Error("invalid admin principal") return admin.NewListFrontendsUnauthorized() } diff --git a/controller/listOrganizationMembers.go b/controller/listOrganizationMembers.go new file mode 100644 index 00000000..54390ddb --- /dev/null +++ b/controller/listOrganizationMembers.go @@ -0,0 +1,50 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type listOrganizationMembersHandler struct{} + +func newListOrganizationMembersHandler() *listOrganizationMembersHandler { + return &listOrganizationMembersHandler{} +} + +func (h *listOrganizationMembersHandler) Handle(params admin.ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Error("invalid admin principal") + return admin.NewListOrganizationMembersUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewListOrganizationMembersInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + org, err := str.FindOrganizationByToken(params.Body.Token, trx) + if err != nil { + logrus.Errorf("error finding organization by token: %v", err) + return admin.NewListOrganizationMembersInternalServerError() + } + if org == nil { + logrus.Errorf("organization '%v' not found", params.Body.Token) + return admin.NewListOrganizationMembersNotFound() + } + + emails, err := str.FindAccountsForOrganization(org.Id, trx) + if err != nil { + logrus.Errorf("error finding accounts for organization: %v", err) + return admin.NewListOrganizationMembersInternalServerError() + } + + var members []*admin.ListOrganizationMembersOKBodyMembersItems0 + for _, email := range emails { + members = append(members, &admin.ListOrganizationMembersOKBodyMembersItems0{Email: email}) + } + return admin.NewListOrganizationMembersOK().WithPayload(&admin.ListOrganizationMembersOKBody{Members: members}) +} diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go index f61896ea..ec9f1108 100644 --- a/controller/store/organizationMember.go +++ b/controller/store/organizationMember.go @@ -17,6 +17,10 @@ func (str *Store) AddAccountToOrganization(acctId, orgId int, trx *sqlx.Tx) erro return nil } +func (str *Store) FindAccountsForOrganization(orgId int, trx *sqlx.Tx) ([]string, error) { + return nil, nil +} + func (str *Store) IsAccountInOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { stmt, err := trx.Prepare("select count(0) from organization_members where organization_id = $1 and account_id = $2") if err != nil { diff --git a/rest_client_zrok/admin/admin_client.go b/rest_client_zrok/admin/admin_client.go index 72944f41..0db767ca 100644 --- a/rest_client_zrok/admin/admin_client.go +++ b/rest_client_zrok/admin/admin_client.go @@ -460,7 +460,7 @@ func (a *Client) ListOrganizationMembers(params *ListOrganizationMembersParams, op := &runtime.ClientOperation{ ID: "listOrganizationMembers", Method: "POST", - PathPattern: "/organization/members", + PathPattern: "/organization/list", ProducesMediaTypes: []string{"application/zrok.v1+json"}, ConsumesMediaTypes: []string{"application/zrok.v1+json"}, Schemes: []string{"http"}, diff --git a/rest_client_zrok/admin/list_organization_members_responses.go b/rest_client_zrok/admin/list_organization_members_responses.go index 736b3d40..6a48998d 100644 --- a/rest_client_zrok/admin/list_organization_members_responses.go +++ b/rest_client_zrok/admin/list_organization_members_responses.go @@ -37,6 +37,12 @@ func (o *ListOrganizationMembersReader) ReadResponse(response runtime.ClientResp return nil, err } return nil, result + case 404: + result := NewListOrganizationMembersNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result case 500: result := NewListOrganizationMembersInternalServerError() if err := result.readResponse(response, consumer, o.formats); err != nil { @@ -44,7 +50,7 @@ func (o *ListOrganizationMembersReader) ReadResponse(response runtime.ClientResp } return nil, result default: - return nil, runtime.NewAPIError("[POST /organization/members] listOrganizationMembers", response, response.Code()) + return nil, runtime.NewAPIError("[POST /organization/list] listOrganizationMembers", response, response.Code()) } } @@ -93,11 +99,11 @@ func (o *ListOrganizationMembersOK) Code() int { } func (o *ListOrganizationMembersOK) Error() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersOK %+v", 200, o.Payload) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersOK %+v", 200, o.Payload) } func (o *ListOrganizationMembersOK) String() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersOK %+v", 200, o.Payload) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersOK %+v", 200, o.Payload) } func (o *ListOrganizationMembersOK) GetPayload() *ListOrganizationMembersOKBody { @@ -160,11 +166,11 @@ func (o *ListOrganizationMembersUnauthorized) Code() int { } func (o *ListOrganizationMembersUnauthorized) Error() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersUnauthorized ", 401) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersUnauthorized ", 401) } func (o *ListOrganizationMembersUnauthorized) String() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersUnauthorized ", 401) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersUnauthorized ", 401) } func (o *ListOrganizationMembersUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { @@ -172,6 +178,62 @@ func (o *ListOrganizationMembersUnauthorized) readResponse(response runtime.Clie return nil } +// NewListOrganizationMembersNotFound creates a ListOrganizationMembersNotFound with default headers values +func NewListOrganizationMembersNotFound() *ListOrganizationMembersNotFound { + return &ListOrganizationMembersNotFound{} +} + +/* +ListOrganizationMembersNotFound describes a response with status code 404, with default header values. + +not found +*/ +type ListOrganizationMembersNotFound struct { +} + +// IsSuccess returns true when this list organization members not found response has a 2xx status code +func (o *ListOrganizationMembersNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list organization members not found response has a 3xx status code +func (o *ListOrganizationMembersNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organization members not found response has a 4xx status code +func (o *ListOrganizationMembersNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this list organization members not found response has a 5xx status code +func (o *ListOrganizationMembersNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this list organization members not found response a status code equal to that given +func (o *ListOrganizationMembersNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the list organization members not found response +func (o *ListOrganizationMembersNotFound) Code() int { + return 404 +} + +func (o *ListOrganizationMembersNotFound) Error() string { + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersNotFound ", 404) +} + +func (o *ListOrganizationMembersNotFound) String() string { + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersNotFound ", 404) +} + +func (o *ListOrganizationMembersNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + // NewListOrganizationMembersInternalServerError creates a ListOrganizationMembersInternalServerError with default headers values func NewListOrganizationMembersInternalServerError() *ListOrganizationMembersInternalServerError { return &ListOrganizationMembersInternalServerError{} @@ -216,11 +278,11 @@ func (o *ListOrganizationMembersInternalServerError) Code() int { } func (o *ListOrganizationMembersInternalServerError) Error() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersInternalServerError ", 500) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersInternalServerError ", 500) } func (o *ListOrganizationMembersInternalServerError) String() string { - return fmt.Sprintf("[POST /organization/members][%d] listOrganizationMembersInternalServerError ", 500) + return fmt.Sprintf("[POST /organization/list][%d] listOrganizationMembersInternalServerError ", 500) } func (o *ListOrganizationMembersInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 38fe5bd6..86268d6b 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -950,7 +950,7 @@ func init() { } } }, - "/organization/members": { + "/organization/list": { "post": { "security": [ { @@ -995,6 +995,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } @@ -3007,7 +3010,7 @@ func init() { } } }, - "/organization/members": { + "/organization/list": { "post": { "security": [ { @@ -3048,6 +3051,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } diff --git a/rest_server_zrok/operations/admin/list_organization_members.go b/rest_server_zrok/operations/admin/list_organization_members.go index d5d0c5bd..d12d3cb8 100644 --- a/rest_server_zrok/operations/admin/list_organization_members.go +++ b/rest_server_zrok/operations/admin/list_organization_members.go @@ -37,7 +37,7 @@ func NewListOrganizationMembers(ctx *middleware.Context, handler ListOrganizatio } /* - ListOrganizationMembers swagger:route POST /organization/members admin listOrganizationMembers + ListOrganizationMembers swagger:route POST /organization/list admin listOrganizationMembers ListOrganizationMembers list organization members API */ diff --git a/rest_server_zrok/operations/admin/list_organization_members_responses.go b/rest_server_zrok/operations/admin/list_organization_members_responses.go index 615e5417..eb58015b 100644 --- a/rest_server_zrok/operations/admin/list_organization_members_responses.go +++ b/rest_server_zrok/operations/admin/list_organization_members_responses.go @@ -81,6 +81,31 @@ func (o *ListOrganizationMembersUnauthorized) WriteResponse(rw http.ResponseWrit rw.WriteHeader(401) } +// ListOrganizationMembersNotFoundCode is the HTTP code returned for type ListOrganizationMembersNotFound +const ListOrganizationMembersNotFoundCode int = 404 + +/* +ListOrganizationMembersNotFound not found + +swagger:response listOrganizationMembersNotFound +*/ +type ListOrganizationMembersNotFound struct { +} + +// NewListOrganizationMembersNotFound creates ListOrganizationMembersNotFound with default headers values +func NewListOrganizationMembersNotFound() *ListOrganizationMembersNotFound { + + return &ListOrganizationMembersNotFound{} +} + +// WriteResponse to the client +func (o *ListOrganizationMembersNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + // ListOrganizationMembersInternalServerErrorCode is the HTTP code returned for type ListOrganizationMembersInternalServerError const ListOrganizationMembersInternalServerErrorCode int = 500 diff --git a/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go b/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go index 62423a6a..c2a9006d 100644 --- a/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go +++ b/rest_server_zrok/operations/admin/list_organization_members_urlbuilder.go @@ -35,7 +35,7 @@ func (o *ListOrganizationMembersURL) SetBasePath(bp string) { func (o *ListOrganizationMembersURL) Build() (*url.URL, error) { var _result url.URL - var _path = "/organization/members" + var _path = "/organization/list" _basePath := o._basePath if _basePath == "" { diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index 0baf6e08..9ea40e10 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -678,7 +678,7 @@ func (o *ZrokAPI) initHandlerCache() { if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } - o.handlers["POST"]["/organization/members"] = admin.NewListOrganizationMembers(o.context, o.AdminListOrganizationMembersHandler) + o.handlers["POST"]["/organization/list"] = admin.NewListOrganizationMembers(o.context, o.AdminListOrganizationMembersHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index b0f0f752..394a94dc 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -724,7 +724,7 @@ export class AdminApi { * @param body */ public async listOrganizationMembers (body?: RegenerateToken200Response, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: ListOrganizationMembers200Response; }> { - const localVarPath = this.basePath + '/organization/members'; + const localVarPath = this.basePath + '/organization/list'; let localVarQueryParameters: any = {}; let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); const produces = ['application/zrok.v1+json']; diff --git a/sdk/python/sdk/zrok/zrok_api/__init__.py b/sdk/python/sdk/zrok/zrok_api/__init__.py index cab88172..1be1da7b 100644 --- a/sdk/python/sdk/zrok/zrok_api/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/__init__.py @@ -56,7 +56,7 @@ from zrok_api.models.metrics_sample import MetricsSample from zrok_api.models.organization_add_body import OrganizationAddBody from zrok_api.models.organization_body import OrganizationBody from zrok_api.models.organization_body1 import OrganizationBody1 -from zrok_api.models.organization_members_body import OrganizationMembersBody +from zrok_api.models.organization_list_body import OrganizationListBody from zrok_api.models.organization_remove_body import OrganizationRemoveBody from zrok_api.models.overview import Overview from zrok_api.models.password_requirements import PasswordRequirements diff --git a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py index 9007e022..b5ba9eb2 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py @@ -943,7 +943,7 @@ class AdminApi(object): >>> result = thread.get() :param async_req bool - :param OrganizationMembersBody body: + :param OrganizationListBody body: :return: InlineResponse2001 If the method is called asynchronously, returns the request thread. @@ -964,7 +964,7 @@ class AdminApi(object): >>> result = thread.get() :param async_req bool - :param OrganizationMembersBody body: + :param OrganizationListBody body: :return: InlineResponse2001 If the method is called asynchronously, returns the request thread. @@ -1012,7 +1012,7 @@ class AdminApi(object): auth_settings = ['key'] # noqa: E501 return self.api_client.call_api( - '/organization/members', 'POST', + '/organization/list', 'POST', path_params, query_params, header_params, diff --git a/sdk/python/sdk/zrok/zrok_api/models/__init__.py b/sdk/python/sdk/zrok/zrok_api/models/__init__.py index b987cf91..1b78fad6 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/models/__init__.py @@ -46,7 +46,7 @@ from zrok_api.models.metrics_sample import MetricsSample from zrok_api.models.organization_add_body import OrganizationAddBody from zrok_api.models.organization_body import OrganizationBody from zrok_api.models.organization_body1 import OrganizationBody1 -from zrok_api.models.organization_members_body import OrganizationMembersBody +from zrok_api.models.organization_list_body import OrganizationListBody from zrok_api.models.organization_remove_body import OrganizationRemoveBody from zrok_api.models.overview import Overview from zrok_api.models.password_requirements import PasswordRequirements diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_list_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_list_body.py new file mode 100644 index 00000000..4b783851 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_list_body.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationListBody(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str' + } + + attribute_map = { + 'token': 'token' + } + + def __init__(self, token=None): # noqa: E501 + """OrganizationListBody - a model defined in Swagger""" # noqa: E501 + self._token = None + self.discriminator = None + if token is not None: + self.token = token + + @property + def token(self): + """Gets the token of this OrganizationListBody. # noqa: E501 + + + :return: The token of this OrganizationListBody. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationListBody. + + + :param token: The token of this OrganizationListBody. # noqa: E501 + :type: str + """ + + self._token = token + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationListBody, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationListBody): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/specs/zrok.yml b/specs/zrok.yml index ff16f13a..fc20d9b7 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -452,7 +452,7 @@ paths: 500: description: internal server error - /organization/members: + /organization/list: post: tags: - admin @@ -479,6 +479,8 @@ paths: type: string 401: description: unauthorized + 404: + description: not found 500: description: internal server error diff --git a/ui/src/api/admin.js b/ui/src/api/admin.js index d1f882df..59ebbbac 100644 --- a/ui/src/api/admin.js +++ b/ui/src/api/admin.js @@ -309,7 +309,7 @@ const addOrganizationMemberOperation = { } const listOrganizationMembersOperation = { - path: '/organization/members', + path: '/organization/list', contentTypes: ['application/zrok.v1+json'], method: 'post', security: [ From 37e945d603941b09c9d92d9e3f7c13725e18c280 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 14:32:43 -0500 Subject: [PATCH 07/32] add organization member handler (#537) --- controller/addOrganizationMember.go | 47 ++++++++++++++ controller/controller.go | 1 + .../add_organization_member_responses.go | 65 +++++++++++++++++++ rest_server_zrok/embedded_spec.go | 12 ++++ .../admin/add_organization_member.go | 3 + .../add_organization_member_responses.go | 25 +++++++ .../sdk/src/zrok/api/.openapi-generator/FILES | 1 + sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 5 +- .../api/model/addOrganizationMemberRequest.ts | 37 +++++++++++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 3 + .../zrok_api/models/organization_add_body.py | 28 +++++++- specs/zrok.yml | 4 ++ 12 files changed, 228 insertions(+), 3 deletions(-) create mode 100644 controller/addOrganizationMember.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts diff --git a/controller/addOrganizationMember.go b/controller/addOrganizationMember.go new file mode 100644 index 00000000..c62c330b --- /dev/null +++ b/controller/addOrganizationMember.go @@ -0,0 +1,47 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type addOrganizationMemberHandler struct{} + +func newAddOrganizationMemberHandler() *addOrganizationMemberHandler { + return &addOrganizationMemberHandler{} +} + +func (h *addOrganizationMemberHandler) Handle(params admin.AddOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Error("invalid admin principal") + return admin.NewAddOrganizationMemberUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewAddOrganizationMemberInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + acct, err := str.FindAccountWithEmail(params.Body.Email, trx) + if err != nil { + logrus.Errorf("error finding account with email address '%v': %v", params.Body.Email, err) + return admin.NewAddOrganizationMemberNotFound() + } + + org, err := str.FindOrganizationByToken(params.Body.Token, trx) + if err != nil { + logrus.Errorf("error finding organization '%v': %v", params.Body.Token, err) + return admin.NewAddOrganizationMemberNotFound() + } + + if err := str.AddAccountToOrganization(acct.Id, org.Id, trx); err != nil { + logrus.Errorf("error adding account '%v' to organization '%v': %v", acct.Id, org.Id, err) + return admin.NewAddOrganizationMemberInternalServerError() + } + + return admin.NewAddOrganizationMemberCreated() +} diff --git a/controller/controller.go b/controller/controller.go index 584703db..6fe657c0 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -51,6 +51,7 @@ func Run(inCfg *config.Config) error { api.AccountResetPasswordHandler = newResetPasswordHandler(cfg) api.AccountResetPasswordRequestHandler = newResetPasswordRequestHandler() api.AccountVerifyHandler = newVerifyHandler() + api.AdminAddOrganizationMemberHandler = newAddOrganizationMemberHandler() api.AdminCreateAccountHandler = newCreateAccountHandler() api.AdminCreateFrontendHandler = newCreateFrontendHandler() api.AdminCreateIdentityHandler = newCreateIdentityHandler() diff --git a/rest_client_zrok/admin/add_organization_member_responses.go b/rest_client_zrok/admin/add_organization_member_responses.go index beca97f8..29c3f8be 100644 --- a/rest_client_zrok/admin/add_organization_member_responses.go +++ b/rest_client_zrok/admin/add_organization_member_responses.go @@ -34,6 +34,12 @@ func (o *AddOrganizationMemberReader) ReadResponse(response runtime.ClientRespon return nil, err } return nil, result + case 404: + result := NewAddOrganizationMemberNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result case 500: result := NewAddOrganizationMemberInternalServerError() if err := result.readResponse(response, consumer, o.formats); err != nil { @@ -157,6 +163,62 @@ func (o *AddOrganizationMemberUnauthorized) readResponse(response runtime.Client return nil } +// NewAddOrganizationMemberNotFound creates a AddOrganizationMemberNotFound with default headers values +func NewAddOrganizationMemberNotFound() *AddOrganizationMemberNotFound { + return &AddOrganizationMemberNotFound{} +} + +/* +AddOrganizationMemberNotFound describes a response with status code 404, with default header values. + +not found +*/ +type AddOrganizationMemberNotFound struct { +} + +// IsSuccess returns true when this add organization member not found response has a 2xx status code +func (o *AddOrganizationMemberNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this add organization member not found response has a 3xx status code +func (o *AddOrganizationMemberNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this add organization member not found response has a 4xx status code +func (o *AddOrganizationMemberNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this add organization member not found response has a 5xx status code +func (o *AddOrganizationMemberNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this add organization member not found response a status code equal to that given +func (o *AddOrganizationMemberNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the add organization member not found response +func (o *AddOrganizationMemberNotFound) Code() int { + return 404 +} + +func (o *AddOrganizationMemberNotFound) Error() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberNotFound ", 404) +} + +func (o *AddOrganizationMemberNotFound) String() string { + return fmt.Sprintf("[POST /organization/add][%d] addOrganizationMemberNotFound ", 404) +} + +func (o *AddOrganizationMemberNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + // NewAddOrganizationMemberInternalServerError creates a AddOrganizationMemberInternalServerError with default headers values func NewAddOrganizationMemberInternalServerError() *AddOrganizationMemberInternalServerError { return &AddOrganizationMemberInternalServerError{} @@ -221,6 +283,9 @@ type AddOrganizationMemberBody struct { // email Email string `json:"email,omitempty"` + + // token + Token string `json:"token,omitempty"` } // Validate validates this add organization member body diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 86268d6b..15a10b52 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -932,6 +932,9 @@ func init() { "properties": { "email": { "type": "string" + }, + "token": { + "type": "string" } } } @@ -944,6 +947,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } @@ -2992,6 +2998,9 @@ func init() { "properties": { "email": { "type": "string" + }, + "token": { + "type": "string" } } } @@ -3004,6 +3013,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } diff --git a/rest_server_zrok/operations/admin/add_organization_member.go b/rest_server_zrok/operations/admin/add_organization_member.go index 3182bd45..12a69aa2 100644 --- a/rest_server_zrok/operations/admin/add_organization_member.go +++ b/rest_server_zrok/operations/admin/add_organization_member.go @@ -80,6 +80,9 @@ type AddOrganizationMemberBody struct { // email Email string `json:"email,omitempty"` + + // token + Token string `json:"token,omitempty"` } // Validate validates this add organization member body diff --git a/rest_server_zrok/operations/admin/add_organization_member_responses.go b/rest_server_zrok/operations/admin/add_organization_member_responses.go index 334c62d0..6b7fea40 100644 --- a/rest_server_zrok/operations/admin/add_organization_member_responses.go +++ b/rest_server_zrok/operations/admin/add_organization_member_responses.go @@ -61,6 +61,31 @@ func (o *AddOrganizationMemberUnauthorized) WriteResponse(rw http.ResponseWriter rw.WriteHeader(401) } +// AddOrganizationMemberNotFoundCode is the HTTP code returned for type AddOrganizationMemberNotFound +const AddOrganizationMemberNotFoundCode int = 404 + +/* +AddOrganizationMemberNotFound not found + +swagger:response addOrganizationMemberNotFound +*/ +type AddOrganizationMemberNotFound struct { +} + +// NewAddOrganizationMemberNotFound creates AddOrganizationMemberNotFound with default headers values +func NewAddOrganizationMemberNotFound() *AddOrganizationMemberNotFound { + + return &AddOrganizationMemberNotFound{} +} + +// WriteResponse to the client +func (o *AddOrganizationMemberNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + // AddOrganizationMemberInternalServerErrorCode is the HTTP code returned for type AddOrganizationMemberInternalServerError const AddOrganizationMemberInternalServerErrorCode int = 500 diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index 55aacd91..b1dd39f5 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -8,6 +8,7 @@ api/metadataApi.ts api/shareApi.ts model/accessRequest.ts model/accessResponse.ts +model/addOrganizationMemberRequest.ts model/authUser.ts model/changePasswordRequest.ts model/configuration.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index 394a94dc..4b84996d 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -15,6 +15,7 @@ import localVarRequest from 'request'; import http from 'http'; /* tslint:disable:no-unused-locals */ +import { AddOrganizationMemberRequest } from '../model/addOrganizationMemberRequest'; import { CreateAccountRequest } from '../model/createAccountRequest'; import { CreateFrontendRequest } from '../model/createFrontendRequest'; import { CreateFrontendResponse } from '../model/createFrontendResponse'; @@ -105,7 +106,7 @@ export class AdminApi { * * @param body */ - public async addOrganizationMember (body?: GrantsRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + public async addOrganizationMember (body?: AddOrganizationMemberRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { const localVarPath = this.basePath + '/organization/add'; let localVarQueryParameters: any = {}; let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); @@ -122,7 +123,7 @@ export class AdminApi { uri: localVarPath, useQuerystring: this._useQuerystring, json: true, - body: ObjectSerializer.serialize(body, "GrantsRequest") + body: ObjectSerializer.serialize(body, "AddOrganizationMemberRequest") }; let authenticationPromise = Promise.resolve(); diff --git a/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts b/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts new file mode 100644 index 00000000..a2a677fa --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts @@ -0,0 +1,37 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class AddOrganizationMemberRequest { + 'token'?: string; + 'email'?: string; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "token", + "baseName": "token", + "type": "string" + }, + { + "name": "email", + "baseName": "email", + "type": "string" + } ]; + + static getAttributeTypeMap() { + return AddOrganizationMemberRequest.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index 62d0b052..7aa8fb8a 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -2,6 +2,7 @@ import localVarRequest from 'request'; export * from './accessRequest'; export * from './accessResponse'; +export * from './addOrganizationMemberRequest'; export * from './authUser'; export * from './changePasswordRequest'; export * from './configuration'; @@ -60,6 +61,7 @@ export type RequestFile = string | Buffer | fs.ReadStream | RequestDetailedFile; import { AccessRequest } from './accessRequest'; import { AccessResponse } from './accessResponse'; +import { AddOrganizationMemberRequest } from './addOrganizationMemberRequest'; import { AuthUser } from './authUser'; import { ChangePasswordRequest } from './changePasswordRequest'; import { Configuration } from './configuration'; @@ -126,6 +128,7 @@ let enumsMap: {[index: string]: any} = { let typeMap: {[index: string]: any} = { "AccessRequest": AccessRequest, "AccessResponse": AccessResponse, + "AddOrganizationMemberRequest": AddOrganizationMemberRequest, "AuthUser": AuthUser, "ChangePasswordRequest": ChangePasswordRequest, "Configuration": Configuration, diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py index 025f2e73..31e66d04 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py @@ -28,20 +28,46 @@ class OrganizationAddBody(object): and the value is json key in definition. """ swagger_types = { + 'token': 'str', 'email': 'str' } attribute_map = { + 'token': 'token', 'email': 'email' } - def __init__(self, email=None): # noqa: E501 + def __init__(self, token=None, email=None): # noqa: E501 """OrganizationAddBody - a model defined in Swagger""" # noqa: E501 + self._token = None self._email = None self.discriminator = None + if token is not None: + self.token = token if email is not None: self.email = email + @property + def token(self): + """Gets the token of this OrganizationAddBody. # noqa: E501 + + + :return: The token of this OrganizationAddBody. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationAddBody. + + + :param token: The token of this OrganizationAddBody. # noqa: E501 + :type: str + """ + + self._token = token + @property def email(self): """Gets the email of this OrganizationAddBody. # noqa: E501 diff --git a/specs/zrok.yml b/specs/zrok.yml index fc20d9b7..efb12a09 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -442,6 +442,8 @@ paths: in: body schema: properties: + token: + type: string email: type: string responses: @@ -449,6 +451,8 @@ paths: description: member added 401: description: unauthorized + 404: + description: not found 500: description: internal server error From 0e30407bbd3f5990118dc484a5fbf9630d673b66 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 14:38:30 -0500 Subject: [PATCH 08/32] remove organization member handler (#537) --- controller/addOrganizationMember.go | 7 +- controller/controller.go | 1 + controller/removeOrganizationMember.go | 52 +++++++++++++++ .../remove_organization_member_responses.go | 65 +++++++++++++++++++ rest_server_zrok/embedded_spec.go | 12 ++++ .../admin/remove_organization_member.go | 3 + .../remove_organization_member_responses.go | 25 +++++++ sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 4 +- .../zrok_api/models/inline_response2001.py | 6 +- .../models/organization_remove_body.py | 28 +++++++- specs/zrok.yml | 4 ++ 11 files changed, 200 insertions(+), 7 deletions(-) create mode 100644 controller/removeOrganizationMember.go diff --git a/controller/addOrganizationMember.go b/controller/addOrganizationMember.go index c62c330b..417c6117 100644 --- a/controller/addOrganizationMember.go +++ b/controller/addOrganizationMember.go @@ -39,7 +39,12 @@ func (h *addOrganizationMemberHandler) Handle(params admin.AddOrganizationMember } if err := str.AddAccountToOrganization(acct.Id, org.Id, trx); err != nil { - logrus.Errorf("error adding account '%v' to organization '%v': %v", acct.Id, org.Id, err) + logrus.Errorf("error adding account '%v' to organization '%v': %v", acct.Email, org.Token, err) + return admin.NewAddOrganizationMemberInternalServerError() + } + + if err := trx.Commit(); err != nil { + logrus.Errorf("error committing transaction: %v", err) return admin.NewAddOrganizationMemberInternalServerError() } diff --git a/controller/controller.go b/controller/controller.go index 6fe657c0..e942fb9d 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -62,6 +62,7 @@ func Run(inCfg *config.Config) error { api.AdminInviteTokenGenerateHandler = newInviteTokenGenerateHandler() api.AdminListFrontendsHandler = newListFrontendsHandler() api.AdminListOrganizationMembersHandler = newListOrganizationMembersHandler() + api.AdminRemoveOrganizationMemberHandler = newRemoveOrganizationMemberHandler() api.AdminUpdateFrontendHandler = newUpdateFrontendHandler() api.EnvironmentEnableHandler = newEnableHandler() api.EnvironmentDisableHandler = newDisableHandler() diff --git a/controller/removeOrganizationMember.go b/controller/removeOrganizationMember.go new file mode 100644 index 00000000..486854bb --- /dev/null +++ b/controller/removeOrganizationMember.go @@ -0,0 +1,52 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type removeOrganizationMemberHandler struct{} + +func newRemoveOrganizationMemberHandler() *removeOrganizationMemberHandler { + return &removeOrganizationMemberHandler{} +} + +func (h *removeOrganizationMemberHandler) Handle(params admin.RemoveOrganizationMemberParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Error("invalid admin principal") + return admin.NewRemoveOrganizationMemberUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewRemoveOrganizationMemberInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + acct, err := str.FindAccountWithEmail(params.Body.Email, trx) + if err != nil { + logrus.Errorf("error finding account with email address '%v': %v", params.Body.Email, err) + return admin.NewAddOrganizationMemberNotFound() + } + + org, err := str.FindOrganizationByToken(params.Body.Token, trx) + if err != nil { + logrus.Errorf("error finding organization '%v': %v", params.Body.Token, err) + return admin.NewAddOrganizationMemberNotFound() + } + + if err := str.RemoveAccountFromOrganization(acct.Id, org.Id, trx); err != nil { + logrus.Errorf("error removing account '%v' from organization '%v': %v", acct.Email, org.Token, err) + return admin.NewRemoveOrganizationMemberInternalServerError() + } + + if err := trx.Commit(); err != nil { + logrus.Errorf("error committing transaction: %v", err) + return admin.NewRemoveOrganizationMemberInternalServerError() + } + + return admin.NewRemoveOrganizationMemberOK() +} diff --git a/rest_client_zrok/admin/remove_organization_member_responses.go b/rest_client_zrok/admin/remove_organization_member_responses.go index ec471b2b..1e66a9db 100644 --- a/rest_client_zrok/admin/remove_organization_member_responses.go +++ b/rest_client_zrok/admin/remove_organization_member_responses.go @@ -34,6 +34,12 @@ func (o *RemoveOrganizationMemberReader) ReadResponse(response runtime.ClientRes return nil, err } return nil, result + case 404: + result := NewRemoveOrganizationMemberNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result case 500: result := NewRemoveOrganizationMemberInternalServerError() if err := result.readResponse(response, consumer, o.formats); err != nil { @@ -157,6 +163,62 @@ func (o *RemoveOrganizationMemberUnauthorized) readResponse(response runtime.Cli return nil } +// NewRemoveOrganizationMemberNotFound creates a RemoveOrganizationMemberNotFound with default headers values +func NewRemoveOrganizationMemberNotFound() *RemoveOrganizationMemberNotFound { + return &RemoveOrganizationMemberNotFound{} +} + +/* +RemoveOrganizationMemberNotFound describes a response with status code 404, with default header values. + +not found +*/ +type RemoveOrganizationMemberNotFound struct { +} + +// IsSuccess returns true when this remove organization member not found response has a 2xx status code +func (o *RemoveOrganizationMemberNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this remove organization member not found response has a 3xx status code +func (o *RemoveOrganizationMemberNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this remove organization member not found response has a 4xx status code +func (o *RemoveOrganizationMemberNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this remove organization member not found response has a 5xx status code +func (o *RemoveOrganizationMemberNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this remove organization member not found response a status code equal to that given +func (o *RemoveOrganizationMemberNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the remove organization member not found response +func (o *RemoveOrganizationMemberNotFound) Code() int { + return 404 +} + +func (o *RemoveOrganizationMemberNotFound) Error() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberNotFound ", 404) +} + +func (o *RemoveOrganizationMemberNotFound) String() string { + return fmt.Sprintf("[POST /organization/remove][%d] removeOrganizationMemberNotFound ", 404) +} + +func (o *RemoveOrganizationMemberNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + // NewRemoveOrganizationMemberInternalServerError creates a RemoveOrganizationMemberInternalServerError with default headers values func NewRemoveOrganizationMemberInternalServerError() *RemoveOrganizationMemberInternalServerError { return &RemoveOrganizationMemberInternalServerError{} @@ -221,6 +283,9 @@ type RemoveOrganizationMemberBody struct { // email Email string `json:"email,omitempty"` + + // token + Token string `json:"token,omitempty"` } // Validate validates this remove organization member body diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 15a10b52..4e516895 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -1029,6 +1029,9 @@ func init() { "properties": { "email": { "type": "string" + }, + "token": { + "type": "string" } } } @@ -1041,6 +1044,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } @@ -3091,6 +3097,9 @@ func init() { "properties": { "email": { "type": "string" + }, + "token": { + "type": "string" } } } @@ -3103,6 +3112,9 @@ func init() { "401": { "description": "unauthorized" }, + "404": { + "description": "not found" + }, "500": { "description": "internal server error" } diff --git a/rest_server_zrok/operations/admin/remove_organization_member.go b/rest_server_zrok/operations/admin/remove_organization_member.go index 087d8f74..7594ba16 100644 --- a/rest_server_zrok/operations/admin/remove_organization_member.go +++ b/rest_server_zrok/operations/admin/remove_organization_member.go @@ -80,6 +80,9 @@ type RemoveOrganizationMemberBody struct { // email Email string `json:"email,omitempty"` + + // token + Token string `json:"token,omitempty"` } // Validate validates this remove organization member body diff --git a/rest_server_zrok/operations/admin/remove_organization_member_responses.go b/rest_server_zrok/operations/admin/remove_organization_member_responses.go index 4164a95e..6ffaab14 100644 --- a/rest_server_zrok/operations/admin/remove_organization_member_responses.go +++ b/rest_server_zrok/operations/admin/remove_organization_member_responses.go @@ -61,6 +61,31 @@ func (o *RemoveOrganizationMemberUnauthorized) WriteResponse(rw http.ResponseWri rw.WriteHeader(401) } +// RemoveOrganizationMemberNotFoundCode is the HTTP code returned for type RemoveOrganizationMemberNotFound +const RemoveOrganizationMemberNotFoundCode int = 404 + +/* +RemoveOrganizationMemberNotFound not found + +swagger:response removeOrganizationMemberNotFound +*/ +type RemoveOrganizationMemberNotFound struct { +} + +// NewRemoveOrganizationMemberNotFound creates RemoveOrganizationMemberNotFound with default headers values +func NewRemoveOrganizationMemberNotFound() *RemoveOrganizationMemberNotFound { + + return &RemoveOrganizationMemberNotFound{} +} + +// WriteResponse to the client +func (o *RemoveOrganizationMemberNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + // RemoveOrganizationMemberInternalServerErrorCode is the HTTP code returned for type RemoveOrganizationMemberInternalServerError const RemoveOrganizationMemberInternalServerErrorCode int = 500 diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index 4b84996d..289442b0 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -790,7 +790,7 @@ export class AdminApi { * * @param body */ - public async removeOrganizationMember (body?: GrantsRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + public async removeOrganizationMember (body?: AddOrganizationMemberRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { const localVarPath = this.basePath + '/organization/remove'; let localVarQueryParameters: any = {}; let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); @@ -807,7 +807,7 @@ export class AdminApi { uri: localVarPath, useQuerystring: this._useQuerystring, json: true, - body: ObjectSerializer.serialize(body, "GrantsRequest") + body: ObjectSerializer.serialize(body, "AddOrganizationMemberRequest") }; let authenticationPromise = Promise.resolve(); diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py index 95f369b4..1b32b09e 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py @@ -28,7 +28,7 @@ class InlineResponse2001(object): and the value is json key in definition. """ swagger_types = { - 'members': 'list[OrganizationRemoveBody]' + 'members': 'list[GrantsBody]' } attribute_map = { @@ -48,7 +48,7 @@ class InlineResponse2001(object): :return: The members of this InlineResponse2001. # noqa: E501 - :rtype: list[OrganizationRemoveBody] + :rtype: list[GrantsBody] """ return self._members @@ -58,7 +58,7 @@ class InlineResponse2001(object): :param members: The members of this InlineResponse2001. # noqa: E501 - :type: list[OrganizationRemoveBody] + :type: list[GrantsBody] """ self._members = members diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py index aa35221c..4600d47f 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_remove_body.py @@ -28,20 +28,46 @@ class OrganizationRemoveBody(object): and the value is json key in definition. """ swagger_types = { + 'token': 'str', 'email': 'str' } attribute_map = { + 'token': 'token', 'email': 'email' } - def __init__(self, email=None): # noqa: E501 + def __init__(self, token=None, email=None): # noqa: E501 """OrganizationRemoveBody - a model defined in Swagger""" # noqa: E501 + self._token = None self._email = None self.discriminator = None + if token is not None: + self.token = token if email is not None: self.email = email + @property + def token(self): + """Gets the token of this OrganizationRemoveBody. # noqa: E501 + + + :return: The token of this OrganizationRemoveBody. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationRemoveBody. + + + :param token: The token of this OrganizationRemoveBody. # noqa: E501 + :type: str + """ + + self._token = token + @property def email(self): """Gets the email of this OrganizationRemoveBody. # noqa: E501 diff --git a/specs/zrok.yml b/specs/zrok.yml index efb12a09..cc15cd72 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -500,6 +500,8 @@ paths: in: body schema: properties: + token: + type: string email: type: string responses: @@ -507,6 +509,8 @@ paths: description: member removed 401: description: unauthorized + 404: + description: not found 500: description: internal server error From 84c4611d2df61a6e8d2c0335752960781b805139 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 14:53:46 -0500 Subject: [PATCH 09/32] plumbed add member to org in cli (#537) --- cmd/zrok/adminCreateOrgMember.go | 54 +++++++++++++++++++ controller/addOrganizationMember.go | 2 +- controller/store/organizationMember.go | 6 +-- .../add_organization_member_responses.go | 3 ++ rest_server_zrok/embedded_spec.go | 6 +++ .../admin/add_organization_member.go | 3 ++ .../sdk/src/zrok/api/.openapi-generator/FILES | 1 + sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 5 +- .../api/model/addOrganizationMemberRequest.ts | 6 +++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 3 ++ .../model/removeOrganizationMemberRequest.ts | 37 +++++++++++++ .../zrok_api/models/organization_add_body.py | 32 +++++++++-- specs/zrok.yml | 2 + 13 files changed, 151 insertions(+), 9 deletions(-) create mode 100644 cmd/zrok/adminCreateOrgMember.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequest.ts diff --git a/cmd/zrok/adminCreateOrgMember.go b/cmd/zrok/adminCreateOrgMember.go new file mode 100644 index 00000000..fc15e3a1 --- /dev/null +++ b/cmd/zrok/adminCreateOrgMember.go @@ -0,0 +1,54 @@ +package main + +import ( + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/sirupsen/logrus" + "github.com/spf13/cobra" +) + +func init() { + adminCreateCmd.AddCommand(newAdminCreateOrgMemberCommand().cmd) +} + +type adminCreateOrgMemberCommand struct { + cmd *cobra.Command + admin bool +} + +func newAdminCreateOrgMemberCommand() *adminCreateOrgMemberCommand { + cmd := &cobra.Command{ + Use: "org-member ", + Aliases: []string{"member"}, + Short: "Add an account to an organization", + Args: cobra.ExactArgs(2), + } + command := &adminCreateOrgMemberCommand{cmd: cmd} + cmd.Flags().BoolVar(&command.admin, "admin", false, "Make the new account an admin of the organization") + cmd.Run = command.run + return command +} + +func (cmd *adminCreateOrgMemberCommand) run(_ *cobra.Command, args []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewAddOrganizationMemberParams() + req.Body.Email = args[0] + req.Body.Token = args[1] + req.Body.Admin = cmd.admin + + _, err = zrok.Admin.AddOrganizationMember(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + logrus.Infof("added '%v' to organization '%v", args[0], args[1]) +} diff --git a/controller/addOrganizationMember.go b/controller/addOrganizationMember.go index 417c6117..b9c7e1db 100644 --- a/controller/addOrganizationMember.go +++ b/controller/addOrganizationMember.go @@ -38,7 +38,7 @@ func (h *addOrganizationMemberHandler) Handle(params admin.AddOrganizationMember return admin.NewAddOrganizationMemberNotFound() } - if err := str.AddAccountToOrganization(acct.Id, org.Id, trx); err != nil { + if err := str.AddAccountToOrganization(acct.Id, org.Id, params.Body.Admin, trx); err != nil { logrus.Errorf("error adding account '%v' to organization '%v': %v", acct.Email, org.Token, err) return admin.NewAddOrganizationMemberInternalServerError() } diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go index ec9f1108..eba3e96f 100644 --- a/controller/store/organizationMember.go +++ b/controller/store/organizationMember.go @@ -5,12 +5,12 @@ import ( "github.com/pkg/errors" ) -func (str *Store) AddAccountToOrganization(acctId, orgId int, trx *sqlx.Tx) error { - stmt, err := trx.Prepare("insert into organization_members (organization_id, account_id) values ($1, $2)") +func (str *Store) AddAccountToOrganization(acctId, orgId int, admin bool, trx *sqlx.Tx) error { + stmt, err := trx.Prepare("insert into organization_members (account_id, organization_id, admin) values ($1, $2, $3)") if err != nil { return errors.Wrap(err, "error preparing organization_members insert statement") } - _, err = stmt.Exec(acctId, orgId) + _, err = stmt.Exec(acctId, orgId, admin) if err != nil { return errors.Wrap(err, "error executing organization_members insert statement") } diff --git a/rest_client_zrok/admin/add_organization_member_responses.go b/rest_client_zrok/admin/add_organization_member_responses.go index 29c3f8be..60866458 100644 --- a/rest_client_zrok/admin/add_organization_member_responses.go +++ b/rest_client_zrok/admin/add_organization_member_responses.go @@ -281,6 +281,9 @@ swagger:model AddOrganizationMemberBody */ type AddOrganizationMemberBody struct { + // admin + Admin bool `json:"admin,omitempty"` + // email Email string `json:"email,omitempty"` diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 4e516895..02875bdf 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -930,6 +930,9 @@ func init() { "in": "body", "schema": { "properties": { + "admin": { + "type": "boolean" + }, "email": { "type": "string" }, @@ -3002,6 +3005,9 @@ func init() { "in": "body", "schema": { "properties": { + "admin": { + "type": "boolean" + }, "email": { "type": "string" }, diff --git a/rest_server_zrok/operations/admin/add_organization_member.go b/rest_server_zrok/operations/admin/add_organization_member.go index 12a69aa2..ce8f8db5 100644 --- a/rest_server_zrok/operations/admin/add_organization_member.go +++ b/rest_server_zrok/operations/admin/add_organization_member.go @@ -78,6 +78,9 @@ func (o *AddOrganizationMember) ServeHTTP(rw http.ResponseWriter, r *http.Reques // swagger:model AddOrganizationMemberBody type AddOrganizationMemberBody struct { + // admin + Admin bool `json:"admin,omitempty"` + // email Email string `json:"email,omitempty"` diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index b1dd39f5..702edf4c 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -41,6 +41,7 @@ model/regenerateToken200Response.ts model/regenerateTokenRequest.ts model/registerRequest.ts model/registerResponse.ts +model/removeOrganizationMemberRequest.ts model/resetPasswordRequest.ts model/share.ts model/shareRequest.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index 289442b0..084b3d2b 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -28,6 +28,7 @@ import { InviteTokenGenerateRequest } from '../model/inviteTokenGenerateRequest' import { ListOrganizationMembers200Response } from '../model/listOrganizationMembers200Response'; import { PublicFrontend } from '../model/publicFrontend'; import { RegenerateToken200Response } from '../model/regenerateToken200Response'; +import { RemoveOrganizationMemberRequest } from '../model/removeOrganizationMemberRequest'; import { UpdateFrontendRequest } from '../model/updateFrontendRequest'; import { ObjectSerializer, Authentication, VoidAuth, Interceptor } from '../model/models'; @@ -790,7 +791,7 @@ export class AdminApi { * * @param body */ - public async removeOrganizationMember (body?: AddOrganizationMemberRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { + public async removeOrganizationMember (body?: RemoveOrganizationMemberRequest, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body?: any; }> { const localVarPath = this.basePath + '/organization/remove'; let localVarQueryParameters: any = {}; let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); @@ -807,7 +808,7 @@ export class AdminApi { uri: localVarPath, useQuerystring: this._useQuerystring, json: true, - body: ObjectSerializer.serialize(body, "AddOrganizationMemberRequest") + body: ObjectSerializer.serialize(body, "RemoveOrganizationMemberRequest") }; let authenticationPromise = Promise.resolve(); diff --git a/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts b/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts index a2a677fa..9b918462 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/addOrganizationMemberRequest.ts @@ -15,6 +15,7 @@ import { RequestFile } from './models'; export class AddOrganizationMemberRequest { 'token'?: string; 'email'?: string; + 'admin'?: boolean; static discriminator: string | undefined = undefined; @@ -28,6 +29,11 @@ export class AddOrganizationMemberRequest { "name": "email", "baseName": "email", "type": "string" + }, + { + "name": "admin", + "baseName": "admin", + "type": "boolean" } ]; static getAttributeTypeMap() { diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index 7aa8fb8a..77765e42 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -34,6 +34,7 @@ export * from './regenerateToken200Response'; export * from './regenerateTokenRequest'; export * from './registerRequest'; export * from './registerResponse'; +export * from './removeOrganizationMemberRequest'; export * from './resetPasswordRequest'; export * from './share'; export * from './shareRequest'; @@ -93,6 +94,7 @@ import { RegenerateToken200Response } from './regenerateToken200Response'; import { RegenerateTokenRequest } from './regenerateTokenRequest'; import { RegisterRequest } from './registerRequest'; import { RegisterResponse } from './registerResponse'; +import { RemoveOrganizationMemberRequest } from './removeOrganizationMemberRequest'; import { ResetPasswordRequest } from './resetPasswordRequest'; import { Share } from './share'; import { ShareRequest } from './shareRequest'; @@ -160,6 +162,7 @@ let typeMap: {[index: string]: any} = { "RegenerateTokenRequest": RegenerateTokenRequest, "RegisterRequest": RegisterRequest, "RegisterResponse": RegisterResponse, + "RemoveOrganizationMemberRequest": RemoveOrganizationMemberRequest, "ResetPasswordRequest": ResetPasswordRequest, "Share": Share, "ShareRequest": ShareRequest, diff --git a/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequest.ts b/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequest.ts new file mode 100644 index 00000000..8caf373b --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequest.ts @@ -0,0 +1,37 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class RemoveOrganizationMemberRequest { + 'token'?: string; + 'email'?: string; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "token", + "baseName": "token", + "type": "string" + }, + { + "name": "email", + "baseName": "email", + "type": "string" + } ]; + + static getAttributeTypeMap() { + return RemoveOrganizationMemberRequest.attributeTypeMap; + } +} + diff --git a/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py index 31e66d04..918758ab 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py +++ b/sdk/python/sdk/zrok/zrok_api/models/organization_add_body.py @@ -29,23 +29,28 @@ class OrganizationAddBody(object): """ swagger_types = { 'token': 'str', - 'email': 'str' + 'email': 'str', + 'admin': 'bool' } attribute_map = { 'token': 'token', - 'email': 'email' + 'email': 'email', + 'admin': 'admin' } - def __init__(self, token=None, email=None): # noqa: E501 + def __init__(self, token=None, email=None, admin=None): # noqa: E501 """OrganizationAddBody - a model defined in Swagger""" # noqa: E501 self._token = None self._email = None + self._admin = None self.discriminator = None if token is not None: self.token = token if email is not None: self.email = email + if admin is not None: + self.admin = admin @property def token(self): @@ -89,6 +94,27 @@ class OrganizationAddBody(object): self._email = email + @property + def admin(self): + """Gets the admin of this OrganizationAddBody. # noqa: E501 + + + :return: The admin of this OrganizationAddBody. # noqa: E501 + :rtype: bool + """ + return self._admin + + @admin.setter + def admin(self, admin): + """Sets the admin of this OrganizationAddBody. + + + :param admin: The admin of this OrganizationAddBody. # noqa: E501 + :type: bool + """ + + self._admin = admin + def to_dict(self): """Returns the model properties as a dict""" result = {} diff --git a/specs/zrok.yml b/specs/zrok.yml index cc15cd72..2c3eace0 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -446,6 +446,8 @@ paths: type: string email: type: string + admin: + type: boolean responses: 201: description: member added From 52333ddb69ab8ebdd83d5d797f55a22f9dfa79a1 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 15:04:43 -0500 Subject: [PATCH 10/32] remove members from organizations (#537) --- cmd/zrok/adminDeleteOrgMember.go | 51 ++++++++++++++++++++++++++ controller/removeOrganizationMember.go | 2 + controller/store/organizationMember.go | 2 +- 3 files changed, 54 insertions(+), 1 deletion(-) create mode 100644 cmd/zrok/adminDeleteOrgMember.go diff --git a/cmd/zrok/adminDeleteOrgMember.go b/cmd/zrok/adminDeleteOrgMember.go new file mode 100644 index 00000000..81c38fe2 --- /dev/null +++ b/cmd/zrok/adminDeleteOrgMember.go @@ -0,0 +1,51 @@ +package main + +import ( + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/sirupsen/logrus" + "github.com/spf13/cobra" +) + +func init() { + adminDeleteCmd.AddCommand(newAdminDeleteOrgMemberCommand().cmd) +} + +type adminDeleteOrgMemberCommand struct { + cmd *cobra.Command +} + +func newAdminDeleteOrgMemberCommand() *adminDeleteOrgMemberCommand { + cmd := &cobra.Command{ + Use: "org-member ", + Aliases: []string{"member"}, + Short: "Remove an account from an organization", + Args: cobra.ExactArgs(2), + } + command := &adminDeleteOrgMemberCommand{cmd: cmd} + cmd.Run = command.run + return command +} + +func (cmd *adminDeleteOrgMemberCommand) run(_ *cobra.Command, args []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewRemoveOrganizationMemberParams() + req.Body.Email = args[0] + req.Body.Token = args[1] + + _, err = zrok.Admin.RemoveOrganizationMember(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + logrus.Infof("removed '%v' from organization '%v", args[0], args[1]) +} diff --git a/controller/removeOrganizationMember.go b/controller/removeOrganizationMember.go index 486854bb..63cb2da2 100644 --- a/controller/removeOrganizationMember.go +++ b/controller/removeOrganizationMember.go @@ -43,6 +43,8 @@ func (h *removeOrganizationMemberHandler) Handle(params admin.RemoveOrganization return admin.NewRemoveOrganizationMemberInternalServerError() } + logrus.Infof("removed '%v' from organization '%v'", acct.Email, org.Token) + if err := trx.Commit(); err != nil { logrus.Errorf("error committing transaction: %v", err) return admin.NewRemoveOrganizationMemberInternalServerError() diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go index eba3e96f..7d3c5585 100644 --- a/controller/store/organizationMember.go +++ b/controller/store/organizationMember.go @@ -46,7 +46,7 @@ func (str *Store) IsAccountAdminOfOrganization(acctId, orgId int, trx *sqlx.Tx) } func (str *Store) RemoveAccountFromOrganization(acctId, orgId int, trx *sqlx.Tx) error { - stmt, err := trx.Prepare("delete from organization_members where organization_id = $1 and account_id = $2") + stmt, err := trx.Prepare("delete from organization_members where account_id = $1 and organization_id = $2") if err != nil { return errors.Wrap(err, "error preparing organization_members delete statement") } From 917a4d3f22adc10379e91e005f963a93818a56c7 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 16:42:30 -0500 Subject: [PATCH 11/32] list members of organization (#537) --- cmd/zrok/adminListOrgMembers.go | 61 ++++++++ controller/listOrganizationMembers.go | 8 +- controller/store/organizationMember.go | 21 ++- .../list_organization_members_responses.go | 3 + rest_server_zrok/embedded_spec.go | 6 + .../admin/list_organization_members.go | 3 + .../sdk/src/zrok/api/.openapi-generator/FILES | 1 + .../listOrganizationMembers200Response.ts | 6 +- ...anizationMembers200ResponseMembersInner.ts | 37 +++++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 3 + sdk/python/sdk/zrok/zrok_api/__init__.py | 1 + .../sdk/zrok/zrok_api/models/__init__.py | 1 + .../zrok_api/models/inline_response2001.py | 6 +- .../models/inline_response2001_members.py | 136 ++++++++++++++++++ specs/zrok.yml | 2 + 15 files changed, 283 insertions(+), 12 deletions(-) create mode 100644 cmd/zrok/adminListOrgMembers.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200ResponseMembersInner.ts create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2001_members.py diff --git a/cmd/zrok/adminListOrgMembers.go b/cmd/zrok/adminListOrgMembers.go new file mode 100644 index 00000000..0a626379 --- /dev/null +++ b/cmd/zrok/adminListOrgMembers.go @@ -0,0 +1,61 @@ +package main + +import ( + "fmt" + "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/spf13/cobra" + "os" +) + +func init() { + adminListCmd.AddCommand(newAdminListOrgMembersCommand().cmd) +} + +type adminListOrgMembersCommand struct { + cmd *cobra.Command +} + +func newAdminListOrgMembersCommand() *adminListOrgMembersCommand { + cmd := &cobra.Command{ + Use: "org-members ", + Aliases: []string{"members"}, + Short: "List the members of the specified organization", + Args: cobra.ExactArgs(1), + } + command := &adminListOrgMembersCommand{cmd: cmd} + cmd.Run = command.run + return command +} + +func (cmd *adminListOrgMembersCommand) run(_ *cobra.Command, args []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewListOrganizationMembersParams() + req.Body.Token = args[0] + + resp, err := zrok.Admin.ListOrganizationMembers(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + fmt.Println() + t := table.NewWriter() + t.SetOutputMirror(os.Stdout) + t.SetStyle(table.StyleColoredDark) + t.AppendHeader(table.Row{"Account Email", "Admin?"}) + for _, member := range resp.Payload.Members { + t.AppendRow(table.Row{member.Email, member.Admin}) + } + t.Render() + fmt.Println() +} diff --git a/controller/listOrganizationMembers.go b/controller/listOrganizationMembers.go index 54390ddb..e101bc49 100644 --- a/controller/listOrganizationMembers.go +++ b/controller/listOrganizationMembers.go @@ -29,22 +29,22 @@ func (h *listOrganizationMembersHandler) Handle(params admin.ListOrganizationMem org, err := str.FindOrganizationByToken(params.Body.Token, trx) if err != nil { logrus.Errorf("error finding organization by token: %v", err) - return admin.NewListOrganizationMembersInternalServerError() + return admin.NewListOrganizationMembersNotFound() } if org == nil { logrus.Errorf("organization '%v' not found", params.Body.Token) return admin.NewListOrganizationMembersNotFound() } - emails, err := str.FindAccountsForOrganization(org.Id, trx) + oms, err := str.FindAccountsForOrganization(org.Id, trx) if err != nil { logrus.Errorf("error finding accounts for organization: %v", err) return admin.NewListOrganizationMembersInternalServerError() } var members []*admin.ListOrganizationMembersOKBodyMembersItems0 - for _, email := range emails { - members = append(members, &admin.ListOrganizationMembersOKBodyMembersItems0{Email: email}) + for _, om := range oms { + members = append(members, &admin.ListOrganizationMembersOKBodyMembersItems0{Email: om.Email, Admin: om.Admin}) } return admin.NewListOrganizationMembersOK().WithPayload(&admin.ListOrganizationMembersOKBody{Members: members}) } diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go index 7d3c5585..041a4736 100644 --- a/controller/store/organizationMember.go +++ b/controller/store/organizationMember.go @@ -17,8 +17,25 @@ func (str *Store) AddAccountToOrganization(acctId, orgId int, admin bool, trx *s return nil } -func (str *Store) FindAccountsForOrganization(orgId int, trx *sqlx.Tx) ([]string, error) { - return nil, nil +type OrganizationMember struct { + Email string + Admin bool +} + +func (str *Store) FindAccountsForOrganization(orgId int, trx *sqlx.Tx) ([]*OrganizationMember, error) { + rows, err := trx.Queryx("select organization_members.admin, accounts.email from organization_members, accounts where organization_members.organization_id = $1 and organization_members.account_id = accounts.id", orgId) + if err != nil { + return nil, errors.Wrap(err, "error querying organization members") + } + var members []*OrganizationMember + for rows.Next() { + om := &OrganizationMember{} + if err := rows.StructScan(&om); err != nil { + return nil, errors.Wrap(err, "error scanning account email") + } + members = append(members, om) + } + return members, nil } func (str *Store) IsAccountInOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { diff --git a/rest_client_zrok/admin/list_organization_members_responses.go b/rest_client_zrok/admin/list_organization_members_responses.go index 6a48998d..d22940e5 100644 --- a/rest_client_zrok/admin/list_organization_members_responses.go +++ b/rest_client_zrok/admin/list_organization_members_responses.go @@ -441,6 +441,9 @@ swagger:model ListOrganizationMembersOKBodyMembersItems0 */ type ListOrganizationMembersOKBodyMembersItems0 struct { + // admin + Admin bool `json:"admin,omitempty"` + // email Email string `json:"email,omitempty"` } diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 02875bdf..810f00c1 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -992,6 +992,9 @@ func init() { "type": "array", "items": { "properties": { + "admin": { + "type": "boolean" + }, "email": { "type": "string" } @@ -3512,6 +3515,9 @@ func init() { "definitions": { "MembersItems0": { "properties": { + "admin": { + "type": "boolean" + }, "email": { "type": "string" } diff --git a/rest_server_zrok/operations/admin/list_organization_members.go b/rest_server_zrok/operations/admin/list_organization_members.go index d12d3cb8..1b6a05c1 100644 --- a/rest_server_zrok/operations/admin/list_organization_members.go +++ b/rest_server_zrok/operations/admin/list_organization_members.go @@ -223,6 +223,9 @@ func (o *ListOrganizationMembersOKBody) UnmarshalBinary(b []byte) error { // swagger:model ListOrganizationMembersOKBodyMembersItems0 type ListOrganizationMembersOKBodyMembersItems0 struct { + // admin + Admin bool `json:"admin,omitempty"` + // email Email string `json:"email,omitempty"` } diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index 702edf4c..2931720e 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -29,6 +29,7 @@ model/grantsRequest.ts model/inviteRequest.ts model/inviteTokenGenerateRequest.ts model/listOrganizationMembers200Response.ts +model/listOrganizationMembers200ResponseMembersInner.ts model/loginRequest.ts model/metrics.ts model/metricsSample.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts index 5e180b79..01452eca 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200Response.ts @@ -11,10 +11,10 @@ */ import { RequestFile } from './models'; -import { GrantsRequest } from './grantsRequest'; +import { ListOrganizationMembers200ResponseMembersInner } from './listOrganizationMembers200ResponseMembersInner'; export class ListOrganizationMembers200Response { - 'members'?: Array; + 'members'?: Array; static discriminator: string | undefined = undefined; @@ -22,7 +22,7 @@ export class ListOrganizationMembers200Response { { "name": "members", "baseName": "members", - "type": "Array" + "type": "Array" } ]; static getAttributeTypeMap() { diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200ResponseMembersInner.ts b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200ResponseMembersInner.ts new file mode 100644 index 00000000..5c4faa33 --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizationMembers200ResponseMembersInner.ts @@ -0,0 +1,37 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class ListOrganizationMembers200ResponseMembersInner { + 'email'?: string; + 'admin'?: boolean; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "email", + "baseName": "email", + "type": "string" + }, + { + "name": "admin", + "baseName": "admin", + "type": "boolean" + } ]; + + static getAttributeTypeMap() { + return ListOrganizationMembers200ResponseMembersInner.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index 77765e42..32450511 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -23,6 +23,7 @@ export * from './grantsRequest'; export * from './inviteRequest'; export * from './inviteTokenGenerateRequest'; export * from './listOrganizationMembers200Response'; +export * from './listOrganizationMembers200ResponseMembersInner'; export * from './loginRequest'; export * from './metrics'; export * from './metricsSample'; @@ -83,6 +84,7 @@ import { GrantsRequest } from './grantsRequest'; import { InviteRequest } from './inviteRequest'; import { InviteTokenGenerateRequest } from './inviteTokenGenerateRequest'; import { ListOrganizationMembers200Response } from './listOrganizationMembers200Response'; +import { ListOrganizationMembers200ResponseMembersInner } from './listOrganizationMembers200ResponseMembersInner'; import { LoginRequest } from './loginRequest'; import { Metrics } from './metrics'; import { MetricsSample } from './metricsSample'; @@ -151,6 +153,7 @@ let typeMap: {[index: string]: any} = { "InviteRequest": InviteRequest, "InviteTokenGenerateRequest": InviteTokenGenerateRequest, "ListOrganizationMembers200Response": ListOrganizationMembers200Response, + "ListOrganizationMembers200ResponseMembersInner": ListOrganizationMembers200ResponseMembersInner, "LoginRequest": LoginRequest, "Metrics": Metrics, "MetricsSample": MetricsSample, diff --git a/sdk/python/sdk/zrok/zrok_api/__init__.py b/sdk/python/sdk/zrok/zrok_api/__init__.py index 1be1da7b..0a5dd923 100644 --- a/sdk/python/sdk/zrok/zrok_api/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/__init__.py @@ -46,6 +46,7 @@ from zrok_api.models.grants_body import GrantsBody from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 from zrok_api.models.inline_response2001 import InlineResponse2001 +from zrok_api.models.inline_response2001_members import InlineResponse2001Members from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/models/__init__.py b/sdk/python/sdk/zrok/zrok_api/models/__init__.py index 1b78fad6..e65e9399 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/models/__init__.py @@ -36,6 +36,7 @@ from zrok_api.models.grants_body import GrantsBody from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 from zrok_api.models.inline_response2001 import InlineResponse2001 +from zrok_api.models.inline_response2001_members import InlineResponse2001Members from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py index 1b32b09e..214eca09 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001.py @@ -28,7 +28,7 @@ class InlineResponse2001(object): and the value is json key in definition. """ swagger_types = { - 'members': 'list[GrantsBody]' + 'members': 'list[InlineResponse2001Members]' } attribute_map = { @@ -48,7 +48,7 @@ class InlineResponse2001(object): :return: The members of this InlineResponse2001. # noqa: E501 - :rtype: list[GrantsBody] + :rtype: list[InlineResponse2001Members] """ return self._members @@ -58,7 +58,7 @@ class InlineResponse2001(object): :param members: The members of this InlineResponse2001. # noqa: E501 - :type: list[GrantsBody] + :type: list[InlineResponse2001Members] """ self._members = members diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2001_members.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001_members.py new file mode 100644 index 00000000..a5fbc3e6 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2001_members.py @@ -0,0 +1,136 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2001Members(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'email': 'str', + 'admin': 'bool' + } + + attribute_map = { + 'email': 'email', + 'admin': 'admin' + } + + def __init__(self, email=None, admin=None): # noqa: E501 + """InlineResponse2001Members - a model defined in Swagger""" # noqa: E501 + self._email = None + self._admin = None + self.discriminator = None + if email is not None: + self.email = email + if admin is not None: + self.admin = admin + + @property + def email(self): + """Gets the email of this InlineResponse2001Members. # noqa: E501 + + + :return: The email of this InlineResponse2001Members. # noqa: E501 + :rtype: str + """ + return self._email + + @email.setter + def email(self, email): + """Sets the email of this InlineResponse2001Members. + + + :param email: The email of this InlineResponse2001Members. # noqa: E501 + :type: str + """ + + self._email = email + + @property + def admin(self): + """Gets the admin of this InlineResponse2001Members. # noqa: E501 + + + :return: The admin of this InlineResponse2001Members. # noqa: E501 + :rtype: bool + """ + return self._admin + + @admin.setter + def admin(self, admin): + """Sets the admin of this InlineResponse2001Members. + + + :param admin: The admin of this InlineResponse2001Members. # noqa: E501 + :type: bool + """ + + self._admin = admin + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2001Members, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2001Members): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/specs/zrok.yml b/specs/zrok.yml index 2c3eace0..3c40cfe5 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -483,6 +483,8 @@ paths: properties: email: type: string + admin: + type: boolean 401: description: unauthorized 404: From 7c17cce8f0ef8c4f3442425b2d2cab7fb746da02 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Mon, 9 Dec 2024 17:03:30 -0500 Subject: [PATCH 12/32] list organizations (#537) --- cmd/zrok/adminListOrganizations.go | 59 +++ controller/controller.go | 1 + controller/listOrganizations.go | 40 ++ controller/store/organization.go | 16 + rest_client_zrok/admin/admin_client.go | 41 ++ .../admin/list_organizations_parameters.go | 128 ++++++ .../admin/list_organizations_responses.go | 377 ++++++++++++++++++ rest_server_zrok/embedded_spec.go | 85 ++++ .../operations/admin/list_organizations.go | 222 +++++++++++ .../admin/list_organizations_parameters.go | 46 +++ .../admin/list_organizations_responses.go | 107 +++++ .../admin/list_organizations_urlbuilder.go | 87 ++++ rest_server_zrok/operations/zrok_api.go | 12 + .../sdk/src/zrok/api/.openapi-generator/FILES | 2 + sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts | 65 +++ .../api/model/listOrganizations200Response.ts | 32 ++ ...anizations200ResponseOrganizationsInner.ts | 37 ++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 6 + ...nizationMemberRequestOrganizationsInner.ts | 37 ++ sdk/python/sdk/zrok/zrok_api/__init__.py | 2 + sdk/python/sdk/zrok/zrok_api/api/admin_api.py | 85 ++++ .../sdk/zrok/zrok_api/models/__init__.py | 2 + .../zrok_api/models/inline_response2002.py | 110 +++++ .../inline_response2002_organizations.py | 136 +++++++ .../organizationremove_organizations.py | 136 +++++++ specs/zrok.yml | 25 ++ ui/src/api/admin.js | 16 + 27 files changed, 1912 insertions(+) create mode 100644 cmd/zrok/adminListOrganizations.go create mode 100644 controller/listOrganizations.go create mode 100644 rest_client_zrok/admin/list_organizations_parameters.go create mode 100644 rest_client_zrok/admin/list_organizations_responses.go create mode 100644 rest_server_zrok/operations/admin/list_organizations.go create mode 100644 rest_server_zrok/operations/admin/list_organizations_parameters.go create mode 100644 rest_server_zrok/operations/admin/list_organizations_responses.go create mode 100644 rest_server_zrok/operations/admin/list_organizations_urlbuilder.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200Response.ts create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200ResponseOrganizationsInner.ts create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequestOrganizationsInner.ts create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2002.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2002_organizations.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/organizationremove_organizations.py diff --git a/cmd/zrok/adminListOrganizations.go b/cmd/zrok/adminListOrganizations.go new file mode 100644 index 00000000..2bbde476 --- /dev/null +++ b/cmd/zrok/adminListOrganizations.go @@ -0,0 +1,59 @@ +package main + +import ( + "fmt" + "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/admin" + "github.com/spf13/cobra" + "os" +) + +func init() { + adminListCmd.AddCommand(newAdminListOrganizationsCommand().cmd) +} + +type adminListOrganizationsCommand struct { + cmd *cobra.Command +} + +func newAdminListOrganizationsCommand() *adminListOrganizationsCommand { + cmd := &cobra.Command{ + Use: "organizations", + Aliases: []string{"orgs"}, + Short: "List all organizations", + Args: cobra.NoArgs, + } + command := &adminListOrganizationsCommand{cmd} + cmd.Run = command.run + return command +} + +func (c *adminListOrganizationsCommand) run(_ *cobra.Command, _ []string) { + env, err := environment.LoadRoot() + if err != nil { + panic(err) + } + + zrok, err := env.Client() + if err != nil { + panic(err) + } + + req := admin.NewListOrganizationsParams() + resp, err := zrok.Admin.ListOrganizations(req, mustGetAdminAuth()) + if err != nil { + panic(err) + } + + fmt.Println() + t := table.NewWriter() + t.SetOutputMirror(os.Stdout) + t.SetStyle(table.StyleColoredDark) + t.AppendHeader(table.Row{"Token", "Description"}) + for _, org := range resp.Payload.Organizations { + t.AppendRow(table.Row{org.Token, org.Description}) + } + t.Render() + fmt.Println() +} diff --git a/controller/controller.go b/controller/controller.go index e942fb9d..03c29d55 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -62,6 +62,7 @@ func Run(inCfg *config.Config) error { api.AdminInviteTokenGenerateHandler = newInviteTokenGenerateHandler() api.AdminListFrontendsHandler = newListFrontendsHandler() api.AdminListOrganizationMembersHandler = newListOrganizationMembersHandler() + api.AdminListOrganizationsHandler = newListOrganizationsHandler() api.AdminRemoveOrganizationMemberHandler = newRemoveOrganizationMemberHandler() api.AdminUpdateFrontendHandler = newUpdateFrontendHandler() api.EnvironmentEnableHandler = newEnableHandler() diff --git a/controller/listOrganizations.go b/controller/listOrganizations.go new file mode 100644 index 00000000..f2f769e9 --- /dev/null +++ b/controller/listOrganizations.go @@ -0,0 +1,40 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/admin" + "github.com/sirupsen/logrus" +) + +type listOrganizationsHandler struct{} + +func newListOrganizationsHandler() *listOrganizationsHandler { + return &listOrganizationsHandler{} +} + +func (h *listOrganizationsHandler) Handle(_ admin.ListOrganizationsParams, principal *rest_model_zrok.Principal) middleware.Responder { + if !principal.Admin { + logrus.Error("invalid admin principal") + return admin.NewListOrganizationsUnauthorized() + } + + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return admin.NewListOrganizationsInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + orgs, err := str.FindOrganizations(trx) + if err != nil { + logrus.Errorf("error finding organizations: %v", err) + return admin.NewListOrganizationsInternalServerError() + } + + var out []*admin.ListOrganizationsOKBodyOrganizationsItems0 + for _, org := range orgs { + out = append(out, &admin.ListOrganizationsOKBodyOrganizationsItems0{Description: org.Description, Token: org.Token}) + } + return admin.NewListOrganizationsOK().WithPayload(&admin.ListOrganizationsOKBody{Organizations: out}) +} diff --git a/controller/store/organization.go b/controller/store/organization.go index 22dd710c..95eba1bd 100644 --- a/controller/store/organization.go +++ b/controller/store/organization.go @@ -23,6 +23,22 @@ func (str *Store) CreateOrganization(org *Organization, trx *sqlx.Tx) (int, erro return id, nil } +func (str *Store) FindOrganizations(trx *sqlx.Tx) ([]*Organization, error) { + rows, err := trx.Queryx("select * from organizations where not deleted") + if err != nil { + return nil, errors.Wrap(err, "error finding organizations") + } + var orgs []*Organization + for rows.Next() { + org := &Organization{} + if err := rows.StructScan(&org); err != nil { + return nil, errors.Wrap(err, "error scanning organization") + } + orgs = append(orgs, org) + } + return orgs, nil +} + func (str *Store) FindOrganizationByToken(token string, trx *sqlx.Tx) (*Organization, error) { org := &Organization{} if err := trx.QueryRowx("select * from organizations where token = $1 and not deleted", token).StructScan(org); err != nil { diff --git a/rest_client_zrok/admin/admin_client.go b/rest_client_zrok/admin/admin_client.go index 0db767ca..e8597a63 100644 --- a/rest_client_zrok/admin/admin_client.go +++ b/rest_client_zrok/admin/admin_client.go @@ -52,6 +52,8 @@ type ClientService interface { ListOrganizationMembers(params *ListOrganizationMembersParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrganizationMembersOK, error) + ListOrganizations(params *ListOrganizationsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrganizationsOK, error) + RemoveOrganizationMember(params *RemoveOrganizationMemberParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*RemoveOrganizationMemberOK, error) UpdateFrontend(params *UpdateFrontendParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*UpdateFrontendOK, error) @@ -488,6 +490,45 @@ func (a *Client) ListOrganizationMembers(params *ListOrganizationMembersParams, panic(msg) } +/* +ListOrganizations list organizations API +*/ +func (a *Client) ListOrganizations(params *ListOrganizationsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrganizationsOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewListOrganizationsParams() + } + op := &runtime.ClientOperation{ + ID: "listOrganizations", + Method: "GET", + PathPattern: "/organizations", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &ListOrganizationsReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*ListOrganizationsOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for listOrganizations: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* RemoveOrganizationMember remove organization member API */ diff --git a/rest_client_zrok/admin/list_organizations_parameters.go b/rest_client_zrok/admin/list_organizations_parameters.go new file mode 100644 index 00000000..251bd83b --- /dev/null +++ b/rest_client_zrok/admin/list_organizations_parameters.go @@ -0,0 +1,128 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewListOrganizationsParams creates a new ListOrganizationsParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewListOrganizationsParams() *ListOrganizationsParams { + return &ListOrganizationsParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewListOrganizationsParamsWithTimeout creates a new ListOrganizationsParams object +// with the ability to set a timeout on a request. +func NewListOrganizationsParamsWithTimeout(timeout time.Duration) *ListOrganizationsParams { + return &ListOrganizationsParams{ + timeout: timeout, + } +} + +// NewListOrganizationsParamsWithContext creates a new ListOrganizationsParams object +// with the ability to set a context for a request. +func NewListOrganizationsParamsWithContext(ctx context.Context) *ListOrganizationsParams { + return &ListOrganizationsParams{ + Context: ctx, + } +} + +// NewListOrganizationsParamsWithHTTPClient creates a new ListOrganizationsParams object +// with the ability to set a custom HTTPClient for a request. +func NewListOrganizationsParamsWithHTTPClient(client *http.Client) *ListOrganizationsParams { + return &ListOrganizationsParams{ + HTTPClient: client, + } +} + +/* +ListOrganizationsParams contains all the parameters to send to the API endpoint + + for the list organizations operation. + + Typically these are written to a http.Request. +*/ +type ListOrganizationsParams struct { + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the list organizations params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrganizationsParams) WithDefaults() *ListOrganizationsParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the list organizations params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrganizationsParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the list organizations params +func (o *ListOrganizationsParams) WithTimeout(timeout time.Duration) *ListOrganizationsParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the list organizations params +func (o *ListOrganizationsParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the list organizations params +func (o *ListOrganizationsParams) WithContext(ctx context.Context) *ListOrganizationsParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the list organizations params +func (o *ListOrganizationsParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the list organizations params +func (o *ListOrganizationsParams) WithHTTPClient(client *http.Client) *ListOrganizationsParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the list organizations params +func (o *ListOrganizationsParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WriteToRequest writes these params to a swagger request +func (o *ListOrganizationsParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/admin/list_organizations_responses.go b/rest_client_zrok/admin/list_organizations_responses.go new file mode 100644 index 00000000..2adbc8cc --- /dev/null +++ b/rest_client_zrok/admin/list_organizations_responses.go @@ -0,0 +1,377 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// ListOrganizationsReader is a Reader for the ListOrganizations structure. +type ListOrganizationsReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *ListOrganizationsReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewListOrganizationsOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 401: + result := NewListOrganizationsUnauthorized() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewListOrganizationsInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[GET /organizations] listOrganizations", response, response.Code()) + } +} + +// NewListOrganizationsOK creates a ListOrganizationsOK with default headers values +func NewListOrganizationsOK() *ListOrganizationsOK { + return &ListOrganizationsOK{} +} + +/* +ListOrganizationsOK describes a response with status code 200, with default header values. + +ok +*/ +type ListOrganizationsOK struct { + Payload *ListOrganizationsOKBody +} + +// IsSuccess returns true when this list organizations o k response has a 2xx status code +func (o *ListOrganizationsOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this list organizations o k response has a 3xx status code +func (o *ListOrganizationsOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organizations o k response has a 4xx status code +func (o *ListOrganizationsOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this list organizations o k response has a 5xx status code +func (o *ListOrganizationsOK) IsServerError() bool { + return false +} + +// IsCode returns true when this list organizations o k response a status code equal to that given +func (o *ListOrganizationsOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the list organizations o k response +func (o *ListOrganizationsOK) Code() int { + return 200 +} + +func (o *ListOrganizationsOK) Error() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsOK %+v", 200, o.Payload) +} + +func (o *ListOrganizationsOK) String() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsOK %+v", 200, o.Payload) +} + +func (o *ListOrganizationsOK) GetPayload() *ListOrganizationsOKBody { + return o.Payload +} + +func (o *ListOrganizationsOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(ListOrganizationsOKBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewListOrganizationsUnauthorized creates a ListOrganizationsUnauthorized with default headers values +func NewListOrganizationsUnauthorized() *ListOrganizationsUnauthorized { + return &ListOrganizationsUnauthorized{} +} + +/* +ListOrganizationsUnauthorized describes a response with status code 401, with default header values. + +unauthorized +*/ +type ListOrganizationsUnauthorized struct { +} + +// IsSuccess returns true when this list organizations unauthorized response has a 2xx status code +func (o *ListOrganizationsUnauthorized) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list organizations unauthorized response has a 3xx status code +func (o *ListOrganizationsUnauthorized) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organizations unauthorized response has a 4xx status code +func (o *ListOrganizationsUnauthorized) IsClientError() bool { + return true +} + +// IsServerError returns true when this list organizations unauthorized response has a 5xx status code +func (o *ListOrganizationsUnauthorized) IsServerError() bool { + return false +} + +// IsCode returns true when this list organizations unauthorized response a status code equal to that given +func (o *ListOrganizationsUnauthorized) IsCode(code int) bool { + return code == 401 +} + +// Code gets the status code for the list organizations unauthorized response +func (o *ListOrganizationsUnauthorized) Code() int { + return 401 +} + +func (o *ListOrganizationsUnauthorized) Error() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsUnauthorized ", 401) +} + +func (o *ListOrganizationsUnauthorized) String() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsUnauthorized ", 401) +} + +func (o *ListOrganizationsUnauthorized) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewListOrganizationsInternalServerError creates a ListOrganizationsInternalServerError with default headers values +func NewListOrganizationsInternalServerError() *ListOrganizationsInternalServerError { + return &ListOrganizationsInternalServerError{} +} + +/* +ListOrganizationsInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type ListOrganizationsInternalServerError struct { +} + +// IsSuccess returns true when this list organizations internal server error response has a 2xx status code +func (o *ListOrganizationsInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list organizations internal server error response has a 3xx status code +func (o *ListOrganizationsInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list organizations internal server error response has a 4xx status code +func (o *ListOrganizationsInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this list organizations internal server error response has a 5xx status code +func (o *ListOrganizationsInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this list organizations internal server error response a status code equal to that given +func (o *ListOrganizationsInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the list organizations internal server error response +func (o *ListOrganizationsInternalServerError) Code() int { + return 500 +} + +func (o *ListOrganizationsInternalServerError) Error() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsInternalServerError ", 500) +} + +func (o *ListOrganizationsInternalServerError) String() string { + return fmt.Sprintf("[GET /organizations][%d] listOrganizationsInternalServerError ", 500) +} + +func (o *ListOrganizationsInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +ListOrganizationsOKBody list organizations o k body +swagger:model ListOrganizationsOKBody +*/ +type ListOrganizationsOKBody struct { + + // organizations + Organizations []*ListOrganizationsOKBodyOrganizationsItems0 `json:"organizations"` +} + +// Validate validates this list organizations o k body +func (o *ListOrganizationsOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateOrganizations(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationsOKBody) validateOrganizations(formats strfmt.Registry) error { + if swag.IsZero(o.Organizations) { // not required + return nil + } + + for i := 0; i < len(o.Organizations); i++ { + if swag.IsZero(o.Organizations[i]) { // not required + continue + } + + if o.Organizations[i] != nil { + if err := o.Organizations[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list organizations o k body based on the context it is used +func (o *ListOrganizationsOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateOrganizations(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationsOKBody) contextValidateOrganizations(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Organizations); i++ { + + if o.Organizations[i] != nil { + + if swag.IsZero(o.Organizations[i]) { // not required + return nil + } + + if err := o.Organizations[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationsOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationsOKBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationsOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListOrganizationsOKBodyOrganizationsItems0 list organizations o k body organizations items0 +swagger:model ListOrganizationsOKBodyOrganizationsItems0 +*/ +type ListOrganizationsOKBodyOrganizationsItems0 struct { + + // description + Description string `json:"description,omitempty"` + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list organizations o k body organizations items0 +func (o *ListOrganizationsOKBodyOrganizationsItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organizations o k body organizations items0 based on context it is used +func (o *ListOrganizationsOKBodyOrganizationsItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationsOKBodyOrganizationsItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationsOKBodyOrganizationsItems0) UnmarshalBinary(b []byte) error { + var res ListOrganizationsOKBodyOrganizationsItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 810f00c1..4c729f4f 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -1059,6 +1059,47 @@ func init() { } } }, + "/organizations": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "listOrganizations", + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "organizations": { + "type": "array", + "items": { + "properties": { + "description": { + "type": "string" + }, + "token": { + "type": "string" + } + } + } + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/overview": { "get": { "security": [ @@ -3130,6 +3171,40 @@ func init() { } } }, + "/organizations": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "admin" + ], + "operationId": "listOrganizations", + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "organizations": { + "type": "array", + "items": { + "$ref": "#/definitions/OrganizationsItems0" + } + } + } + } + }, + "401": { + "description": "unauthorized" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/overview": { "get": { "security": [ @@ -3523,6 +3598,16 @@ func init() { } } }, + "OrganizationsItems0": { + "properties": { + "description": { + "type": "string" + }, + "token": { + "type": "string" + } + } + }, "accessRequest": { "type": "object", "properties": { diff --git a/rest_server_zrok/operations/admin/list_organizations.go b/rest_server_zrok/operations/admin/list_organizations.go new file mode 100644 index 00000000..112f889e --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organizations.go @@ -0,0 +1,222 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// ListOrganizationsHandlerFunc turns a function with the right signature into a list organizations handler +type ListOrganizationsHandlerFunc func(ListOrganizationsParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn ListOrganizationsHandlerFunc) Handle(params ListOrganizationsParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// ListOrganizationsHandler interface for that can handle valid list organizations params +type ListOrganizationsHandler interface { + Handle(ListOrganizationsParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewListOrganizations creates a new http.Handler for the list organizations operation +func NewListOrganizations(ctx *middleware.Context, handler ListOrganizationsHandler) *ListOrganizations { + return &ListOrganizations{Context: ctx, Handler: handler} +} + +/* + ListOrganizations swagger:route GET /organizations admin listOrganizations + +ListOrganizations list organizations API +*/ +type ListOrganizations struct { + Context *middleware.Context + Handler ListOrganizationsHandler +} + +func (o *ListOrganizations) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewListOrganizationsParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// ListOrganizationsOKBody list organizations o k body +// +// swagger:model ListOrganizationsOKBody +type ListOrganizationsOKBody struct { + + // organizations + Organizations []*ListOrganizationsOKBodyOrganizationsItems0 `json:"organizations"` +} + +// Validate validates this list organizations o k body +func (o *ListOrganizationsOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateOrganizations(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationsOKBody) validateOrganizations(formats strfmt.Registry) error { + if swag.IsZero(o.Organizations) { // not required + return nil + } + + for i := 0; i < len(o.Organizations); i++ { + if swag.IsZero(o.Organizations[i]) { // not required + continue + } + + if o.Organizations[i] != nil { + if err := o.Organizations[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list organizations o k body based on the context it is used +func (o *ListOrganizationsOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateOrganizations(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrganizationsOKBody) contextValidateOrganizations(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Organizations); i++ { + + if o.Organizations[i] != nil { + + if swag.IsZero(o.Organizations[i]) { // not required + return nil + } + + if err := o.Organizations[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrganizationsOK" + "." + "organizations" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationsOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationsOKBody) UnmarshalBinary(b []byte) error { + var res ListOrganizationsOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListOrganizationsOKBodyOrganizationsItems0 list organizations o k body organizations items0 +// +// swagger:model ListOrganizationsOKBodyOrganizationsItems0 +type ListOrganizationsOKBodyOrganizationsItems0 struct { + + // description + Description string `json:"description,omitempty"` + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list organizations o k body organizations items0 +func (o *ListOrganizationsOKBodyOrganizationsItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list organizations o k body organizations items0 based on context it is used +func (o *ListOrganizationsOKBodyOrganizationsItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrganizationsOKBodyOrganizationsItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrganizationsOKBodyOrganizationsItems0) UnmarshalBinary(b []byte) error { + var res ListOrganizationsOKBodyOrganizationsItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/admin/list_organizations_parameters.go b/rest_server_zrok/operations/admin/list_organizations_parameters.go new file mode 100644 index 00000000..dd6a50ff --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organizations_parameters.go @@ -0,0 +1,46 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" +) + +// NewListOrganizationsParams creates a new ListOrganizationsParams object +// +// There are no default values defined in the spec. +func NewListOrganizationsParams() ListOrganizationsParams { + + return ListOrganizationsParams{} +} + +// ListOrganizationsParams contains all the bound params for the list organizations operation +// typically these are obtained from a http.Request +// +// swagger:parameters listOrganizations +type ListOrganizationsParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewListOrganizationsParams() beforehand. +func (o *ListOrganizationsParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/admin/list_organizations_responses.go b/rest_server_zrok/operations/admin/list_organizations_responses.go new file mode 100644 index 00000000..0e02fe63 --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organizations_responses.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// ListOrganizationsOKCode is the HTTP code returned for type ListOrganizationsOK +const ListOrganizationsOKCode int = 200 + +/* +ListOrganizationsOK ok + +swagger:response listOrganizationsOK +*/ +type ListOrganizationsOK struct { + + /* + In: Body + */ + Payload *ListOrganizationsOKBody `json:"body,omitempty"` +} + +// NewListOrganizationsOK creates ListOrganizationsOK with default headers values +func NewListOrganizationsOK() *ListOrganizationsOK { + + return &ListOrganizationsOK{} +} + +// WithPayload adds the payload to the list organizations o k response +func (o *ListOrganizationsOK) WithPayload(payload *ListOrganizationsOKBody) *ListOrganizationsOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the list organizations o k response +func (o *ListOrganizationsOK) SetPayload(payload *ListOrganizationsOKBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *ListOrganizationsOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// ListOrganizationsUnauthorizedCode is the HTTP code returned for type ListOrganizationsUnauthorized +const ListOrganizationsUnauthorizedCode int = 401 + +/* +ListOrganizationsUnauthorized unauthorized + +swagger:response listOrganizationsUnauthorized +*/ +type ListOrganizationsUnauthorized struct { +} + +// NewListOrganizationsUnauthorized creates ListOrganizationsUnauthorized with default headers values +func NewListOrganizationsUnauthorized() *ListOrganizationsUnauthorized { + + return &ListOrganizationsUnauthorized{} +} + +// WriteResponse to the client +func (o *ListOrganizationsUnauthorized) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(401) +} + +// ListOrganizationsInternalServerErrorCode is the HTTP code returned for type ListOrganizationsInternalServerError +const ListOrganizationsInternalServerErrorCode int = 500 + +/* +ListOrganizationsInternalServerError internal server error + +swagger:response listOrganizationsInternalServerError +*/ +type ListOrganizationsInternalServerError struct { +} + +// NewListOrganizationsInternalServerError creates ListOrganizationsInternalServerError with default headers values +func NewListOrganizationsInternalServerError() *ListOrganizationsInternalServerError { + + return &ListOrganizationsInternalServerError{} +} + +// WriteResponse to the client +func (o *ListOrganizationsInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/admin/list_organizations_urlbuilder.go b/rest_server_zrok/operations/admin/list_organizations_urlbuilder.go new file mode 100644 index 00000000..1d589c63 --- /dev/null +++ b/rest_server_zrok/operations/admin/list_organizations_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package admin + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// ListOrganizationsURL generates an URL for the list organizations operation +type ListOrganizationsURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrganizationsURL) WithBasePath(bp string) *ListOrganizationsURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrganizationsURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *ListOrganizationsURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/organizations" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *ListOrganizationsURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *ListOrganizationsURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *ListOrganizationsURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on ListOrganizationsURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on ListOrganizationsURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *ListOrganizationsURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index 9ea40e10..1042e45b 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -121,6 +121,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AdminListOrganizationMembersHandler: admin.ListOrganizationMembersHandlerFunc(func(params admin.ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.ListOrganizationMembers has not yet been implemented") }), + AdminListOrganizationsHandler: admin.ListOrganizationsHandlerFunc(func(params admin.ListOrganizationsParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation admin.ListOrganizations has not yet been implemented") + }), AccountLoginHandler: account.LoginHandlerFunc(func(params account.LoginParams) middleware.Responder { return middleware.NotImplemented("operation account.Login has not yet been implemented") }), @@ -261,6 +264,8 @@ type ZrokAPI struct { AdminListFrontendsHandler admin.ListFrontendsHandler // AdminListOrganizationMembersHandler sets the operation handler for the list organization members operation AdminListOrganizationMembersHandler admin.ListOrganizationMembersHandler + // AdminListOrganizationsHandler sets the operation handler for the list organizations operation + AdminListOrganizationsHandler admin.ListOrganizationsHandler // AccountLoginHandler sets the operation handler for the login operation AccountLoginHandler account.LoginHandler // MetadataOverviewHandler sets the operation handler for the overview operation @@ -442,6 +447,9 @@ func (o *ZrokAPI) Validate() error { if o.AdminListOrganizationMembersHandler == nil { unregistered = append(unregistered, "admin.ListOrganizationMembersHandler") } + if o.AdminListOrganizationsHandler == nil { + unregistered = append(unregistered, "admin.ListOrganizationsHandler") + } if o.AccountLoginHandler == nil { unregistered = append(unregistered, "account.LoginHandler") } @@ -679,6 +687,10 @@ func (o *ZrokAPI) initHandlerCache() { o.handlers["POST"] = make(map[string]http.Handler) } o.handlers["POST"]["/organization/list"] = admin.NewListOrganizationMembers(o.context, o.AdminListOrganizationMembersHandler) + if o.handlers["GET"] == nil { + o.handlers["GET"] = make(map[string]http.Handler) + } + o.handlers["GET"]["/organizations"] = admin.NewListOrganizations(o.context, o.AdminListOrganizationsHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index 2931720e..bbddcaa2 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -30,6 +30,8 @@ model/inviteRequest.ts model/inviteTokenGenerateRequest.ts model/listOrganizationMembers200Response.ts model/listOrganizationMembers200ResponseMembersInner.ts +model/listOrganizations200Response.ts +model/listOrganizations200ResponseOrganizationsInner.ts model/loginRequest.ts model/metrics.ts model/metricsSample.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts index 084b3d2b..20ece673 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/adminApi.ts @@ -26,6 +26,7 @@ import { DeleteFrontendRequest } from '../model/deleteFrontendRequest'; import { GrantsRequest } from '../model/grantsRequest'; import { InviteTokenGenerateRequest } from '../model/inviteTokenGenerateRequest'; import { ListOrganizationMembers200Response } from '../model/listOrganizationMembers200Response'; +import { ListOrganizations200Response } from '../model/listOrganizations200Response'; import { PublicFrontend } from '../model/publicFrontend'; import { RegenerateToken200Response } from '../model/regenerateToken200Response'; import { RemoveOrganizationMemberRequest } from '../model/removeOrganizationMemberRequest'; @@ -787,6 +788,70 @@ export class AdminApi { }); }); } + /** + * + */ + public async listOrganizations (options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: ListOrganizations200Response; }> { + const localVarPath = this.basePath + '/organizations'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'GET', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: ListOrganizations200Response; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "ListOrganizations200Response"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param body diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200Response.ts b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200Response.ts new file mode 100644 index 00000000..0e5bb380 --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200Response.ts @@ -0,0 +1,32 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; +import { ListOrganizations200ResponseOrganizationsInner } from './listOrganizations200ResponseOrganizationsInner'; + +export class ListOrganizations200Response { + 'organizations'?: Array; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "organizations", + "baseName": "organizations", + "type": "Array" + } ]; + + static getAttributeTypeMap() { + return ListOrganizations200Response.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200ResponseOrganizationsInner.ts b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200ResponseOrganizationsInner.ts new file mode 100644 index 00000000..f8e968dc --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listOrganizations200ResponseOrganizationsInner.ts @@ -0,0 +1,37 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class ListOrganizations200ResponseOrganizationsInner { + 'token'?: string; + 'description'?: string; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "token", + "baseName": "token", + "type": "string" + }, + { + "name": "description", + "baseName": "description", + "type": "string" + } ]; + + static getAttributeTypeMap() { + return ListOrganizations200ResponseOrganizationsInner.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index 32450511..1b4baf11 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -24,6 +24,8 @@ export * from './inviteRequest'; export * from './inviteTokenGenerateRequest'; export * from './listOrganizationMembers200Response'; export * from './listOrganizationMembers200ResponseMembersInner'; +export * from './listOrganizations200Response'; +export * from './listOrganizations200ResponseOrganizationsInner'; export * from './loginRequest'; export * from './metrics'; export * from './metricsSample'; @@ -85,6 +87,8 @@ import { InviteRequest } from './inviteRequest'; import { InviteTokenGenerateRequest } from './inviteTokenGenerateRequest'; import { ListOrganizationMembers200Response } from './listOrganizationMembers200Response'; import { ListOrganizationMembers200ResponseMembersInner } from './listOrganizationMembers200ResponseMembersInner'; +import { ListOrganizations200Response } from './listOrganizations200Response'; +import { ListOrganizations200ResponseOrganizationsInner } from './listOrganizations200ResponseOrganizationsInner'; import { LoginRequest } from './loginRequest'; import { Metrics } from './metrics'; import { MetricsSample } from './metricsSample'; @@ -154,6 +158,8 @@ let typeMap: {[index: string]: any} = { "InviteTokenGenerateRequest": InviteTokenGenerateRequest, "ListOrganizationMembers200Response": ListOrganizationMembers200Response, "ListOrganizationMembers200ResponseMembersInner": ListOrganizationMembers200ResponseMembersInner, + "ListOrganizations200Response": ListOrganizations200Response, + "ListOrganizations200ResponseOrganizationsInner": ListOrganizations200ResponseOrganizationsInner, "LoginRequest": LoginRequest, "Metrics": Metrics, "MetricsSample": MetricsSample, diff --git a/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequestOrganizationsInner.ts b/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequestOrganizationsInner.ts new file mode 100644 index 00000000..1a611d55 --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/removeOrganizationMemberRequestOrganizationsInner.ts @@ -0,0 +1,37 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class RemoveOrganizationMemberRequestOrganizationsInner { + 'token'?: string; + 'email'?: string; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "token", + "baseName": "token", + "type": "string" + }, + { + "name": "email", + "baseName": "email", + "type": "string" + } ]; + + static getAttributeTypeMap() { + return RemoveOrganizationMemberRequestOrganizationsInner.attributeTypeMap; + } +} + diff --git a/sdk/python/sdk/zrok/zrok_api/__init__.py b/sdk/python/sdk/zrok/zrok_api/__init__.py index 0a5dd923..e97f9910 100644 --- a/sdk/python/sdk/zrok/zrok_api/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/__init__.py @@ -47,6 +47,8 @@ from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response2001_members import InlineResponse2001Members +from zrok_api.models.inline_response2002 import InlineResponse2002 +from zrok_api.models.inline_response2002_organizations import InlineResponse2002Organizations from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py index b5ba9eb2..172d0968 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/admin_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/admin_api.py @@ -1027,6 +1027,91 @@ class AdminApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def list_organizations(self, **kwargs): # noqa: E501 + """list_organizations # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_organizations(async_req=True) + >>> result = thread.get() + + :param async_req bool + :return: InlineResponse2002 + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.list_organizations_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.list_organizations_with_http_info(**kwargs) # noqa: E501 + return data + + def list_organizations_with_http_info(self, **kwargs): # noqa: E501 + """list_organizations # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_organizations_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :return: InlineResponse2002 + If the method is called asynchronously, + returns the request thread. + """ + + all_params = [] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method list_organizations" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/organizations', 'GET', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='InlineResponse2002', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def remove_organization_member(self, **kwargs): # noqa: E501 """remove_organization_member # noqa: E501 diff --git a/sdk/python/sdk/zrok/zrok_api/models/__init__.py b/sdk/python/sdk/zrok/zrok_api/models/__init__.py index e65e9399..4efe43d4 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/models/__init__.py @@ -37,6 +37,8 @@ from zrok_api.models.identity_body import IdentityBody from zrok_api.models.inline_response200 import InlineResponse200 from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response2001_members import InlineResponse2001Members +from zrok_api.models.inline_response2002 import InlineResponse2002 +from zrok_api.models.inline_response2002_organizations import InlineResponse2002Organizations from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2002.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2002.py new file mode 100644 index 00000000..31aca38e --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2002.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2002(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'organizations': 'list[InlineResponse2002Organizations]' + } + + attribute_map = { + 'organizations': 'organizations' + } + + def __init__(self, organizations=None): # noqa: E501 + """InlineResponse2002 - a model defined in Swagger""" # noqa: E501 + self._organizations = None + self.discriminator = None + if organizations is not None: + self.organizations = organizations + + @property + def organizations(self): + """Gets the organizations of this InlineResponse2002. # noqa: E501 + + + :return: The organizations of this InlineResponse2002. # noqa: E501 + :rtype: list[InlineResponse2002Organizations] + """ + return self._organizations + + @organizations.setter + def organizations(self, organizations): + """Sets the organizations of this InlineResponse2002. + + + :param organizations: The organizations of this InlineResponse2002. # noqa: E501 + :type: list[InlineResponse2002Organizations] + """ + + self._organizations = organizations + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2002, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2002): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2002_organizations.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2002_organizations.py new file mode 100644 index 00000000..b80da9bb --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2002_organizations.py @@ -0,0 +1,136 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2002Organizations(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str', + 'description': 'str' + } + + attribute_map = { + 'token': 'token', + 'description': 'description' + } + + def __init__(self, token=None, description=None): # noqa: E501 + """InlineResponse2002Organizations - a model defined in Swagger""" # noqa: E501 + self._token = None + self._description = None + self.discriminator = None + if token is not None: + self.token = token + if description is not None: + self.description = description + + @property + def token(self): + """Gets the token of this InlineResponse2002Organizations. # noqa: E501 + + + :return: The token of this InlineResponse2002Organizations. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this InlineResponse2002Organizations. + + + :param token: The token of this InlineResponse2002Organizations. # noqa: E501 + :type: str + """ + + self._token = token + + @property + def description(self): + """Gets the description of this InlineResponse2002Organizations. # noqa: E501 + + + :return: The description of this InlineResponse2002Organizations. # noqa: E501 + :rtype: str + """ + return self._description + + @description.setter + def description(self, description): + """Sets the description of this InlineResponse2002Organizations. + + + :param description: The description of this InlineResponse2002Organizations. # noqa: E501 + :type: str + """ + + self._description = description + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2002Organizations, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2002Organizations): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/organizationremove_organizations.py b/sdk/python/sdk/zrok/zrok_api/models/organizationremove_organizations.py new file mode 100644 index 00000000..017ed6bb --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/organizationremove_organizations.py @@ -0,0 +1,136 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class OrganizationremoveOrganizations(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str', + 'email': 'str' + } + + attribute_map = { + 'token': 'token', + 'email': 'email' + } + + def __init__(self, token=None, email=None): # noqa: E501 + """OrganizationremoveOrganizations - a model defined in Swagger""" # noqa: E501 + self._token = None + self._email = None + self.discriminator = None + if token is not None: + self.token = token + if email is not None: + self.email = email + + @property + def token(self): + """Gets the token of this OrganizationremoveOrganizations. # noqa: E501 + + + :return: The token of this OrganizationremoveOrganizations. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this OrganizationremoveOrganizations. + + + :param token: The token of this OrganizationremoveOrganizations. # noqa: E501 + :type: str + """ + + self._token = token + + @property + def email(self): + """Gets the email of this OrganizationremoveOrganizations. # noqa: E501 + + + :return: The email of this OrganizationremoveOrganizations. # noqa: E501 + :rtype: str + """ + return self._email + + @email.setter + def email(self, email): + """Sets the email of this OrganizationremoveOrganizations. + + + :param email: The email of this OrganizationremoveOrganizations. # noqa: E501 + :type: str + """ + + self._email = email + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(OrganizationremoveOrganizations, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, OrganizationremoveOrganizations): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/specs/zrok.yml b/specs/zrok.yml index 3c40cfe5..21312a50 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -518,6 +518,31 @@ paths: 500: description: internal server error + /organizations: + get: + tags: + - admin + security: + - key: [] + operationId: listOrganizations + responses: + 200: + description: ok + schema: + properties: + organizations: + type: array + items: + properties: + token: + type: string + description: + type: string + 401: + description: unauthorized + 500: + description: internal server error + # # environment # diff --git a/ui/src/api/admin.js b/ui/src/api/admin.js index 59ebbbac..bf49d30f 100644 --- a/ui/src/api/admin.js +++ b/ui/src/api/admin.js @@ -188,6 +188,12 @@ export function removeOrganizationMember(options) { return gateway.request(removeOrganizationMemberOperation, parameters) } +/** + */ +export function listOrganizations() { + return gateway.request(listOrganizationsOperation) +} + const createAccountOperation = { path: '/account', contentTypes: ['application/zrok.v1+json'], @@ -329,3 +335,13 @@ const removeOrganizationMemberOperation = { } ] } + +const listOrganizationsOperation = { + path: '/organizations', + method: 'get', + security: [ + { + id: 'key' + } + ] +} From 65104e9e18added4b47f18e57d9d292ddf3306a5 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 11:46:01 -0500 Subject: [PATCH 13/32] initial implementation of 'orgAccountOverview' (#537) --- controller/controller.go | 1 + controller/orgAccountOverview.go | 159 ++++++++++++ controller/overview.go | 14 +- controller/store/organizationMember.go | 4 +- rest_client_zrok/metadata/metadata_client.go | 41 ++++ .../org_account_overview_parameters.go | 167 +++++++++++++ .../org_account_overview_responses.go | 227 ++++++++++++++++++ rest_server_zrok/embedded_spec.go | 82 +++++++ .../metadata/org_account_overview.go | 71 ++++++ .../org_account_overview_parameters.go | 95 ++++++++ .../org_account_overview_responses.go | 109 +++++++++ .../org_account_overview_urlbuilder.go | 107 +++++++++ rest_server_zrok/operations/zrok_api.go | 12 + .../sdk/src/zrok/api/api/metadataApi.ts | 78 ++++++ .../sdk/zrok/zrok_api/api/metadata_api.py | 101 ++++++++ specs/zrok.yml | 26 ++ ui/src/api/metadata.js | 25 ++ 17 files changed, 1313 insertions(+), 6 deletions(-) create mode 100644 controller/orgAccountOverview.go create mode 100644 rest_client_zrok/metadata/org_account_overview_parameters.go create mode 100644 rest_client_zrok/metadata/org_account_overview_responses.go create mode 100644 rest_server_zrok/operations/metadata/org_account_overview.go create mode 100644 rest_server_zrok/operations/metadata/org_account_overview_parameters.go create mode 100644 rest_server_zrok/operations/metadata/org_account_overview_responses.go create mode 100644 rest_server_zrok/operations/metadata/org_account_overview_urlbuilder.go diff --git a/controller/controller.go b/controller/controller.go index 03c29d55..ca844050 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -77,6 +77,7 @@ func Run(inCfg *config.Config) error { api.MetadataGetEnvironmentDetailHandler = newEnvironmentDetailHandler() api.MetadataGetFrontendDetailHandler = newGetFrontendDetailHandler() api.MetadataGetShareDetailHandler = newShareDetailHandler() + api.MetadataOrgAccountOverviewHandler = newOrgAccountOverviewHandler() api.MetadataOverviewHandler = newOverviewHandler() api.MetadataVersionHandler = metadata.VersionHandlerFunc(versionHandler) api.ShareAccessHandler = newAccessHandler() diff --git a/controller/orgAccountOverview.go b/controller/orgAccountOverview.go new file mode 100644 index 00000000..32d422c1 --- /dev/null +++ b/controller/orgAccountOverview.go @@ -0,0 +1,159 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/jmoiron/sqlx" + "github.com/openziti/zrok/controller/store" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/metadata" + "github.com/sirupsen/logrus" +) + +type orgAccountOverviewHandler struct{} + +func newOrgAccountOverviewHandler() *orgAccountOverviewHandler { + return &orgAccountOverviewHandler{} +} + +func (h *orgAccountOverviewHandler) Handle(params metadata.OrgAccountOverviewParams, principal *rest_model_zrok.Principal) middleware.Responder { + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return metadata.NewOrgAccountOverviewInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + org, err := str.FindOrganizationByToken(params.OrganizationToken, trx) + if err != nil { + logrus.Errorf("error finding organization by token: %v", err) + return metadata.NewOrgAccountOverviewNotFound() + } + + admin, err := str.IsAccountAdminOfOrganization(int(principal.ID), org.Id, trx) + if err != nil { + logrus.Errorf("error checking account admin: %v", err) + return metadata.NewOrgAccountOverviewNotFound() + } + if !admin { + logrus.Errorf("requesting account '%v' is not admin of organization '%v'", principal.Email, org.Token) + return metadata.NewOrgAccountOverviewNotFound() + } + + acct, err := str.FindAccountWithEmail(params.AccountEmail, trx) + if err != nil { + logrus.Errorf("error finding account by email: %v", err) + return metadata.NewOrgAccountOverviewNotFound() + } + + inOrg, err := str.IsAccountInOrganization(acct.Id, org.Id, trx) + if err != nil { + logrus.Errorf("error checking account '%v' organization membership: %v", acct.Email, err) + return metadata.NewOrgAccountOverviewNotFound() + } + if !inOrg { + logrus.Errorf("account '%v' is not a member of organization '%v'", acct.Email, org.Token) + return metadata.NewOrgAccountOverviewNotFound() + } + + envs, err := str.FindEnvironmentsForAccount(acct.Id, trx) + if err != nil { + logrus.Errorf("error finding environments for '%v': %v", acct.Email, err) + return metadata.NewOrgAccountOverviewNotFound() + } + + accountLimited, err := h.isAccountLimited(acct.Id, trx) + if err != nil { + logrus.Errorf("error checking account '%v' limited: %v", acct.Email, err) + } + + ovr := &rest_model_zrok.Overview{AccountLimited: accountLimited} + + for _, env := range envs { + ear := &rest_model_zrok.EnvironmentAndResources{ + Environment: &rest_model_zrok.Environment{ + Address: env.Address, + Description: env.Description, + Host: env.Host, + ZID: env.ZId, + CreatedAt: env.CreatedAt.UnixMilli(), + UpdatedAt: env.UpdatedAt.UnixMilli(), + }, + } + + shrs, err := str.FindSharesForEnvironment(env.Id, trx) + if err != nil { + logrus.Errorf("error finding shares for environment '%v': %v", env.ZId, err) + return metadata.NewOverviewInternalServerError() + } + for _, shr := range shrs { + feEndpoint := "" + if shr.FrontendEndpoint != nil { + feEndpoint = *shr.FrontendEndpoint + } + feSelection := "" + if shr.FrontendSelection != nil { + feSelection = *shr.FrontendSelection + } + beProxyEndpoint := "" + if shr.BackendProxyEndpoint != nil { + beProxyEndpoint = *shr.BackendProxyEndpoint + } + envShr := &rest_model_zrok.Share{ + Token: shr.Token, + ZID: shr.ZId, + ShareMode: shr.ShareMode, + BackendMode: shr.BackendMode, + FrontendSelection: feSelection, + FrontendEndpoint: feEndpoint, + BackendProxyEndpoint: beProxyEndpoint, + Reserved: shr.Reserved, + CreatedAt: shr.CreatedAt.UnixMilli(), + UpdatedAt: shr.UpdatedAt.UnixMilli(), + } + ear.Shares = append(ear.Shares, envShr) + } + + fes, err := str.FindFrontendsForEnvironment(env.Id, trx) + if err != nil { + logrus.Errorf("error finding frontends for environment '%v': %v", env.ZId, err) + return metadata.NewOverviewInternalServerError() + } + for _, fe := range fes { + envFe := &rest_model_zrok.Frontend{ + ID: int64(fe.Id), + Token: fe.Token, + ZID: fe.ZId, + CreatedAt: fe.CreatedAt.UnixMilli(), + UpdatedAt: fe.UpdatedAt.UnixMilli(), + } + if fe.PrivateShareId != nil { + feShr, err := str.GetShare(*fe.PrivateShareId, trx) + if err != nil { + logrus.Errorf("error getting share for frontend '%v': %v", fe.ZId, err) + return metadata.NewOverviewInternalServerError() + } + envFe.ShrToken = feShr.Token + } + ear.Frontends = append(ear.Frontends, envFe) + } + + ovr.Environments = append(ovr.Environments, ear) + } + + return metadata.NewOrgAccountOverviewOK().WithPayload(ovr) +} + +func (h *orgAccountOverviewHandler) isAccountLimited(acctId int, trx *sqlx.Tx) (bool, error) { + var je *store.BandwidthLimitJournalEntry + jEmpty, err := str.IsBandwidthLimitJournalEmpty(acctId, trx) + if err != nil { + return false, err + } + if !jEmpty { + je, err = str.FindLatestBandwidthLimitJournal(acctId, trx) + if err != nil { + return false, err + } + } + return je != nil && je.Action == store.LimitLimitAction, nil +} diff --git a/controller/overview.go b/controller/overview.go index f36c31f8..d75b79e1 100644 --- a/controller/overview.go +++ b/controller/overview.go @@ -22,18 +22,21 @@ func (h *overviewHandler) Handle(_ metadata.OverviewParams, principal *rest_mode return metadata.NewOverviewInternalServerError() } defer func() { _ = trx.Rollback() }() + envs, err := str.FindEnvironmentsForAccount(int(principal.ID), trx) if err != nil { logrus.Errorf("error finding environments for '%v': %v", principal.Email, err) return metadata.NewOverviewInternalServerError() } + accountLimited, err := h.isAccountLimited(principal, trx) if err != nil { logrus.Errorf("error checking account limited for '%v': %v", principal.Email, err) } + ovr := &rest_model_zrok.Overview{AccountLimited: accountLimited} for _, env := range envs { - envRes := &rest_model_zrok.EnvironmentAndResources{ + ear := &rest_model_zrok.EnvironmentAndResources{ Environment: &rest_model_zrok.Environment{ Address: env.Address, Description: env.Description, @@ -43,6 +46,7 @@ func (h *overviewHandler) Handle(_ metadata.OverviewParams, principal *rest_mode UpdatedAt: env.UpdatedAt.UnixMilli(), }, } + shrs, err := str.FindSharesForEnvironment(env.Id, trx) if err != nil { logrus.Errorf("error finding shares for environment '%v': %v", env.ZId, err) @@ -73,7 +77,7 @@ func (h *overviewHandler) Handle(_ metadata.OverviewParams, principal *rest_mode CreatedAt: shr.CreatedAt.UnixMilli(), UpdatedAt: shr.UpdatedAt.UnixMilli(), } - envRes.Shares = append(envRes.Shares, envShr) + ear.Shares = append(ear.Shares, envShr) } fes, err := str.FindFrontendsForEnvironment(env.Id, trx) if err != nil { @@ -96,10 +100,12 @@ func (h *overviewHandler) Handle(_ metadata.OverviewParams, principal *rest_mode } envFe.ShrToken = feShr.Token } - envRes.Frontends = append(envRes.Frontends, envFe) + ear.Frontends = append(ear.Frontends, envFe) } - ovr.Environments = append(ovr.Environments, envRes) + + ovr.Environments = append(ovr.Environments, ear) } + return metadata.NewOverviewOK().WithPayload(ovr) } diff --git a/controller/store/organizationMember.go b/controller/store/organizationMember.go index 041a4736..1de0f93a 100644 --- a/controller/store/organizationMember.go +++ b/controller/store/organizationMember.go @@ -39,7 +39,7 @@ func (str *Store) FindAccountsForOrganization(orgId int, trx *sqlx.Tx) ([]*Organ } func (str *Store) IsAccountInOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { - stmt, err := trx.Prepare("select count(0) from organization_members where organization_id = $1 and account_id = $2") + stmt, err := trx.Prepare("select count(0) from organization_members where account_id = $1 and organization_id = $2") if err != nil { return false, errors.Wrap(err, "error preparing organization_members count statement") } @@ -51,7 +51,7 @@ func (str *Store) IsAccountInOrganization(acctId, orgId int, trx *sqlx.Tx) (bool } func (str *Store) IsAccountAdminOfOrganization(acctId, orgId int, trx *sqlx.Tx) (bool, error) { - stmt, err := trx.Prepare("select count(0) from organization_members where organization_id = $1 and account_id = $2 and admin") + stmt, err := trx.Prepare("select count(0) from organization_members where account_id = $1 and organization_id = $2 and admin") if err != nil { return false, errors.Wrap(err, "error preparing organization_members count statement") } diff --git a/rest_client_zrok/metadata/metadata_client.go b/rest_client_zrok/metadata/metadata_client.go index 194736ee..fc0f4040 100644 --- a/rest_client_zrok/metadata/metadata_client.go +++ b/rest_client_zrok/metadata/metadata_client.go @@ -46,6 +46,8 @@ type ClientService interface { GetShareMetrics(params *GetShareMetricsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*GetShareMetricsOK, error) + OrgAccountOverview(params *OrgAccountOverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OrgAccountOverviewOK, error) + Overview(params *OverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OverviewOK, error) Version(params *VersionParams, opts ...ClientOption) (*VersionOK, error) @@ -364,6 +366,45 @@ func (a *Client) GetShareMetrics(params *GetShareMetricsParams, authInfo runtime panic(msg) } +/* +OrgAccountOverview org account overview API +*/ +func (a *Client) OrgAccountOverview(params *OrgAccountOverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OrgAccountOverviewOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewOrgAccountOverviewParams() + } + op := &runtime.ClientOperation{ + ID: "orgAccountOverview", + Method: "GET", + PathPattern: "/overview/{organizationToken}/{accountEmail}", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &OrgAccountOverviewReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*OrgAccountOverviewOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for orgAccountOverview: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* Overview overview API */ diff --git a/rest_client_zrok/metadata/org_account_overview_parameters.go b/rest_client_zrok/metadata/org_account_overview_parameters.go new file mode 100644 index 00000000..5b37a434 --- /dev/null +++ b/rest_client_zrok/metadata/org_account_overview_parameters.go @@ -0,0 +1,167 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewOrgAccountOverviewParams creates a new OrgAccountOverviewParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewOrgAccountOverviewParams() *OrgAccountOverviewParams { + return &OrgAccountOverviewParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewOrgAccountOverviewParamsWithTimeout creates a new OrgAccountOverviewParams object +// with the ability to set a timeout on a request. +func NewOrgAccountOverviewParamsWithTimeout(timeout time.Duration) *OrgAccountOverviewParams { + return &OrgAccountOverviewParams{ + timeout: timeout, + } +} + +// NewOrgAccountOverviewParamsWithContext creates a new OrgAccountOverviewParams object +// with the ability to set a context for a request. +func NewOrgAccountOverviewParamsWithContext(ctx context.Context) *OrgAccountOverviewParams { + return &OrgAccountOverviewParams{ + Context: ctx, + } +} + +// NewOrgAccountOverviewParamsWithHTTPClient creates a new OrgAccountOverviewParams object +// with the ability to set a custom HTTPClient for a request. +func NewOrgAccountOverviewParamsWithHTTPClient(client *http.Client) *OrgAccountOverviewParams { + return &OrgAccountOverviewParams{ + HTTPClient: client, + } +} + +/* +OrgAccountOverviewParams contains all the parameters to send to the API endpoint + + for the org account overview operation. + + Typically these are written to a http.Request. +*/ +type OrgAccountOverviewParams struct { + + // AccountEmail. + AccountEmail string + + // OrganizationToken. + OrganizationToken string + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the org account overview params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *OrgAccountOverviewParams) WithDefaults() *OrgAccountOverviewParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the org account overview params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *OrgAccountOverviewParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the org account overview params +func (o *OrgAccountOverviewParams) WithTimeout(timeout time.Duration) *OrgAccountOverviewParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the org account overview params +func (o *OrgAccountOverviewParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the org account overview params +func (o *OrgAccountOverviewParams) WithContext(ctx context.Context) *OrgAccountOverviewParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the org account overview params +func (o *OrgAccountOverviewParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the org account overview params +func (o *OrgAccountOverviewParams) WithHTTPClient(client *http.Client) *OrgAccountOverviewParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the org account overview params +func (o *OrgAccountOverviewParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithAccountEmail adds the accountEmail to the org account overview params +func (o *OrgAccountOverviewParams) WithAccountEmail(accountEmail string) *OrgAccountOverviewParams { + o.SetAccountEmail(accountEmail) + return o +} + +// SetAccountEmail adds the accountEmail to the org account overview params +func (o *OrgAccountOverviewParams) SetAccountEmail(accountEmail string) { + o.AccountEmail = accountEmail +} + +// WithOrganizationToken adds the organizationToken to the org account overview params +func (o *OrgAccountOverviewParams) WithOrganizationToken(organizationToken string) *OrgAccountOverviewParams { + o.SetOrganizationToken(organizationToken) + return o +} + +// SetOrganizationToken adds the organizationToken to the org account overview params +func (o *OrgAccountOverviewParams) SetOrganizationToken(organizationToken string) { + o.OrganizationToken = organizationToken +} + +// WriteToRequest writes these params to a swagger request +func (o *OrgAccountOverviewParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + + // path param accountEmail + if err := r.SetPathParam("accountEmail", o.AccountEmail); err != nil { + return err + } + + // path param organizationToken + if err := r.SetPathParam("organizationToken", o.OrganizationToken); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/metadata/org_account_overview_responses.go b/rest_client_zrok/metadata/org_account_overview_responses.go new file mode 100644 index 00000000..11f69a0e --- /dev/null +++ b/rest_client_zrok/metadata/org_account_overview_responses.go @@ -0,0 +1,227 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "fmt" + "io" + + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// OrgAccountOverviewReader is a Reader for the OrgAccountOverview structure. +type OrgAccountOverviewReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *OrgAccountOverviewReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewOrgAccountOverviewOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 404: + result := NewOrgAccountOverviewNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewOrgAccountOverviewInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[GET /overview/{organizationToken}/{accountEmail}] orgAccountOverview", response, response.Code()) + } +} + +// NewOrgAccountOverviewOK creates a OrgAccountOverviewOK with default headers values +func NewOrgAccountOverviewOK() *OrgAccountOverviewOK { + return &OrgAccountOverviewOK{} +} + +/* +OrgAccountOverviewOK describes a response with status code 200, with default header values. + +ok +*/ +type OrgAccountOverviewOK struct { + Payload *rest_model_zrok.Overview +} + +// IsSuccess returns true when this org account overview o k response has a 2xx status code +func (o *OrgAccountOverviewOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this org account overview o k response has a 3xx status code +func (o *OrgAccountOverviewOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this org account overview o k response has a 4xx status code +func (o *OrgAccountOverviewOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this org account overview o k response has a 5xx status code +func (o *OrgAccountOverviewOK) IsServerError() bool { + return false +} + +// IsCode returns true when this org account overview o k response a status code equal to that given +func (o *OrgAccountOverviewOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the org account overview o k response +func (o *OrgAccountOverviewOK) Code() int { + return 200 +} + +func (o *OrgAccountOverviewOK) Error() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewOK %+v", 200, o.Payload) +} + +func (o *OrgAccountOverviewOK) String() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewOK %+v", 200, o.Payload) +} + +func (o *OrgAccountOverviewOK) GetPayload() *rest_model_zrok.Overview { + return o.Payload +} + +func (o *OrgAccountOverviewOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(rest_model_zrok.Overview) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewOrgAccountOverviewNotFound creates a OrgAccountOverviewNotFound with default headers values +func NewOrgAccountOverviewNotFound() *OrgAccountOverviewNotFound { + return &OrgAccountOverviewNotFound{} +} + +/* +OrgAccountOverviewNotFound describes a response with status code 404, with default header values. + +not found +*/ +type OrgAccountOverviewNotFound struct { +} + +// IsSuccess returns true when this org account overview not found response has a 2xx status code +func (o *OrgAccountOverviewNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this org account overview not found response has a 3xx status code +func (o *OrgAccountOverviewNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this org account overview not found response has a 4xx status code +func (o *OrgAccountOverviewNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this org account overview not found response has a 5xx status code +func (o *OrgAccountOverviewNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this org account overview not found response a status code equal to that given +func (o *OrgAccountOverviewNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the org account overview not found response +func (o *OrgAccountOverviewNotFound) Code() int { + return 404 +} + +func (o *OrgAccountOverviewNotFound) Error() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewNotFound ", 404) +} + +func (o *OrgAccountOverviewNotFound) String() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewNotFound ", 404) +} + +func (o *OrgAccountOverviewNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewOrgAccountOverviewInternalServerError creates a OrgAccountOverviewInternalServerError with default headers values +func NewOrgAccountOverviewInternalServerError() *OrgAccountOverviewInternalServerError { + return &OrgAccountOverviewInternalServerError{} +} + +/* +OrgAccountOverviewInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type OrgAccountOverviewInternalServerError struct { +} + +// IsSuccess returns true when this org account overview internal server error response has a 2xx status code +func (o *OrgAccountOverviewInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this org account overview internal server error response has a 3xx status code +func (o *OrgAccountOverviewInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this org account overview internal server error response has a 4xx status code +func (o *OrgAccountOverviewInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this org account overview internal server error response has a 5xx status code +func (o *OrgAccountOverviewInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this org account overview internal server error response a status code equal to that given +func (o *OrgAccountOverviewInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the org account overview internal server error response +func (o *OrgAccountOverviewInternalServerError) Code() int { + return 500 +} + +func (o *OrgAccountOverviewInternalServerError) Error() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewInternalServerError ", 500) +} + +func (o *OrgAccountOverviewInternalServerError) String() string { + return fmt.Sprintf("[GET /overview/{organizationToken}/{accountEmail}][%d] orgAccountOverviewInternalServerError ", 500) +} + +func (o *OrgAccountOverviewInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 4c729f4f..f407ad61 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -1127,6 +1127,47 @@ func init() { } } }, + "/overview/{organizationToken}/{accountEmail}": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "orgAccountOverview", + "parameters": [ + { + "type": "string", + "name": "organizationToken", + "in": "path", + "required": true + }, + { + "type": "string", + "name": "accountEmail", + "in": "path", + "required": true + } + ], + "responses": { + "200": { + "description": "ok", + "schema": { + "$ref": "#/definitions/overview" + } + }, + "404": { + "description": "not found" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/regenerateToken": { "post": { "security": [ @@ -3232,6 +3273,47 @@ func init() { } } }, + "/overview/{organizationToken}/{accountEmail}": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "orgAccountOverview", + "parameters": [ + { + "type": "string", + "name": "organizationToken", + "in": "path", + "required": true + }, + { + "type": "string", + "name": "accountEmail", + "in": "path", + "required": true + } + ], + "responses": { + "200": { + "description": "ok", + "schema": { + "$ref": "#/definitions/overview" + } + }, + "404": { + "description": "not found" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/regenerateToken": { "post": { "security": [ diff --git a/rest_server_zrok/operations/metadata/org_account_overview.go b/rest_server_zrok/operations/metadata/org_account_overview.go new file mode 100644 index 00000000..eba81af3 --- /dev/null +++ b/rest_server_zrok/operations/metadata/org_account_overview.go @@ -0,0 +1,71 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime/middleware" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// OrgAccountOverviewHandlerFunc turns a function with the right signature into a org account overview handler +type OrgAccountOverviewHandlerFunc func(OrgAccountOverviewParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn OrgAccountOverviewHandlerFunc) Handle(params OrgAccountOverviewParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// OrgAccountOverviewHandler interface for that can handle valid org account overview params +type OrgAccountOverviewHandler interface { + Handle(OrgAccountOverviewParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewOrgAccountOverview creates a new http.Handler for the org account overview operation +func NewOrgAccountOverview(ctx *middleware.Context, handler OrgAccountOverviewHandler) *OrgAccountOverview { + return &OrgAccountOverview{Context: ctx, Handler: handler} +} + +/* + OrgAccountOverview swagger:route GET /overview/{organizationToken}/{accountEmail} metadata orgAccountOverview + +OrgAccountOverview org account overview API +*/ +type OrgAccountOverview struct { + Context *middleware.Context + Handler OrgAccountOverviewHandler +} + +func (o *OrgAccountOverview) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewOrgAccountOverviewParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} diff --git a/rest_server_zrok/operations/metadata/org_account_overview_parameters.go b/rest_server_zrok/operations/metadata/org_account_overview_parameters.go new file mode 100644 index 00000000..9daff212 --- /dev/null +++ b/rest_server_zrok/operations/metadata/org_account_overview_parameters.go @@ -0,0 +1,95 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" +) + +// NewOrgAccountOverviewParams creates a new OrgAccountOverviewParams object +// +// There are no default values defined in the spec. +func NewOrgAccountOverviewParams() OrgAccountOverviewParams { + + return OrgAccountOverviewParams{} +} + +// OrgAccountOverviewParams contains all the bound params for the org account overview operation +// typically these are obtained from a http.Request +// +// swagger:parameters orgAccountOverview +type OrgAccountOverviewParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + Required: true + In: path + */ + AccountEmail string + /* + Required: true + In: path + */ + OrganizationToken string +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewOrgAccountOverviewParams() beforehand. +func (o *OrgAccountOverviewParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + rAccountEmail, rhkAccountEmail, _ := route.Params.GetOK("accountEmail") + if err := o.bindAccountEmail(rAccountEmail, rhkAccountEmail, route.Formats); err != nil { + res = append(res, err) + } + + rOrganizationToken, rhkOrganizationToken, _ := route.Params.GetOK("organizationToken") + if err := o.bindOrganizationToken(rOrganizationToken, rhkOrganizationToken, route.Formats); err != nil { + res = append(res, err) + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +// bindAccountEmail binds and validates parameter AccountEmail from path. +func (o *OrgAccountOverviewParams) bindAccountEmail(rawData []string, hasKey bool, formats strfmt.Registry) error { + var raw string + if len(rawData) > 0 { + raw = rawData[len(rawData)-1] + } + + // Required: true + // Parameter is provided by construction from the route + o.AccountEmail = raw + + return nil +} + +// bindOrganizationToken binds and validates parameter OrganizationToken from path. +func (o *OrgAccountOverviewParams) bindOrganizationToken(rawData []string, hasKey bool, formats strfmt.Registry) error { + var raw string + if len(rawData) > 0 { + raw = rawData[len(rawData)-1] + } + + // Required: true + // Parameter is provided by construction from the route + o.OrganizationToken = raw + + return nil +} diff --git a/rest_server_zrok/operations/metadata/org_account_overview_responses.go b/rest_server_zrok/operations/metadata/org_account_overview_responses.go new file mode 100644 index 00000000..b2a3b34f --- /dev/null +++ b/rest_server_zrok/operations/metadata/org_account_overview_responses.go @@ -0,0 +1,109 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// OrgAccountOverviewOKCode is the HTTP code returned for type OrgAccountOverviewOK +const OrgAccountOverviewOKCode int = 200 + +/* +OrgAccountOverviewOK ok + +swagger:response orgAccountOverviewOK +*/ +type OrgAccountOverviewOK struct { + + /* + In: Body + */ + Payload *rest_model_zrok.Overview `json:"body,omitempty"` +} + +// NewOrgAccountOverviewOK creates OrgAccountOverviewOK with default headers values +func NewOrgAccountOverviewOK() *OrgAccountOverviewOK { + + return &OrgAccountOverviewOK{} +} + +// WithPayload adds the payload to the org account overview o k response +func (o *OrgAccountOverviewOK) WithPayload(payload *rest_model_zrok.Overview) *OrgAccountOverviewOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the org account overview o k response +func (o *OrgAccountOverviewOK) SetPayload(payload *rest_model_zrok.Overview) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *OrgAccountOverviewOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// OrgAccountOverviewNotFoundCode is the HTTP code returned for type OrgAccountOverviewNotFound +const OrgAccountOverviewNotFoundCode int = 404 + +/* +OrgAccountOverviewNotFound not found + +swagger:response orgAccountOverviewNotFound +*/ +type OrgAccountOverviewNotFound struct { +} + +// NewOrgAccountOverviewNotFound creates OrgAccountOverviewNotFound with default headers values +func NewOrgAccountOverviewNotFound() *OrgAccountOverviewNotFound { + + return &OrgAccountOverviewNotFound{} +} + +// WriteResponse to the client +func (o *OrgAccountOverviewNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + +// OrgAccountOverviewInternalServerErrorCode is the HTTP code returned for type OrgAccountOverviewInternalServerError +const OrgAccountOverviewInternalServerErrorCode int = 500 + +/* +OrgAccountOverviewInternalServerError internal server error + +swagger:response orgAccountOverviewInternalServerError +*/ +type OrgAccountOverviewInternalServerError struct { +} + +// NewOrgAccountOverviewInternalServerError creates OrgAccountOverviewInternalServerError with default headers values +func NewOrgAccountOverviewInternalServerError() *OrgAccountOverviewInternalServerError { + + return &OrgAccountOverviewInternalServerError{} +} + +// WriteResponse to the client +func (o *OrgAccountOverviewInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/metadata/org_account_overview_urlbuilder.go b/rest_server_zrok/operations/metadata/org_account_overview_urlbuilder.go new file mode 100644 index 00000000..10ff4aac --- /dev/null +++ b/rest_server_zrok/operations/metadata/org_account_overview_urlbuilder.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" + "strings" +) + +// OrgAccountOverviewURL generates an URL for the org account overview operation +type OrgAccountOverviewURL struct { + AccountEmail string + OrganizationToken string + + _basePath string + // avoid unkeyed usage + _ struct{} +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *OrgAccountOverviewURL) WithBasePath(bp string) *OrgAccountOverviewURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *OrgAccountOverviewURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *OrgAccountOverviewURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/overview/{organizationToken}/{accountEmail}" + + accountEmail := o.AccountEmail + if accountEmail != "" { + _path = strings.Replace(_path, "{accountEmail}", accountEmail, -1) + } else { + return nil, errors.New("accountEmail is required on OrgAccountOverviewURL") + } + + organizationToken := o.OrganizationToken + if organizationToken != "" { + _path = strings.Replace(_path, "{organizationToken}", organizationToken, -1) + } else { + return nil, errors.New("organizationToken is required on OrgAccountOverviewURL") + } + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *OrgAccountOverviewURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *OrgAccountOverviewURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *OrgAccountOverviewURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on OrgAccountOverviewURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on OrgAccountOverviewURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *OrgAccountOverviewURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index 1042e45b..a8004b82 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -127,6 +127,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AccountLoginHandler: account.LoginHandlerFunc(func(params account.LoginParams) middleware.Responder { return middleware.NotImplemented("operation account.Login has not yet been implemented") }), + MetadataOrgAccountOverviewHandler: metadata.OrgAccountOverviewHandlerFunc(func(params metadata.OrgAccountOverviewParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation metadata.OrgAccountOverview has not yet been implemented") + }), MetadataOverviewHandler: metadata.OverviewHandlerFunc(func(params metadata.OverviewParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation metadata.Overview has not yet been implemented") }), @@ -268,6 +271,8 @@ type ZrokAPI struct { AdminListOrganizationsHandler admin.ListOrganizationsHandler // AccountLoginHandler sets the operation handler for the login operation AccountLoginHandler account.LoginHandler + // MetadataOrgAccountOverviewHandler sets the operation handler for the org account overview operation + MetadataOrgAccountOverviewHandler metadata.OrgAccountOverviewHandler // MetadataOverviewHandler sets the operation handler for the overview operation MetadataOverviewHandler metadata.OverviewHandler // AccountRegenerateTokenHandler sets the operation handler for the regenerate token operation @@ -453,6 +458,9 @@ func (o *ZrokAPI) Validate() error { if o.AccountLoginHandler == nil { unregistered = append(unregistered, "account.LoginHandler") } + if o.MetadataOrgAccountOverviewHandler == nil { + unregistered = append(unregistered, "metadata.OrgAccountOverviewHandler") + } if o.MetadataOverviewHandler == nil { unregistered = append(unregistered, "metadata.OverviewHandler") } @@ -698,6 +706,10 @@ func (o *ZrokAPI) initHandlerCache() { if o.handlers["GET"] == nil { o.handlers["GET"] = make(map[string]http.Handler) } + o.handlers["GET"]["/overview/{organizationToken}/{accountEmail}"] = metadata.NewOrgAccountOverview(o.context, o.MetadataOrgAccountOverviewHandler) + if o.handlers["GET"] == nil { + o.handlers["GET"] = make(map[string]http.Handler) + } o.handlers["GET"]["/overview"] = metadata.NewOverview(o.context, o.MetadataOverviewHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) diff --git a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts index 7c6cba4e..e28d4dbf 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts @@ -654,6 +654,84 @@ export class MetadataApi { }); }); } + /** + * + * @param organizationToken + * @param accountEmail + */ + public async orgAccountOverview (organizationToken: string, accountEmail: string, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: Overview; }> { + const localVarPath = this.basePath + '/overview/{organizationToken}/{accountEmail}' + .replace('{' + 'organizationToken' + '}', encodeURIComponent(String(organizationToken))) + .replace('{' + 'accountEmail' + '}', encodeURIComponent(String(accountEmail))); + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + // verify required parameter 'organizationToken' is not null or undefined + if (organizationToken === null || organizationToken === undefined) { + throw new Error('Required parameter organizationToken was null or undefined when calling orgAccountOverview.'); + } + + // verify required parameter 'accountEmail' is not null or undefined + if (accountEmail === null || accountEmail === undefined) { + throw new Error('Required parameter accountEmail was null or undefined when calling orgAccountOverview.'); + } + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'GET', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: Overview; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "Overview"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * */ diff --git a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py index fb4b8675..ec9236df 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py @@ -764,6 +764,107 @@ class MetadataApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def org_account_overview(self, organization_token, account_email, **kwargs): # noqa: E501 + """org_account_overview # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.org_account_overview(organization_token, account_email, async_req=True) + >>> result = thread.get() + + :param async_req bool + :param str organization_token: (required) + :param str account_email: (required) + :return: Overview + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.org_account_overview_with_http_info(organization_token, account_email, **kwargs) # noqa: E501 + else: + (data) = self.org_account_overview_with_http_info(organization_token, account_email, **kwargs) # noqa: E501 + return data + + def org_account_overview_with_http_info(self, organization_token, account_email, **kwargs): # noqa: E501 + """org_account_overview # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.org_account_overview_with_http_info(organization_token, account_email, async_req=True) + >>> result = thread.get() + + :param async_req bool + :param str organization_token: (required) + :param str account_email: (required) + :return: Overview + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['organization_token', 'account_email'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method org_account_overview" % key + ) + params[key] = val + del params['kwargs'] + # verify the required parameter 'organization_token' is set + if ('organization_token' not in params or + params['organization_token'] is None): + raise ValueError("Missing the required parameter `organization_token` when calling `org_account_overview`") # noqa: E501 + # verify the required parameter 'account_email' is set + if ('account_email' not in params or + params['account_email'] is None): + raise ValueError("Missing the required parameter `account_email` when calling `org_account_overview`") # noqa: E501 + + collection_formats = {} + + path_params = {} + if 'organization_token' in params: + path_params['organizationToken'] = params['organization_token'] # noqa: E501 + if 'account_email' in params: + path_params['accountEmail'] = params['account_email'] # noqa: E501 + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/overview/{organizationToken}/{accountEmail}', 'GET', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='Overview', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def overview(self, **kwargs): # noqa: E501 """overview # noqa: E501 diff --git a/specs/zrok.yml b/specs/zrok.yml index 21312a50..7c96e5ee 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -708,6 +708,32 @@ paths: schema: $ref: "#/definitions/errorMessage" + /overview/{organizationToken}/{accountEmail}: + get: + tags: + - metadata + security: + - key: [] + operationId: orgAccountOverview + parameters: + - name: organizationToken + in: path + type: string + required: true + - name: accountEmail + in: path + type: string + required: true + responses: + 200: + description: ok + schema: + $ref: "#/definitions/overview" + 404: + description: not found + 500: + description: internal server error + /metrics/account: get: tags: diff --git a/ui/src/api/metadata.js b/ui/src/api/metadata.js index 463128c3..6ff83b76 100644 --- a/ui/src/api/metadata.js +++ b/ui/src/api/metadata.js @@ -59,6 +59,21 @@ export function overview() { return gateway.request(overviewOperation) } +/** + * @param {string} organizationToken + * @param {string} accountEmail + * @return {Promise} ok + */ +export function orgAccountOverview(organizationToken, accountEmail) { + const parameters = { + path: { + organizationToken, + accountEmail + } + } + return gateway.request(orgAccountOverviewOperation, parameters) +} + /** * @param {object} options Optional options * @param {string} [options.duration] @@ -173,6 +188,16 @@ const overviewOperation = { ] } +const orgAccountOverviewOperation = { + path: '/overview/{organizationToken}/{accountEmail}', + method: 'get', + security: [ + { + id: 'key' + } + ] +} + const getAccountMetricsOperation = { path: '/metrics/account', method: 'get', From 5582ac0ea57ef67c90ebde269712de02a507cf54 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 12:55:34 -0500 Subject: [PATCH 14/32] added 'zrok organization account-overview' ('zrok org overview') to allow admins to query overview data for any account in an org where they're an admin (#537) --- cmd/zrok/main.go | 7 +++ cmd/zrok/orgAccountOverview.go | 79 ++++++++++++++++++++++++++++++++++ 2 files changed, 86 insertions(+) create mode 100644 cmd/zrok/orgAccountOverview.go diff --git a/cmd/zrok/main.go b/cmd/zrok/main.go index 8dc56441..a8940e88 100644 --- a/cmd/zrok/main.go +++ b/cmd/zrok/main.go @@ -28,6 +28,7 @@ func init() { rootCmd.AddCommand(adminCmd) rootCmd.AddCommand(configCmd) rootCmd.AddCommand(modifyCmd) + rootCmd.AddCommand(organizationCmd) rootCmd.AddCommand(shareCmd) rootCmd.AddCommand(testCmd) rootCmd.AddCommand(gendoc.NewGendocCmd(rootCmd)) @@ -94,6 +95,12 @@ var modifyCmd = &cobra.Command{ Short: "Modify resources", } +var organizationCmd = &cobra.Command{ + Use: "organization", + Aliases: []string{"org"}, + Short: "Organization admin commands", +} + var shareCmd = &cobra.Command{ Use: "share", Short: "Create backend access for shares", diff --git a/cmd/zrok/orgAccountOverview.go b/cmd/zrok/orgAccountOverview.go new file mode 100644 index 00000000..77a90ee2 --- /dev/null +++ b/cmd/zrok/orgAccountOverview.go @@ -0,0 +1,79 @@ +package main + +import ( + "fmt" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/tui" + "github.com/pkg/errors" + "github.com/spf13/cobra" + "io" + "net/http" +) + +func init() { + organizationCmd.AddCommand(newOrgAccountOverviewCommand().cmd) +} + +type orgAccountOverviewCommand struct { + cmd *cobra.Command +} + +func newOrgAccountOverviewCommand() *orgAccountOverviewCommand { + cmd := &cobra.Command{ + Use: "account-overview ", + Aliases: []string{"overview"}, + Args: cobra.ExactArgs(2), + } + command := &orgAccountOverviewCommand{cmd: cmd} + cmd.Run = command.run + return command +} + +func (cmd *orgAccountOverviewCommand) run(_ *cobra.Command, args []string) { + root, err := environment.LoadRoot() + if err != nil { + if !panicInstead { + tui.Error("error loading zrokdir", err) + } + panic(err) + } + + if !root.IsEnabled() { + tui.Error("unable to load environment; did you 'zrok enable'?", nil) + } + + client := &http.Client{} + apiEndpoint, _ := root.ApiEndpoint() + req, err := http.NewRequest("GET", fmt.Sprintf("%v/api/v1/overview/%v/%v", apiEndpoint, args[0], args[1]), nil) + if err != nil { + if !panicInstead { + tui.Error("error creating request", err) + } + panic(err) + } + req.Header.Add("X-TOKEN", root.Environment().Token) + resp, err := client.Do(req) + if err != nil { + if !panicInstead { + tui.Error("error sending request", err) + } + panic(err) + } + if resp.StatusCode != http.StatusOK { + if !panicInstead { + tui.Error("received error response", errors.New(resp.Status)) + } + panic(errors.New(resp.Status)) + } + + json, err := io.ReadAll(resp.Body) + if err != nil { + if !panicInstead { + tui.Error("error reading json", err) + } + panic(err) + } + _ = resp.Body.Close() + + fmt.Println(string(json)) +} From 3aff9950c8ca6caa0f9b076fb5c9a437b6ac9e28 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 13:28:29 -0500 Subject: [PATCH 15/32] list memberships for end users (#537) --- cmd/zrok/orgAccountOverview.go | 1 + controller/controller.go | 1 + controller/listMemberships.go | 35 ++ controller/store/organization.go | 25 ++ .../metadata/list_memberships_parameters.go | 128 +++++++ .../metadata/list_memberships_responses.go | 318 ++++++++++++++++++ rest_client_zrok/metadata/metadata_client.go | 41 +++ rest_server_zrok/embedded_spec.go | 85 +++++ .../operations/metadata/list_memberships.go | 225 +++++++++++++ .../metadata/list_memberships_parameters.go | 46 +++ .../metadata/list_memberships_responses.go | 82 +++++ .../metadata/list_memberships_urlbuilder.go | 87 +++++ rest_server_zrok/operations/zrok_api.go | 12 + .../sdk/src/zrok/api/.openapi-generator/FILES | 2 + .../sdk/src/zrok/api/api/metadataApi.ts | 65 ++++ .../api/model/listMemberships200Response.ts | 32 ++ ...tMemberships200ResponseMembershipsInner.ts | 43 +++ sdk/nodejs/sdk/src/zrok/api/model/models.ts | 6 + sdk/python/sdk/zrok/zrok_api/__init__.py | 2 + .../sdk/zrok/zrok_api/api/metadata_api.py | 85 +++++ .../sdk/zrok/zrok_api/models/__init__.py | 2 + .../zrok_api/models/inline_response2003.py | 110 ++++++ .../models/inline_response2003_memberships.py | 162 +++++++++ specs/zrok.yml | 25 ++ ui/src/api/metadata.js | 16 + 25 files changed, 1636 insertions(+) create mode 100644 controller/listMemberships.go create mode 100644 rest_client_zrok/metadata/list_memberships_parameters.go create mode 100644 rest_client_zrok/metadata/list_memberships_responses.go create mode 100644 rest_server_zrok/operations/metadata/list_memberships.go create mode 100644 rest_server_zrok/operations/metadata/list_memberships_parameters.go create mode 100644 rest_server_zrok/operations/metadata/list_memberships_responses.go create mode 100644 rest_server_zrok/operations/metadata/list_memberships_urlbuilder.go create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listMemberships200Response.ts create mode 100644 sdk/nodejs/sdk/src/zrok/api/model/listMemberships200ResponseMembershipsInner.ts create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2003.py create mode 100644 sdk/python/sdk/zrok/zrok_api/models/inline_response2003_memberships.py diff --git a/cmd/zrok/orgAccountOverview.go b/cmd/zrok/orgAccountOverview.go index 77a90ee2..4b7d415f 100644 --- a/cmd/zrok/orgAccountOverview.go +++ b/cmd/zrok/orgAccountOverview.go @@ -22,6 +22,7 @@ func newOrgAccountOverviewCommand() *orgAccountOverviewCommand { cmd := &cobra.Command{ Use: "account-overview ", Aliases: []string{"overview"}, + Short: "Retrieve account overview for organization account (requires admin)", Args: cobra.ExactArgs(2), } command := &orgAccountOverviewCommand{cmd: cmd} diff --git a/controller/controller.go b/controller/controller.go index ca844050..0f952c28 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -77,6 +77,7 @@ func Run(inCfg *config.Config) error { api.MetadataGetEnvironmentDetailHandler = newEnvironmentDetailHandler() api.MetadataGetFrontendDetailHandler = newGetFrontendDetailHandler() api.MetadataGetShareDetailHandler = newShareDetailHandler() + api.MetadataListMembershipsHandler = newListMembershipsHandler() api.MetadataOrgAccountOverviewHandler = newOrgAccountOverviewHandler() api.MetadataOverviewHandler = newOverviewHandler() api.MetadataVersionHandler = metadata.VersionHandlerFunc(versionHandler) diff --git a/controller/listMemberships.go b/controller/listMemberships.go new file mode 100644 index 00000000..e6e91f3d --- /dev/null +++ b/controller/listMemberships.go @@ -0,0 +1,35 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/metadata" + "github.com/sirupsen/logrus" +) + +type listMembershipsHandler struct{} + +func newListMembershipsHandler() *listMembershipsHandler { + return &listMembershipsHandler{} +} + +func (h *listMembershipsHandler) Handle(_ metadata.ListMembershipsParams, principal *rest_model_zrok.Principal) middleware.Responder { + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error startin transaction: %v", err) + return metadata.NewListMembershipsInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + oms, err := str.FindOrganizationsForAccount(int(principal.ID), trx) + if err != nil { + logrus.Errorf("error finding organizations for account '%v': %v", principal.Email, err) + return metadata.NewListMembershipsInternalServerError() + } + + var out []*metadata.ListMembershipsOKBodyMembershipsItems0 + for _, om := range oms { + out = append(out, &metadata.ListMembershipsOKBodyMembershipsItems0{Token: om.Token, Description: om.Description, Admin: om.Admin}) + } + return metadata.NewListMembershipsOK().WithPayload(&metadata.ListMembershipsOKBody{Memberships: out}) +} diff --git a/controller/store/organization.go b/controller/store/organization.go index 95eba1bd..8b06b80c 100644 --- a/controller/store/organization.go +++ b/controller/store/organization.go @@ -47,6 +47,31 @@ func (str *Store) FindOrganizationByToken(token string, trx *sqlx.Tx) (*Organiza return org, nil } +type OrganizationMembership struct { + Token string + Description string + Admin bool +} + +func (str *Store) FindOrganizationsForAccount(acctId int, trx *sqlx.Tx) ([]*OrganizationMembership, error) { + sql := "select organizations.token, organizations.description, organization_members.admin from organizations, organization_members " + + "where organization_members.account_id = $1 and organization_members.organization_id = organizations.id and not organizations.deleted" + rows, err := trx.Queryx(sql, acctId) + if err != nil { + return nil, errors.Wrap(err, "error querying organization memberships") + } + var oms []*OrganizationMembership + for rows.Next() { + om := &OrganizationMembership{} + if err := rows.StructScan(&om); err != nil { + return nil, errors.Wrap(err, "error scanning organization membership") + } + oms = append(oms, om) + } + return oms, nil + +} + func (str *Store) DeleteOrganization(id int, trx *sqlx.Tx) error { stmt, err := trx.Prepare("update organizations set updated_at = current_timestamp, deleted = true where id = $1") if err != nil { diff --git a/rest_client_zrok/metadata/list_memberships_parameters.go b/rest_client_zrok/metadata/list_memberships_parameters.go new file mode 100644 index 00000000..1a77abc9 --- /dev/null +++ b/rest_client_zrok/metadata/list_memberships_parameters.go @@ -0,0 +1,128 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewListMembershipsParams creates a new ListMembershipsParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewListMembershipsParams() *ListMembershipsParams { + return &ListMembershipsParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewListMembershipsParamsWithTimeout creates a new ListMembershipsParams object +// with the ability to set a timeout on a request. +func NewListMembershipsParamsWithTimeout(timeout time.Duration) *ListMembershipsParams { + return &ListMembershipsParams{ + timeout: timeout, + } +} + +// NewListMembershipsParamsWithContext creates a new ListMembershipsParams object +// with the ability to set a context for a request. +func NewListMembershipsParamsWithContext(ctx context.Context) *ListMembershipsParams { + return &ListMembershipsParams{ + Context: ctx, + } +} + +// NewListMembershipsParamsWithHTTPClient creates a new ListMembershipsParams object +// with the ability to set a custom HTTPClient for a request. +func NewListMembershipsParamsWithHTTPClient(client *http.Client) *ListMembershipsParams { + return &ListMembershipsParams{ + HTTPClient: client, + } +} + +/* +ListMembershipsParams contains all the parameters to send to the API endpoint + + for the list memberships operation. + + Typically these are written to a http.Request. +*/ +type ListMembershipsParams struct { + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the list memberships params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListMembershipsParams) WithDefaults() *ListMembershipsParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the list memberships params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListMembershipsParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the list memberships params +func (o *ListMembershipsParams) WithTimeout(timeout time.Duration) *ListMembershipsParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the list memberships params +func (o *ListMembershipsParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the list memberships params +func (o *ListMembershipsParams) WithContext(ctx context.Context) *ListMembershipsParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the list memberships params +func (o *ListMembershipsParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the list memberships params +func (o *ListMembershipsParams) WithHTTPClient(client *http.Client) *ListMembershipsParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the list memberships params +func (o *ListMembershipsParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WriteToRequest writes these params to a swagger request +func (o *ListMembershipsParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/metadata/list_memberships_responses.go b/rest_client_zrok/metadata/list_memberships_responses.go new file mode 100644 index 00000000..c79b2d1c --- /dev/null +++ b/rest_client_zrok/metadata/list_memberships_responses.go @@ -0,0 +1,318 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// ListMembershipsReader is a Reader for the ListMemberships structure. +type ListMembershipsReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *ListMembershipsReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewListMembershipsOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 500: + result := NewListMembershipsInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[GET /memberships] listMemberships", response, response.Code()) + } +} + +// NewListMembershipsOK creates a ListMembershipsOK with default headers values +func NewListMembershipsOK() *ListMembershipsOK { + return &ListMembershipsOK{} +} + +/* +ListMembershipsOK describes a response with status code 200, with default header values. + +ok +*/ +type ListMembershipsOK struct { + Payload *ListMembershipsOKBody +} + +// IsSuccess returns true when this list memberships o k response has a 2xx status code +func (o *ListMembershipsOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this list memberships o k response has a 3xx status code +func (o *ListMembershipsOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list memberships o k response has a 4xx status code +func (o *ListMembershipsOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this list memberships o k response has a 5xx status code +func (o *ListMembershipsOK) IsServerError() bool { + return false +} + +// IsCode returns true when this list memberships o k response a status code equal to that given +func (o *ListMembershipsOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the list memberships o k response +func (o *ListMembershipsOK) Code() int { + return 200 +} + +func (o *ListMembershipsOK) Error() string { + return fmt.Sprintf("[GET /memberships][%d] listMembershipsOK %+v", 200, o.Payload) +} + +func (o *ListMembershipsOK) String() string { + return fmt.Sprintf("[GET /memberships][%d] listMembershipsOK %+v", 200, o.Payload) +} + +func (o *ListMembershipsOK) GetPayload() *ListMembershipsOKBody { + return o.Payload +} + +func (o *ListMembershipsOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(ListMembershipsOKBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewListMembershipsInternalServerError creates a ListMembershipsInternalServerError with default headers values +func NewListMembershipsInternalServerError() *ListMembershipsInternalServerError { + return &ListMembershipsInternalServerError{} +} + +/* +ListMembershipsInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type ListMembershipsInternalServerError struct { +} + +// IsSuccess returns true when this list memberships internal server error response has a 2xx status code +func (o *ListMembershipsInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list memberships internal server error response has a 3xx status code +func (o *ListMembershipsInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list memberships internal server error response has a 4xx status code +func (o *ListMembershipsInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this list memberships internal server error response has a 5xx status code +func (o *ListMembershipsInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this list memberships internal server error response a status code equal to that given +func (o *ListMembershipsInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the list memberships internal server error response +func (o *ListMembershipsInternalServerError) Code() int { + return 500 +} + +func (o *ListMembershipsInternalServerError) Error() string { + return fmt.Sprintf("[GET /memberships][%d] listMembershipsInternalServerError ", 500) +} + +func (o *ListMembershipsInternalServerError) String() string { + return fmt.Sprintf("[GET /memberships][%d] listMembershipsInternalServerError ", 500) +} + +func (o *ListMembershipsInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +ListMembershipsOKBody list memberships o k body +swagger:model ListMembershipsOKBody +*/ +type ListMembershipsOKBody struct { + + // memberships + Memberships []*ListMembershipsOKBodyMembershipsItems0 `json:"memberships"` +} + +// Validate validates this list memberships o k body +func (o *ListMembershipsOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMemberships(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembershipsOKBody) validateMemberships(formats strfmt.Registry) error { + if swag.IsZero(o.Memberships) { // not required + return nil + } + + for i := 0; i < len(o.Memberships); i++ { + if swag.IsZero(o.Memberships[i]) { // not required + continue + } + + if o.Memberships[i] != nil { + if err := o.Memberships[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list memberships o k body based on the context it is used +func (o *ListMembershipsOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMemberships(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembershipsOKBody) contextValidateMemberships(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Memberships); i++ { + + if o.Memberships[i] != nil { + + if swag.IsZero(o.Memberships[i]) { // not required + return nil + } + + if err := o.Memberships[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembershipsOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembershipsOKBody) UnmarshalBinary(b []byte) error { + var res ListMembershipsOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListMembershipsOKBodyMembershipsItems0 list memberships o k body memberships items0 +swagger:model ListMembershipsOKBodyMembershipsItems0 +*/ +type ListMembershipsOKBodyMembershipsItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // description + Description string `json:"description,omitempty"` + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list memberships o k body memberships items0 +func (o *ListMembershipsOKBodyMembershipsItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list memberships o k body memberships items0 based on context it is used +func (o *ListMembershipsOKBodyMembershipsItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembershipsOKBodyMembershipsItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembershipsOKBodyMembershipsItems0) UnmarshalBinary(b []byte) error { + var res ListMembershipsOKBodyMembershipsItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/metadata/metadata_client.go b/rest_client_zrok/metadata/metadata_client.go index fc0f4040..4706380a 100644 --- a/rest_client_zrok/metadata/metadata_client.go +++ b/rest_client_zrok/metadata/metadata_client.go @@ -46,6 +46,8 @@ type ClientService interface { GetShareMetrics(params *GetShareMetricsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*GetShareMetricsOK, error) + ListMemberships(params *ListMembershipsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListMembershipsOK, error) + OrgAccountOverview(params *OrgAccountOverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OrgAccountOverviewOK, error) Overview(params *OverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OverviewOK, error) @@ -366,6 +368,45 @@ func (a *Client) GetShareMetrics(params *GetShareMetricsParams, authInfo runtime panic(msg) } +/* +ListMemberships list memberships API +*/ +func (a *Client) ListMemberships(params *ListMembershipsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListMembershipsOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewListMembershipsParams() + } + op := &runtime.ClientOperation{ + ID: "listMemberships", + Method: "GET", + PathPattern: "/memberships", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &ListMembershipsReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*ListMembershipsOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for listMemberships: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* OrgAccountOverview org account overview API */ diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index f407ad61..68d4556c 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -711,6 +711,47 @@ func init() { } } }, + "/memberships": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "listMemberships", + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "memberships": { + "type": "array", + "items": { + "properties": { + "admin": { + "type": "boolean" + }, + "description": { + "type": "string" + }, + "token": { + "type": "string" + } + } + } + } + } + } + }, + "500": { + "description": "internal server error" + } + } + } + }, "/metrics/account": { "get": { "security": [ @@ -2871,6 +2912,37 @@ func init() { } } }, + "/memberships": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "listMemberships", + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "memberships": { + "type": "array", + "items": { + "$ref": "#/definitions/MembershipsItems0" + } + } + } + } + }, + "500": { + "description": "internal server error" + } + } + } + }, "/metrics/account": { "get": { "security": [ @@ -3680,6 +3752,19 @@ func init() { } } }, + "MembershipsItems0": { + "properties": { + "admin": { + "type": "boolean" + }, + "description": { + "type": "string" + }, + "token": { + "type": "string" + } + } + }, "OrganizationsItems0": { "properties": { "description": { diff --git a/rest_server_zrok/operations/metadata/list_memberships.go b/rest_server_zrok/operations/metadata/list_memberships.go new file mode 100644 index 00000000..985140cc --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_memberships.go @@ -0,0 +1,225 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// ListMembershipsHandlerFunc turns a function with the right signature into a list memberships handler +type ListMembershipsHandlerFunc func(ListMembershipsParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn ListMembershipsHandlerFunc) Handle(params ListMembershipsParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// ListMembershipsHandler interface for that can handle valid list memberships params +type ListMembershipsHandler interface { + Handle(ListMembershipsParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewListMemberships creates a new http.Handler for the list memberships operation +func NewListMemberships(ctx *middleware.Context, handler ListMembershipsHandler) *ListMemberships { + return &ListMemberships{Context: ctx, Handler: handler} +} + +/* + ListMemberships swagger:route GET /memberships metadata listMemberships + +ListMemberships list memberships API +*/ +type ListMemberships struct { + Context *middleware.Context + Handler ListMembershipsHandler +} + +func (o *ListMemberships) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewListMembershipsParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// ListMembershipsOKBody list memberships o k body +// +// swagger:model ListMembershipsOKBody +type ListMembershipsOKBody struct { + + // memberships + Memberships []*ListMembershipsOKBodyMembershipsItems0 `json:"memberships"` +} + +// Validate validates this list memberships o k body +func (o *ListMembershipsOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMemberships(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembershipsOKBody) validateMemberships(formats strfmt.Registry) error { + if swag.IsZero(o.Memberships) { // not required + return nil + } + + for i := 0; i < len(o.Memberships); i++ { + if swag.IsZero(o.Memberships[i]) { // not required + continue + } + + if o.Memberships[i] != nil { + if err := o.Memberships[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list memberships o k body based on the context it is used +func (o *ListMembershipsOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMemberships(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembershipsOKBody) contextValidateMemberships(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Memberships); i++ { + + if o.Memberships[i] != nil { + + if swag.IsZero(o.Memberships[i]) { // not required + return nil + } + + if err := o.Memberships[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembershipsOK" + "." + "memberships" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembershipsOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembershipsOKBody) UnmarshalBinary(b []byte) error { + var res ListMembershipsOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListMembershipsOKBodyMembershipsItems0 list memberships o k body memberships items0 +// +// swagger:model ListMembershipsOKBodyMembershipsItems0 +type ListMembershipsOKBodyMembershipsItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // description + Description string `json:"description,omitempty"` + + // token + Token string `json:"token,omitempty"` +} + +// Validate validates this list memberships o k body memberships items0 +func (o *ListMembershipsOKBodyMembershipsItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list memberships o k body memberships items0 based on context it is used +func (o *ListMembershipsOKBodyMembershipsItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembershipsOKBodyMembershipsItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembershipsOKBodyMembershipsItems0) UnmarshalBinary(b []byte) error { + var res ListMembershipsOKBodyMembershipsItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_memberships_parameters.go b/rest_server_zrok/operations/metadata/list_memberships_parameters.go new file mode 100644 index 00000000..59d3004d --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_memberships_parameters.go @@ -0,0 +1,46 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" +) + +// NewListMembershipsParams creates a new ListMembershipsParams object +// +// There are no default values defined in the spec. +func NewListMembershipsParams() ListMembershipsParams { + + return ListMembershipsParams{} +} + +// ListMembershipsParams contains all the bound params for the list memberships operation +// typically these are obtained from a http.Request +// +// swagger:parameters listMemberships +type ListMembershipsParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewListMembershipsParams() beforehand. +func (o *ListMembershipsParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_memberships_responses.go b/rest_server_zrok/operations/metadata/list_memberships_responses.go new file mode 100644 index 00000000..cd052c09 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_memberships_responses.go @@ -0,0 +1,82 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// ListMembershipsOKCode is the HTTP code returned for type ListMembershipsOK +const ListMembershipsOKCode int = 200 + +/* +ListMembershipsOK ok + +swagger:response listMembershipsOK +*/ +type ListMembershipsOK struct { + + /* + In: Body + */ + Payload *ListMembershipsOKBody `json:"body,omitempty"` +} + +// NewListMembershipsOK creates ListMembershipsOK with default headers values +func NewListMembershipsOK() *ListMembershipsOK { + + return &ListMembershipsOK{} +} + +// WithPayload adds the payload to the list memberships o k response +func (o *ListMembershipsOK) WithPayload(payload *ListMembershipsOKBody) *ListMembershipsOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the list memberships o k response +func (o *ListMembershipsOK) SetPayload(payload *ListMembershipsOKBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *ListMembershipsOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// ListMembershipsInternalServerErrorCode is the HTTP code returned for type ListMembershipsInternalServerError +const ListMembershipsInternalServerErrorCode int = 500 + +/* +ListMembershipsInternalServerError internal server error + +swagger:response listMembershipsInternalServerError +*/ +type ListMembershipsInternalServerError struct { +} + +// NewListMembershipsInternalServerError creates ListMembershipsInternalServerError with default headers values +func NewListMembershipsInternalServerError() *ListMembershipsInternalServerError { + + return &ListMembershipsInternalServerError{} +} + +// WriteResponse to the client +func (o *ListMembershipsInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/metadata/list_memberships_urlbuilder.go b/rest_server_zrok/operations/metadata/list_memberships_urlbuilder.go new file mode 100644 index 00000000..13a684d2 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_memberships_urlbuilder.go @@ -0,0 +1,87 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" +) + +// ListMembershipsURL generates an URL for the list memberships operation +type ListMembershipsURL struct { + _basePath string +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListMembershipsURL) WithBasePath(bp string) *ListMembershipsURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListMembershipsURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *ListMembershipsURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/memberships" + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *ListMembershipsURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *ListMembershipsURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *ListMembershipsURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on ListMembershipsURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on ListMembershipsURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *ListMembershipsURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index a8004b82..1e097b52 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -118,6 +118,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { AdminListFrontendsHandler: admin.ListFrontendsHandlerFunc(func(params admin.ListFrontendsParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.ListFrontends has not yet been implemented") }), + MetadataListMembershipsHandler: metadata.ListMembershipsHandlerFunc(func(params metadata.ListMembershipsParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation metadata.ListMemberships has not yet been implemented") + }), AdminListOrganizationMembersHandler: admin.ListOrganizationMembersHandlerFunc(func(params admin.ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.ListOrganizationMembers has not yet been implemented") }), @@ -265,6 +268,8 @@ type ZrokAPI struct { AdminInviteTokenGenerateHandler admin.InviteTokenGenerateHandler // AdminListFrontendsHandler sets the operation handler for the list frontends operation AdminListFrontendsHandler admin.ListFrontendsHandler + // MetadataListMembershipsHandler sets the operation handler for the list memberships operation + MetadataListMembershipsHandler metadata.ListMembershipsHandler // AdminListOrganizationMembersHandler sets the operation handler for the list organization members operation AdminListOrganizationMembersHandler admin.ListOrganizationMembersHandler // AdminListOrganizationsHandler sets the operation handler for the list organizations operation @@ -449,6 +454,9 @@ func (o *ZrokAPI) Validate() error { if o.AdminListFrontendsHandler == nil { unregistered = append(unregistered, "admin.ListFrontendsHandler") } + if o.MetadataListMembershipsHandler == nil { + unregistered = append(unregistered, "metadata.ListMembershipsHandler") + } if o.AdminListOrganizationMembersHandler == nil { unregistered = append(unregistered, "admin.ListOrganizationMembersHandler") } @@ -691,6 +699,10 @@ func (o *ZrokAPI) initHandlerCache() { o.handlers["GET"] = make(map[string]http.Handler) } o.handlers["GET"]["/frontends"] = admin.NewListFrontends(o.context, o.AdminListFrontendsHandler) + if o.handlers["GET"] == nil { + o.handlers["GET"] = make(map[string]http.Handler) + } + o.handlers["GET"]["/memberships"] = metadata.NewListMemberships(o.context, o.MetadataListMembershipsHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } diff --git a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES index bbddcaa2..1e696e01 100644 --- a/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES +++ b/sdk/nodejs/sdk/src/zrok/api/.openapi-generator/FILES @@ -28,6 +28,8 @@ model/frontend.ts model/grantsRequest.ts model/inviteRequest.ts model/inviteTokenGenerateRequest.ts +model/listMemberships200Response.ts +model/listMemberships200ResponseMembershipsInner.ts model/listOrganizationMembers200Response.ts model/listOrganizationMembers200ResponseMembersInner.ts model/listOrganizations200Response.ts diff --git a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts index e28d4dbf..5caebf4e 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts @@ -19,6 +19,7 @@ import { Configuration } from '../model/configuration'; import { Environment } from '../model/environment'; import { EnvironmentAndResources } from '../model/environmentAndResources'; import { Frontend } from '../model/frontend'; +import { ListMemberships200Response } from '../model/listMemberships200Response'; import { Metrics } from '../model/metrics'; import { Overview } from '../model/overview'; import { Share } from '../model/share'; @@ -654,6 +655,70 @@ export class MetadataApi { }); }); } + /** + * + */ + public async listMemberships (options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: ListMemberships200Response; }> { + const localVarPath = this.basePath + '/memberships'; + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'GET', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: ListMemberships200Response; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "ListMemberships200Response"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param organizationToken diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200Response.ts b/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200Response.ts new file mode 100644 index 00000000..7195a2cd --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200Response.ts @@ -0,0 +1,32 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; +import { ListMemberships200ResponseMembershipsInner } from './listMemberships200ResponseMembershipsInner'; + +export class ListMemberships200Response { + 'memberships'?: Array; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "memberships", + "baseName": "memberships", + "type": "Array" + } ]; + + static getAttributeTypeMap() { + return ListMemberships200Response.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200ResponseMembershipsInner.ts b/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200ResponseMembershipsInner.ts new file mode 100644 index 00000000..dfbb4257 --- /dev/null +++ b/sdk/nodejs/sdk/src/zrok/api/model/listMemberships200ResponseMembershipsInner.ts @@ -0,0 +1,43 @@ +/** + * zrok + * zrok client access + * + * The version of the OpenAPI document: 0.3.0 + * + * + * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). + * https://openapi-generator.tech + * Do not edit the class manually. + */ + +import { RequestFile } from './models'; + +export class ListMemberships200ResponseMembershipsInner { + 'token'?: string; + 'description'?: string; + 'admin'?: boolean; + + static discriminator: string | undefined = undefined; + + static attributeTypeMap: Array<{name: string, baseName: string, type: string}> = [ + { + "name": "token", + "baseName": "token", + "type": "string" + }, + { + "name": "description", + "baseName": "description", + "type": "string" + }, + { + "name": "admin", + "baseName": "admin", + "type": "boolean" + } ]; + + static getAttributeTypeMap() { + return ListMemberships200ResponseMembershipsInner.attributeTypeMap; + } +} + diff --git a/sdk/nodejs/sdk/src/zrok/api/model/models.ts b/sdk/nodejs/sdk/src/zrok/api/model/models.ts index 1b4baf11..74aa5b4c 100644 --- a/sdk/nodejs/sdk/src/zrok/api/model/models.ts +++ b/sdk/nodejs/sdk/src/zrok/api/model/models.ts @@ -22,6 +22,8 @@ export * from './frontend'; export * from './grantsRequest'; export * from './inviteRequest'; export * from './inviteTokenGenerateRequest'; +export * from './listMemberships200Response'; +export * from './listMemberships200ResponseMembershipsInner'; export * from './listOrganizationMembers200Response'; export * from './listOrganizationMembers200ResponseMembersInner'; export * from './listOrganizations200Response'; @@ -85,6 +87,8 @@ import { Frontend } from './frontend'; import { GrantsRequest } from './grantsRequest'; import { InviteRequest } from './inviteRequest'; import { InviteTokenGenerateRequest } from './inviteTokenGenerateRequest'; +import { ListMemberships200Response } from './listMemberships200Response'; +import { ListMemberships200ResponseMembershipsInner } from './listMemberships200ResponseMembershipsInner'; import { ListOrganizationMembers200Response } from './listOrganizationMembers200Response'; import { ListOrganizationMembers200ResponseMembersInner } from './listOrganizationMembers200ResponseMembersInner'; import { ListOrganizations200Response } from './listOrganizations200Response'; @@ -156,6 +160,8 @@ let typeMap: {[index: string]: any} = { "GrantsRequest": GrantsRequest, "InviteRequest": InviteRequest, "InviteTokenGenerateRequest": InviteTokenGenerateRequest, + "ListMemberships200Response": ListMemberships200Response, + "ListMemberships200ResponseMembershipsInner": ListMemberships200ResponseMembershipsInner, "ListOrganizationMembers200Response": ListOrganizationMembers200Response, "ListOrganizationMembers200ResponseMembersInner": ListOrganizationMembers200ResponseMembersInner, "ListOrganizations200Response": ListOrganizations200Response, diff --git a/sdk/python/sdk/zrok/zrok_api/__init__.py b/sdk/python/sdk/zrok/zrok_api/__init__.py index e97f9910..5028fe65 100644 --- a/sdk/python/sdk/zrok/zrok_api/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/__init__.py @@ -49,6 +49,8 @@ from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response2001_members import InlineResponse2001Members from zrok_api.models.inline_response2002 import InlineResponse2002 from zrok_api.models.inline_response2002_organizations import InlineResponse2002Organizations +from zrok_api.models.inline_response2003 import InlineResponse2003 +from zrok_api.models.inline_response2003_memberships import InlineResponse2003Memberships from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py index ec9236df..6798e098 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py @@ -764,6 +764,91 @@ class MetadataApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def list_memberships(self, **kwargs): # noqa: E501 + """list_memberships # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_memberships(async_req=True) + >>> result = thread.get() + + :param async_req bool + :return: InlineResponse2003 + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.list_memberships_with_http_info(**kwargs) # noqa: E501 + else: + (data) = self.list_memberships_with_http_info(**kwargs) # noqa: E501 + return data + + def list_memberships_with_http_info(self, **kwargs): # noqa: E501 + """list_memberships # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_memberships_with_http_info(async_req=True) + >>> result = thread.get() + + :param async_req bool + :return: InlineResponse2003 + If the method is called asynchronously, + returns the request thread. + """ + + all_params = [] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method list_memberships" % key + ) + params[key] = val + del params['kwargs'] + + collection_formats = {} + + path_params = {} + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/memberships', 'GET', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='InlineResponse2003', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def org_account_overview(self, organization_token, account_email, **kwargs): # noqa: E501 """org_account_overview # noqa: E501 diff --git a/sdk/python/sdk/zrok/zrok_api/models/__init__.py b/sdk/python/sdk/zrok/zrok_api/models/__init__.py index 4efe43d4..fff66b79 100644 --- a/sdk/python/sdk/zrok/zrok_api/models/__init__.py +++ b/sdk/python/sdk/zrok/zrok_api/models/__init__.py @@ -39,6 +39,8 @@ from zrok_api.models.inline_response2001 import InlineResponse2001 from zrok_api.models.inline_response2001_members import InlineResponse2001Members from zrok_api.models.inline_response2002 import InlineResponse2002 from zrok_api.models.inline_response2002_organizations import InlineResponse2002Organizations +from zrok_api.models.inline_response2003 import InlineResponse2003 +from zrok_api.models.inline_response2003_memberships import InlineResponse2003Memberships from zrok_api.models.inline_response201 import InlineResponse201 from zrok_api.models.invite_request import InviteRequest from zrok_api.models.invite_token_generate_request import InviteTokenGenerateRequest diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2003.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2003.py new file mode 100644 index 00000000..b92d8287 --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2003.py @@ -0,0 +1,110 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2003(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'memberships': 'list[InlineResponse2003Memberships]' + } + + attribute_map = { + 'memberships': 'memberships' + } + + def __init__(self, memberships=None): # noqa: E501 + """InlineResponse2003 - a model defined in Swagger""" # noqa: E501 + self._memberships = None + self.discriminator = None + if memberships is not None: + self.memberships = memberships + + @property + def memberships(self): + """Gets the memberships of this InlineResponse2003. # noqa: E501 + + + :return: The memberships of this InlineResponse2003. # noqa: E501 + :rtype: list[InlineResponse2003Memberships] + """ + return self._memberships + + @memberships.setter + def memberships(self, memberships): + """Sets the memberships of this InlineResponse2003. + + + :param memberships: The memberships of this InlineResponse2003. # noqa: E501 + :type: list[InlineResponse2003Memberships] + """ + + self._memberships = memberships + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2003, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2003): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/sdk/python/sdk/zrok/zrok_api/models/inline_response2003_memberships.py b/sdk/python/sdk/zrok/zrok_api/models/inline_response2003_memberships.py new file mode 100644 index 00000000..e7d293af --- /dev/null +++ b/sdk/python/sdk/zrok/zrok_api/models/inline_response2003_memberships.py @@ -0,0 +1,162 @@ +# coding: utf-8 + +""" + zrok + + zrok client access # noqa: E501 + + OpenAPI spec version: 0.3.0 + + Generated by: https://github.com/swagger-api/swagger-codegen.git +""" + +import pprint +import re # noqa: F401 + +import six + +class InlineResponse2003Memberships(object): + """NOTE: This class is auto generated by the swagger code generator program. + + Do not edit the class manually. + """ + """ + Attributes: + swagger_types (dict): The key is attribute name + and the value is attribute type. + attribute_map (dict): The key is attribute name + and the value is json key in definition. + """ + swagger_types = { + 'token': 'str', + 'description': 'str', + 'admin': 'bool' + } + + attribute_map = { + 'token': 'token', + 'description': 'description', + 'admin': 'admin' + } + + def __init__(self, token=None, description=None, admin=None): # noqa: E501 + """InlineResponse2003Memberships - a model defined in Swagger""" # noqa: E501 + self._token = None + self._description = None + self._admin = None + self.discriminator = None + if token is not None: + self.token = token + if description is not None: + self.description = description + if admin is not None: + self.admin = admin + + @property + def token(self): + """Gets the token of this InlineResponse2003Memberships. # noqa: E501 + + + :return: The token of this InlineResponse2003Memberships. # noqa: E501 + :rtype: str + """ + return self._token + + @token.setter + def token(self, token): + """Sets the token of this InlineResponse2003Memberships. + + + :param token: The token of this InlineResponse2003Memberships. # noqa: E501 + :type: str + """ + + self._token = token + + @property + def description(self): + """Gets the description of this InlineResponse2003Memberships. # noqa: E501 + + + :return: The description of this InlineResponse2003Memberships. # noqa: E501 + :rtype: str + """ + return self._description + + @description.setter + def description(self, description): + """Sets the description of this InlineResponse2003Memberships. + + + :param description: The description of this InlineResponse2003Memberships. # noqa: E501 + :type: str + """ + + self._description = description + + @property + def admin(self): + """Gets the admin of this InlineResponse2003Memberships. # noqa: E501 + + + :return: The admin of this InlineResponse2003Memberships. # noqa: E501 + :rtype: bool + """ + return self._admin + + @admin.setter + def admin(self, admin): + """Sets the admin of this InlineResponse2003Memberships. + + + :param admin: The admin of this InlineResponse2003Memberships. # noqa: E501 + :type: bool + """ + + self._admin = admin + + def to_dict(self): + """Returns the model properties as a dict""" + result = {} + + for attr, _ in six.iteritems(self.swagger_types): + value = getattr(self, attr) + if isinstance(value, list): + result[attr] = list(map( + lambda x: x.to_dict() if hasattr(x, "to_dict") else x, + value + )) + elif hasattr(value, "to_dict"): + result[attr] = value.to_dict() + elif isinstance(value, dict): + result[attr] = dict(map( + lambda item: (item[0], item[1].to_dict()) + if hasattr(item[1], "to_dict") else item, + value.items() + )) + else: + result[attr] = value + if issubclass(InlineResponse2003Memberships, dict): + for key, value in self.items(): + result[key] = value + + return result + + def to_str(self): + """Returns the string representation of the model""" + return pprint.pformat(self.to_dict()) + + def __repr__(self): + """For `print` and `pprint`""" + return self.to_str() + + def __eq__(self, other): + """Returns true if both objects are equal""" + if not isinstance(other, InlineResponse2003Memberships): + return False + + return self.__dict__ == other.__dict__ + + def __ne__(self, other): + """Returns true if both objects are not equal""" + return not self == other diff --git a/specs/zrok.yml b/specs/zrok.yml index 7c96e5ee..0dc59f58 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -691,6 +691,31 @@ paths: 500: description: internal server error + /memberships: + get: + tags: + - metadata + security: + - key: [] + operationId: listMemberships + responses: + 200: + description: ok + schema: + properties: + memberships: + type: array + items: + properties: + token: + type: string + description: + type: string + admin: + type: boolean + 500: + description: internal server error + /overview: get: tags: diff --git a/ui/src/api/metadata.js b/ui/src/api/metadata.js index 6ff83b76..73cd6a25 100644 --- a/ui/src/api/metadata.js +++ b/ui/src/api/metadata.js @@ -53,6 +53,12 @@ export function getShareDetail(shrToken) { return gateway.request(getShareDetailOperation, parameters) } +/** + */ +export function listMemberships() { + return gateway.request(listMembershipsOperation) +} + /** */ export function overview() { @@ -178,6 +184,16 @@ const getShareDetailOperation = { ] } +const listMembershipsOperation = { + path: '/memberships', + method: 'get', + security: [ + { + id: 'key' + } + ] +} + const overviewOperation = { path: '/overview', method: 'get', From c3c318d529455e37f47a045b78037cc12a809e18 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 13:53:45 -0500 Subject: [PATCH 16/32] 'zrok organization memberships' to list my memberships (#537) --- cmd/zrok/orgMemberships.go | 72 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 cmd/zrok/orgMemberships.go diff --git a/cmd/zrok/orgMemberships.go b/cmd/zrok/orgMemberships.go new file mode 100644 index 00000000..bafcb064 --- /dev/null +++ b/cmd/zrok/orgMemberships.go @@ -0,0 +1,72 @@ +package main + +import ( + "fmt" + httptransport "github.com/go-openapi/runtime/client" + "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/tui" + "github.com/spf13/cobra" + "os" +) + +func init() { + organizationCmd.AddCommand(newOrgMembershipsCommand().cmd) +} + +type orgMembershipsCommand struct { + cmd *cobra.Command +} + +func newOrgMembershipsCommand() *orgMembershipsCommand { + cmd := &cobra.Command{ + Use: "memberships", + Short: "List the organization memberships for my account", + Args: cobra.NoArgs, + } + command := &orgMembershipsCommand{cmd} + cmd.Run = command.run + return command +} + +func (c *orgMembershipsCommand) run(_ *cobra.Command, _ []string) { + root, err := environment.LoadRoot() + if err != nil { + if !panicInstead { + tui.Error("error loading zrokdir", err) + } + panic(err) + } + + if !root.IsEnabled() { + tui.Error("unable to load environment; did you 'zrok enable'?", nil) + } + + zrok, err := root.Client() + if err != nil { + if !panicInstead { + tui.Error("error loading zrokdir", err) + } + panic(err) + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + + in, err := zrok.Metadata.ListMemberships(nil, auth) + if err != nil { + if !panicInstead { + tui.Error("error listing memberships", err) + } + panic(err) + } + + fmt.Println() + t := table.NewWriter() + t.SetOutputMirror(os.Stdout) + t.SetStyle(table.StyleColoredDark) + t.AppendHeader(table.Row{"Token", "Description", "Admin?"}) + for _, i := range in.Payload.Memberships { + t.AppendRow(table.Row{i.Token, i.Description, i.Admin}) + } + t.Render() + fmt.Println() +} From a8ec61a8f94598661144b4467fd1a3f5822ea3a6 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 13:56:52 -0500 Subject: [PATCH 17/32] better CLI pathing for org vs org admin commands (#537) --- cmd/zrok/main.go | 8 +++++++- ...rgAccountOverview.go => orgAdminOverview.go} | 17 ++++++++--------- 2 files changed, 15 insertions(+), 10 deletions(-) rename cmd/zrok/{orgAccountOverview.go => orgAdminOverview.go} (72%) diff --git a/cmd/zrok/main.go b/cmd/zrok/main.go index a8940e88..197ef7ca 100644 --- a/cmd/zrok/main.go +++ b/cmd/zrok/main.go @@ -28,6 +28,7 @@ func init() { rootCmd.AddCommand(adminCmd) rootCmd.AddCommand(configCmd) rootCmd.AddCommand(modifyCmd) + organizationCmd.AddCommand(organizationAdminCmd) rootCmd.AddCommand(organizationCmd) rootCmd.AddCommand(shareCmd) rootCmd.AddCommand(testCmd) @@ -95,10 +96,15 @@ var modifyCmd = &cobra.Command{ Short: "Modify resources", } +var organizationAdminCmd = &cobra.Command{ + Use: "admin", + Short: "Organization admin commands", +} + var organizationCmd = &cobra.Command{ Use: "organization", Aliases: []string{"org"}, - Short: "Organization admin commands", + Short: "Organization commands", } var shareCmd = &cobra.Command{ diff --git a/cmd/zrok/orgAccountOverview.go b/cmd/zrok/orgAdminOverview.go similarity index 72% rename from cmd/zrok/orgAccountOverview.go rename to cmd/zrok/orgAdminOverview.go index 4b7d415f..372911d4 100644 --- a/cmd/zrok/orgAccountOverview.go +++ b/cmd/zrok/orgAdminOverview.go @@ -11,26 +11,25 @@ import ( ) func init() { - organizationCmd.AddCommand(newOrgAccountOverviewCommand().cmd) + organizationAdminCmd.AddCommand(newOrgAdminOverviewCommand().cmd) } -type orgAccountOverviewCommand struct { +type orgAdminOverviewCommand struct { cmd *cobra.Command } -func newOrgAccountOverviewCommand() *orgAccountOverviewCommand { +func newOrgAdminOverviewCommand() *orgAdminOverviewCommand { cmd := &cobra.Command{ - Use: "account-overview ", - Aliases: []string{"overview"}, - Short: "Retrieve account overview for organization account (requires admin)", - Args: cobra.ExactArgs(2), + Use: "overview ", + Short: "Retrieve account overview for organization account (requires admin)", + Args: cobra.ExactArgs(2), } - command := &orgAccountOverviewCommand{cmd: cmd} + command := &orgAdminOverviewCommand{cmd: cmd} cmd.Run = command.run return command } -func (cmd *orgAccountOverviewCommand) run(_ *cobra.Command, args []string) { +func (cmd *orgAdminOverviewCommand) run(_ *cobra.Command, args []string) { root, err := environment.LoadRoot() if err != nil { if !panicInstead { From 98804320a1e07bc6b32e82f506b01b34c341e5cb Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 14:15:27 -0500 Subject: [PATCH 18/32] plumbing for org admin members list (#537) --- controller/controller.go | 1 + controller/listOrgMembers.go | 51 +++ controller/orgAccountOverview.go | 2 +- .../metadata/list_members_parameters.go | 148 +++++++ .../metadata/list_members_responses.go | 377 ++++++++++++++++++ .../metadata/list_org_members_parameters.go | 148 +++++++ .../metadata/list_org_members_responses.go | 377 ++++++++++++++++++ rest_client_zrok/metadata/metadata_client.go | 41 ++ rest_server_zrok/embedded_spec.go | 91 +++++ .../operations/metadata/list_members.go | 222 +++++++++++ .../metadata/list_members_parameters.go | 71 ++++ .../metadata/list_members_responses.go | 107 +++++ .../metadata/list_members_urlbuilder.go | 99 +++++ .../operations/metadata/list_org_members.go | 222 +++++++++++ .../metadata/list_org_members_parameters.go | 71 ++++ .../metadata/list_org_members_responses.go | 107 +++++ .../metadata/list_org_members_urlbuilder.go | 99 +++++ rest_server_zrok/operations/zrok_api.go | 12 + .../sdk/src/zrok/api/api/metadataApi.ts | 72 ++++ .../sdk/zrok/zrok_api/api/metadata_api.py | 93 +++++ specs/zrok.yml | 30 ++ ui/src/api/metadata.js | 23 ++ 22 files changed, 2463 insertions(+), 1 deletion(-) create mode 100644 controller/listOrgMembers.go create mode 100644 rest_client_zrok/metadata/list_members_parameters.go create mode 100644 rest_client_zrok/metadata/list_members_responses.go create mode 100644 rest_client_zrok/metadata/list_org_members_parameters.go create mode 100644 rest_client_zrok/metadata/list_org_members_responses.go create mode 100644 rest_server_zrok/operations/metadata/list_members.go create mode 100644 rest_server_zrok/operations/metadata/list_members_parameters.go create mode 100644 rest_server_zrok/operations/metadata/list_members_responses.go create mode 100644 rest_server_zrok/operations/metadata/list_members_urlbuilder.go create mode 100644 rest_server_zrok/operations/metadata/list_org_members.go create mode 100644 rest_server_zrok/operations/metadata/list_org_members_parameters.go create mode 100644 rest_server_zrok/operations/metadata/list_org_members_responses.go create mode 100644 rest_server_zrok/operations/metadata/list_org_members_urlbuilder.go diff --git a/controller/controller.go b/controller/controller.go index 0f952c28..e72c3c6a 100644 --- a/controller/controller.go +++ b/controller/controller.go @@ -78,6 +78,7 @@ func Run(inCfg *config.Config) error { api.MetadataGetFrontendDetailHandler = newGetFrontendDetailHandler() api.MetadataGetShareDetailHandler = newShareDetailHandler() api.MetadataListMembershipsHandler = newListMembershipsHandler() + api.MetadataListOrgMembersHandler = newListOrgMembersHandler() api.MetadataOrgAccountOverviewHandler = newOrgAccountOverviewHandler() api.MetadataOverviewHandler = newOverviewHandler() api.MetadataVersionHandler = metadata.VersionHandlerFunc(versionHandler) diff --git a/controller/listOrgMembers.go b/controller/listOrgMembers.go new file mode 100644 index 00000000..0a865d62 --- /dev/null +++ b/controller/listOrgMembers.go @@ -0,0 +1,51 @@ +package controller + +import ( + "github.com/go-openapi/runtime/middleware" + "github.com/openziti/zrok/rest_model_zrok" + "github.com/openziti/zrok/rest_server_zrok/operations/metadata" + "github.com/sirupsen/logrus" +) + +type listOrgMembersHandler struct{} + +func newListOrgMembersHandler() *listOrgMembersHandler { + return &listOrgMembersHandler{} +} + +func (h *listOrgMembersHandler) Handle(params metadata.ListOrgMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + trx, err := str.Begin() + if err != nil { + logrus.Errorf("error starting transaction: %v", err) + return metadata.NewListOrgMembersInternalServerError() + } + defer func() { _ = trx.Rollback() }() + + org, err := str.FindOrganizationByToken(params.OrganizationToken, trx) + if err != nil { + logrus.Errorf("error finding organization by token: %v", err) + return metadata.NewListOrgMembersNotFound() + } + + admin, err := str.IsAccountAdminOfOrganization(int(principal.ID), org.Id, trx) + if err != nil { + logrus.Errorf("error checking account '%v' admin: %v", principal.Email, err) + return metadata.NewListOrgMembersNotFound() + } + if !admin { + logrus.Errorf("requesting account '%v' is not admin of organization '%v'", principal.Email, org.Token) + return metadata.NewOrgAccountOverviewNotFound() + } + + members, err := str.FindAccountsForOrganization(org.Id, trx) + if err != nil { + logrus.Errorf("error finding accounts for organization '%v': %v", org.Token, err) + return metadata.NewListOrgMembersInternalServerError() + } + + var out []*metadata.ListOrgMembersOKBodyMembersItems0 + for _, member := range members { + out = append(out, &metadata.ListOrgMembersOKBodyMembersItems0{Email: member.Email, Admin: member.Admin}) + } + return metadata.NewListOrgMembersOK().WithPayload(&metadata.ListOrgMembersOKBody{Members: out}) +} diff --git a/controller/orgAccountOverview.go b/controller/orgAccountOverview.go index 32d422c1..2bea8b6a 100644 --- a/controller/orgAccountOverview.go +++ b/controller/orgAccountOverview.go @@ -31,7 +31,7 @@ func (h *orgAccountOverviewHandler) Handle(params metadata.OrgAccountOverviewPar admin, err := str.IsAccountAdminOfOrganization(int(principal.ID), org.Id, trx) if err != nil { - logrus.Errorf("error checking account admin: %v", err) + logrus.Errorf("error checking account '%v' admin: %v", principal.Email, err) return metadata.NewOrgAccountOverviewNotFound() } if !admin { diff --git a/rest_client_zrok/metadata/list_members_parameters.go b/rest_client_zrok/metadata/list_members_parameters.go new file mode 100644 index 00000000..18d3ab5a --- /dev/null +++ b/rest_client_zrok/metadata/list_members_parameters.go @@ -0,0 +1,148 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewListMembersParams creates a new ListMembersParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewListMembersParams() *ListMembersParams { + return &ListMembersParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewListMembersParamsWithTimeout creates a new ListMembersParams object +// with the ability to set a timeout on a request. +func NewListMembersParamsWithTimeout(timeout time.Duration) *ListMembersParams { + return &ListMembersParams{ + timeout: timeout, + } +} + +// NewListMembersParamsWithContext creates a new ListMembersParams object +// with the ability to set a context for a request. +func NewListMembersParamsWithContext(ctx context.Context) *ListMembersParams { + return &ListMembersParams{ + Context: ctx, + } +} + +// NewListMembersParamsWithHTTPClient creates a new ListMembersParams object +// with the ability to set a custom HTTPClient for a request. +func NewListMembersParamsWithHTTPClient(client *http.Client) *ListMembersParams { + return &ListMembersParams{ + HTTPClient: client, + } +} + +/* +ListMembersParams contains all the parameters to send to the API endpoint + + for the list members operation. + + Typically these are written to a http.Request. +*/ +type ListMembersParams struct { + + // OrganizationToken. + OrganizationToken string + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the list members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListMembersParams) WithDefaults() *ListMembersParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the list members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListMembersParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the list members params +func (o *ListMembersParams) WithTimeout(timeout time.Duration) *ListMembersParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the list members params +func (o *ListMembersParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the list members params +func (o *ListMembersParams) WithContext(ctx context.Context) *ListMembersParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the list members params +func (o *ListMembersParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the list members params +func (o *ListMembersParams) WithHTTPClient(client *http.Client) *ListMembersParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the list members params +func (o *ListMembersParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithOrganizationToken adds the organizationToken to the list members params +func (o *ListMembersParams) WithOrganizationToken(organizationToken string) *ListMembersParams { + o.SetOrganizationToken(organizationToken) + return o +} + +// SetOrganizationToken adds the organizationToken to the list members params +func (o *ListMembersParams) SetOrganizationToken(organizationToken string) { + o.OrganizationToken = organizationToken +} + +// WriteToRequest writes these params to a swagger request +func (o *ListMembersParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + + // path param organizationToken + if err := r.SetPathParam("organizationToken", o.OrganizationToken); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/metadata/list_members_responses.go b/rest_client_zrok/metadata/list_members_responses.go new file mode 100644 index 00000000..0086f112 --- /dev/null +++ b/rest_client_zrok/metadata/list_members_responses.go @@ -0,0 +1,377 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// ListMembersReader is a Reader for the ListMembers structure. +type ListMembersReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *ListMembersReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewListMembersOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 404: + result := NewListMembersNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewListMembersInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[GET /members/{organizationToken}] listMembers", response, response.Code()) + } +} + +// NewListMembersOK creates a ListMembersOK with default headers values +func NewListMembersOK() *ListMembersOK { + return &ListMembersOK{} +} + +/* +ListMembersOK describes a response with status code 200, with default header values. + +ok +*/ +type ListMembersOK struct { + Payload *ListMembersOKBody +} + +// IsSuccess returns true when this list members o k response has a 2xx status code +func (o *ListMembersOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this list members o k response has a 3xx status code +func (o *ListMembersOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list members o k response has a 4xx status code +func (o *ListMembersOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this list members o k response has a 5xx status code +func (o *ListMembersOK) IsServerError() bool { + return false +} + +// IsCode returns true when this list members o k response a status code equal to that given +func (o *ListMembersOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the list members o k response +func (o *ListMembersOK) Code() int { + return 200 +} + +func (o *ListMembersOK) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersOK %+v", 200, o.Payload) +} + +func (o *ListMembersOK) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersOK %+v", 200, o.Payload) +} + +func (o *ListMembersOK) GetPayload() *ListMembersOKBody { + return o.Payload +} + +func (o *ListMembersOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(ListMembersOKBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewListMembersNotFound creates a ListMembersNotFound with default headers values +func NewListMembersNotFound() *ListMembersNotFound { + return &ListMembersNotFound{} +} + +/* +ListMembersNotFound describes a response with status code 404, with default header values. + +not found +*/ +type ListMembersNotFound struct { +} + +// IsSuccess returns true when this list members not found response has a 2xx status code +func (o *ListMembersNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list members not found response has a 3xx status code +func (o *ListMembersNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list members not found response has a 4xx status code +func (o *ListMembersNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this list members not found response has a 5xx status code +func (o *ListMembersNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this list members not found response a status code equal to that given +func (o *ListMembersNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the list members not found response +func (o *ListMembersNotFound) Code() int { + return 404 +} + +func (o *ListMembersNotFound) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersNotFound ", 404) +} + +func (o *ListMembersNotFound) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersNotFound ", 404) +} + +func (o *ListMembersNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewListMembersInternalServerError creates a ListMembersInternalServerError with default headers values +func NewListMembersInternalServerError() *ListMembersInternalServerError { + return &ListMembersInternalServerError{} +} + +/* +ListMembersInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type ListMembersInternalServerError struct { +} + +// IsSuccess returns true when this list members internal server error response has a 2xx status code +func (o *ListMembersInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list members internal server error response has a 3xx status code +func (o *ListMembersInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list members internal server error response has a 4xx status code +func (o *ListMembersInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this list members internal server error response has a 5xx status code +func (o *ListMembersInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this list members internal server error response a status code equal to that given +func (o *ListMembersInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the list members internal server error response +func (o *ListMembersInternalServerError) Code() int { + return 500 +} + +func (o *ListMembersInternalServerError) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersInternalServerError ", 500) +} + +func (o *ListMembersInternalServerError) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listMembersInternalServerError ", 500) +} + +func (o *ListMembersInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +ListMembersOKBody list members o k body +swagger:model ListMembersOKBody +*/ +type ListMembersOKBody struct { + + // members + Members []*ListMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list members o k body +func (o *ListMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list members o k body based on the context it is used +func (o *ListMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListMembersOKBodyMembersItems0 list members o k body members items0 +swagger:model ListMembersOKBodyMembersItems0 +*/ +type ListMembersOKBodyMembersItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list members o k body members items0 +func (o *ListMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list members o k body members items0 based on context it is used +func (o *ListMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/metadata/list_org_members_parameters.go b/rest_client_zrok/metadata/list_org_members_parameters.go new file mode 100644 index 00000000..bdf3a60f --- /dev/null +++ b/rest_client_zrok/metadata/list_org_members_parameters.go @@ -0,0 +1,148 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "net/http" + "time" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + cr "github.com/go-openapi/runtime/client" + "github.com/go-openapi/strfmt" +) + +// NewListOrgMembersParams creates a new ListOrgMembersParams object, +// with the default timeout for this client. +// +// Default values are not hydrated, since defaults are normally applied by the API server side. +// +// To enforce default values in parameter, use SetDefaults or WithDefaults. +func NewListOrgMembersParams() *ListOrgMembersParams { + return &ListOrgMembersParams{ + timeout: cr.DefaultTimeout, + } +} + +// NewListOrgMembersParamsWithTimeout creates a new ListOrgMembersParams object +// with the ability to set a timeout on a request. +func NewListOrgMembersParamsWithTimeout(timeout time.Duration) *ListOrgMembersParams { + return &ListOrgMembersParams{ + timeout: timeout, + } +} + +// NewListOrgMembersParamsWithContext creates a new ListOrgMembersParams object +// with the ability to set a context for a request. +func NewListOrgMembersParamsWithContext(ctx context.Context) *ListOrgMembersParams { + return &ListOrgMembersParams{ + Context: ctx, + } +} + +// NewListOrgMembersParamsWithHTTPClient creates a new ListOrgMembersParams object +// with the ability to set a custom HTTPClient for a request. +func NewListOrgMembersParamsWithHTTPClient(client *http.Client) *ListOrgMembersParams { + return &ListOrgMembersParams{ + HTTPClient: client, + } +} + +/* +ListOrgMembersParams contains all the parameters to send to the API endpoint + + for the list org members operation. + + Typically these are written to a http.Request. +*/ +type ListOrgMembersParams struct { + + // OrganizationToken. + OrganizationToken string + + timeout time.Duration + Context context.Context + HTTPClient *http.Client +} + +// WithDefaults hydrates default values in the list org members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrgMembersParams) WithDefaults() *ListOrgMembersParams { + o.SetDefaults() + return o +} + +// SetDefaults hydrates default values in the list org members params (not the query body). +// +// All values with no default are reset to their zero value. +func (o *ListOrgMembersParams) SetDefaults() { + // no default values defined for this parameter +} + +// WithTimeout adds the timeout to the list org members params +func (o *ListOrgMembersParams) WithTimeout(timeout time.Duration) *ListOrgMembersParams { + o.SetTimeout(timeout) + return o +} + +// SetTimeout adds the timeout to the list org members params +func (o *ListOrgMembersParams) SetTimeout(timeout time.Duration) { + o.timeout = timeout +} + +// WithContext adds the context to the list org members params +func (o *ListOrgMembersParams) WithContext(ctx context.Context) *ListOrgMembersParams { + o.SetContext(ctx) + return o +} + +// SetContext adds the context to the list org members params +func (o *ListOrgMembersParams) SetContext(ctx context.Context) { + o.Context = ctx +} + +// WithHTTPClient adds the HTTPClient to the list org members params +func (o *ListOrgMembersParams) WithHTTPClient(client *http.Client) *ListOrgMembersParams { + o.SetHTTPClient(client) + return o +} + +// SetHTTPClient adds the HTTPClient to the list org members params +func (o *ListOrgMembersParams) SetHTTPClient(client *http.Client) { + o.HTTPClient = client +} + +// WithOrganizationToken adds the organizationToken to the list org members params +func (o *ListOrgMembersParams) WithOrganizationToken(organizationToken string) *ListOrgMembersParams { + o.SetOrganizationToken(organizationToken) + return o +} + +// SetOrganizationToken adds the organizationToken to the list org members params +func (o *ListOrgMembersParams) SetOrganizationToken(organizationToken string) { + o.OrganizationToken = organizationToken +} + +// WriteToRequest writes these params to a swagger request +func (o *ListOrgMembersParams) WriteToRequest(r runtime.ClientRequest, reg strfmt.Registry) error { + + if err := r.SetTimeout(o.timeout); err != nil { + return err + } + var res []error + + // path param organizationToken + if err := r.SetPathParam("organizationToken", o.OrganizationToken); err != nil { + return err + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} diff --git a/rest_client_zrok/metadata/list_org_members_responses.go b/rest_client_zrok/metadata/list_org_members_responses.go new file mode 100644 index 00000000..138ef025 --- /dev/null +++ b/rest_client_zrok/metadata/list_org_members_responses.go @@ -0,0 +1,377 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "context" + "fmt" + "io" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" +) + +// ListOrgMembersReader is a Reader for the ListOrgMembers structure. +type ListOrgMembersReader struct { + formats strfmt.Registry +} + +// ReadResponse reads a server response into the received o. +func (o *ListOrgMembersReader) ReadResponse(response runtime.ClientResponse, consumer runtime.Consumer) (interface{}, error) { + switch response.Code() { + case 200: + result := NewListOrgMembersOK() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return result, nil + case 404: + result := NewListOrgMembersNotFound() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + case 500: + result := NewListOrgMembersInternalServerError() + if err := result.readResponse(response, consumer, o.formats); err != nil { + return nil, err + } + return nil, result + default: + return nil, runtime.NewAPIError("[GET /members/{organizationToken}] listOrgMembers", response, response.Code()) + } +} + +// NewListOrgMembersOK creates a ListOrgMembersOK with default headers values +func NewListOrgMembersOK() *ListOrgMembersOK { + return &ListOrgMembersOK{} +} + +/* +ListOrgMembersOK describes a response with status code 200, with default header values. + +ok +*/ +type ListOrgMembersOK struct { + Payload *ListOrgMembersOKBody +} + +// IsSuccess returns true when this list org members o k response has a 2xx status code +func (o *ListOrgMembersOK) IsSuccess() bool { + return true +} + +// IsRedirect returns true when this list org members o k response has a 3xx status code +func (o *ListOrgMembersOK) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list org members o k response has a 4xx status code +func (o *ListOrgMembersOK) IsClientError() bool { + return false +} + +// IsServerError returns true when this list org members o k response has a 5xx status code +func (o *ListOrgMembersOK) IsServerError() bool { + return false +} + +// IsCode returns true when this list org members o k response a status code equal to that given +func (o *ListOrgMembersOK) IsCode(code int) bool { + return code == 200 +} + +// Code gets the status code for the list org members o k response +func (o *ListOrgMembersOK) Code() int { + return 200 +} + +func (o *ListOrgMembersOK) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersOK %+v", 200, o.Payload) +} + +func (o *ListOrgMembersOK) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersOK %+v", 200, o.Payload) +} + +func (o *ListOrgMembersOK) GetPayload() *ListOrgMembersOKBody { + return o.Payload +} + +func (o *ListOrgMembersOK) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + o.Payload = new(ListOrgMembersOKBody) + + // response payload + if err := consumer.Consume(response.Body(), o.Payload); err != nil && err != io.EOF { + return err + } + + return nil +} + +// NewListOrgMembersNotFound creates a ListOrgMembersNotFound with default headers values +func NewListOrgMembersNotFound() *ListOrgMembersNotFound { + return &ListOrgMembersNotFound{} +} + +/* +ListOrgMembersNotFound describes a response with status code 404, with default header values. + +not found +*/ +type ListOrgMembersNotFound struct { +} + +// IsSuccess returns true when this list org members not found response has a 2xx status code +func (o *ListOrgMembersNotFound) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list org members not found response has a 3xx status code +func (o *ListOrgMembersNotFound) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list org members not found response has a 4xx status code +func (o *ListOrgMembersNotFound) IsClientError() bool { + return true +} + +// IsServerError returns true when this list org members not found response has a 5xx status code +func (o *ListOrgMembersNotFound) IsServerError() bool { + return false +} + +// IsCode returns true when this list org members not found response a status code equal to that given +func (o *ListOrgMembersNotFound) IsCode(code int) bool { + return code == 404 +} + +// Code gets the status code for the list org members not found response +func (o *ListOrgMembersNotFound) Code() int { + return 404 +} + +func (o *ListOrgMembersNotFound) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersNotFound ", 404) +} + +func (o *ListOrgMembersNotFound) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersNotFound ", 404) +} + +func (o *ListOrgMembersNotFound) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +// NewListOrgMembersInternalServerError creates a ListOrgMembersInternalServerError with default headers values +func NewListOrgMembersInternalServerError() *ListOrgMembersInternalServerError { + return &ListOrgMembersInternalServerError{} +} + +/* +ListOrgMembersInternalServerError describes a response with status code 500, with default header values. + +internal server error +*/ +type ListOrgMembersInternalServerError struct { +} + +// IsSuccess returns true when this list org members internal server error response has a 2xx status code +func (o *ListOrgMembersInternalServerError) IsSuccess() bool { + return false +} + +// IsRedirect returns true when this list org members internal server error response has a 3xx status code +func (o *ListOrgMembersInternalServerError) IsRedirect() bool { + return false +} + +// IsClientError returns true when this list org members internal server error response has a 4xx status code +func (o *ListOrgMembersInternalServerError) IsClientError() bool { + return false +} + +// IsServerError returns true when this list org members internal server error response has a 5xx status code +func (o *ListOrgMembersInternalServerError) IsServerError() bool { + return true +} + +// IsCode returns true when this list org members internal server error response a status code equal to that given +func (o *ListOrgMembersInternalServerError) IsCode(code int) bool { + return code == 500 +} + +// Code gets the status code for the list org members internal server error response +func (o *ListOrgMembersInternalServerError) Code() int { + return 500 +} + +func (o *ListOrgMembersInternalServerError) Error() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersInternalServerError ", 500) +} + +func (o *ListOrgMembersInternalServerError) String() string { + return fmt.Sprintf("[GET /members/{organizationToken}][%d] listOrgMembersInternalServerError ", 500) +} + +func (o *ListOrgMembersInternalServerError) readResponse(response runtime.ClientResponse, consumer runtime.Consumer, formats strfmt.Registry) error { + + return nil +} + +/* +ListOrgMembersOKBody list org members o k body +swagger:model ListOrgMembersOKBody +*/ +type ListOrgMembersOKBody struct { + + // members + Members []*ListOrgMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list org members o k body +func (o *ListOrgMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrgMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list org members o k body based on the context it is used +func (o *ListOrgMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrgMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrgMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrgMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListOrgMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +/* +ListOrgMembersOKBodyMembersItems0 list org members o k body members items0 +swagger:model ListOrgMembersOKBodyMembersItems0 +*/ +type ListOrgMembersOKBodyMembersItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list org members o k body members items0 +func (o *ListOrgMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list org members o k body members items0 based on context it is used +func (o *ListOrgMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrgMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrgMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListOrgMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_client_zrok/metadata/metadata_client.go b/rest_client_zrok/metadata/metadata_client.go index 4706380a..9e69c04e 100644 --- a/rest_client_zrok/metadata/metadata_client.go +++ b/rest_client_zrok/metadata/metadata_client.go @@ -48,6 +48,8 @@ type ClientService interface { ListMemberships(params *ListMembershipsParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListMembershipsOK, error) + ListOrgMembers(params *ListOrgMembersParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrgMembersOK, error) + OrgAccountOverview(params *OrgAccountOverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OrgAccountOverviewOK, error) Overview(params *OverviewParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*OverviewOK, error) @@ -407,6 +409,45 @@ func (a *Client) ListMemberships(params *ListMembershipsParams, authInfo runtime panic(msg) } +/* +ListOrgMembers list org members API +*/ +func (a *Client) ListOrgMembers(params *ListOrgMembersParams, authInfo runtime.ClientAuthInfoWriter, opts ...ClientOption) (*ListOrgMembersOK, error) { + // TODO: Validate the params before sending + if params == nil { + params = NewListOrgMembersParams() + } + op := &runtime.ClientOperation{ + ID: "listOrgMembers", + Method: "GET", + PathPattern: "/members/{organizationToken}", + ProducesMediaTypes: []string{"application/zrok.v1+json"}, + ConsumesMediaTypes: []string{"application/zrok.v1+json"}, + Schemes: []string{"http"}, + Params: params, + Reader: &ListOrgMembersReader{formats: a.formats}, + AuthInfo: authInfo, + Context: params.Context, + Client: params.HTTPClient, + } + for _, opt := range opts { + opt(op) + } + + result, err := a.transport.Submit(op) + if err != nil { + return nil, err + } + success, ok := result.(*ListOrgMembersOK) + if ok { + return success, nil + } + // unexpected success response + // safeguard: normally, absent a default response, unknown success responses return an error above: so this is a codegen issue + msg := fmt.Sprintf("unexpected success response for listOrgMembers: API contract not enforced by server. Client expected to get an error, but got: %T", result) + panic(msg) +} + /* OrgAccountOverview org account overview API */ diff --git a/rest_server_zrok/embedded_spec.go b/rest_server_zrok/embedded_spec.go index 68d4556c..3879712e 100644 --- a/rest_server_zrok/embedded_spec.go +++ b/rest_server_zrok/embedded_spec.go @@ -711,6 +711,55 @@ func init() { } } }, + "/members/{organizationToken}": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "listOrgMembers", + "parameters": [ + { + "type": "string", + "name": "organizationToken", + "in": "path", + "required": true + } + ], + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "members": { + "type": "array", + "items": { + "properties": { + "admin": { + "type": "boolean" + }, + "email": { + "type": "string" + } + } + } + } + } + } + }, + "404": { + "description": "not found" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/memberships": { "get": { "security": [ @@ -2912,6 +2961,48 @@ func init() { } } }, + "/members/{organizationToken}": { + "get": { + "security": [ + { + "key": [] + } + ], + "tags": [ + "metadata" + ], + "operationId": "listOrgMembers", + "parameters": [ + { + "type": "string", + "name": "organizationToken", + "in": "path", + "required": true + } + ], + "responses": { + "200": { + "description": "ok", + "schema": { + "properties": { + "members": { + "type": "array", + "items": { + "$ref": "#/definitions/MembersItems0" + } + } + } + } + }, + "404": { + "description": "not found" + }, + "500": { + "description": "internal server error" + } + } + } + }, "/memberships": { "get": { "security": [ diff --git a/rest_server_zrok/operations/metadata/list_members.go b/rest_server_zrok/operations/metadata/list_members.go new file mode 100644 index 00000000..8a841a79 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_members.go @@ -0,0 +1,222 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// ListMembersHandlerFunc turns a function with the right signature into a list members handler +type ListMembersHandlerFunc func(ListMembersParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn ListMembersHandlerFunc) Handle(params ListMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// ListMembersHandler interface for that can handle valid list members params +type ListMembersHandler interface { + Handle(ListMembersParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewListMembers creates a new http.Handler for the list members operation +func NewListMembers(ctx *middleware.Context, handler ListMembersHandler) *ListMembers { + return &ListMembers{Context: ctx, Handler: handler} +} + +/* + ListMembers swagger:route GET /members/{organizationToken} metadata listMembers + +ListMembers list members API +*/ +type ListMembers struct { + Context *middleware.Context + Handler ListMembersHandler +} + +func (o *ListMembers) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewListMembersParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// ListMembersOKBody list members o k body +// +// swagger:model ListMembersOKBody +type ListMembersOKBody struct { + + // members + Members []*ListMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list members o k body +func (o *ListMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list members o k body based on the context it is used +func (o *ListMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListMembersOKBodyMembersItems0 list members o k body members items0 +// +// swagger:model ListMembersOKBodyMembersItems0 +type ListMembersOKBodyMembersItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list members o k body members items0 +func (o *ListMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list members o k body members items0 based on context it is used +func (o *ListMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_members_parameters.go b/rest_server_zrok/operations/metadata/list_members_parameters.go new file mode 100644 index 00000000..6ab6b2b2 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_members_parameters.go @@ -0,0 +1,71 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" +) + +// NewListMembersParams creates a new ListMembersParams object +// +// There are no default values defined in the spec. +func NewListMembersParams() ListMembersParams { + + return ListMembersParams{} +} + +// ListMembersParams contains all the bound params for the list members operation +// typically these are obtained from a http.Request +// +// swagger:parameters listMembers +type ListMembersParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + Required: true + In: path + */ + OrganizationToken string +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewListMembersParams() beforehand. +func (o *ListMembersParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + rOrganizationToken, rhkOrganizationToken, _ := route.Params.GetOK("organizationToken") + if err := o.bindOrganizationToken(rOrganizationToken, rhkOrganizationToken, route.Formats); err != nil { + res = append(res, err) + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +// bindOrganizationToken binds and validates parameter OrganizationToken from path. +func (o *ListMembersParams) bindOrganizationToken(rawData []string, hasKey bool, formats strfmt.Registry) error { + var raw string + if len(rawData) > 0 { + raw = rawData[len(rawData)-1] + } + + // Required: true + // Parameter is provided by construction from the route + o.OrganizationToken = raw + + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_members_responses.go b/rest_server_zrok/operations/metadata/list_members_responses.go new file mode 100644 index 00000000..be67d254 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_members_responses.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// ListMembersOKCode is the HTTP code returned for type ListMembersOK +const ListMembersOKCode int = 200 + +/* +ListMembersOK ok + +swagger:response listMembersOK +*/ +type ListMembersOK struct { + + /* + In: Body + */ + Payload *ListMembersOKBody `json:"body,omitempty"` +} + +// NewListMembersOK creates ListMembersOK with default headers values +func NewListMembersOK() *ListMembersOK { + + return &ListMembersOK{} +} + +// WithPayload adds the payload to the list members o k response +func (o *ListMembersOK) WithPayload(payload *ListMembersOKBody) *ListMembersOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the list members o k response +func (o *ListMembersOK) SetPayload(payload *ListMembersOKBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *ListMembersOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// ListMembersNotFoundCode is the HTTP code returned for type ListMembersNotFound +const ListMembersNotFoundCode int = 404 + +/* +ListMembersNotFound not found + +swagger:response listMembersNotFound +*/ +type ListMembersNotFound struct { +} + +// NewListMembersNotFound creates ListMembersNotFound with default headers values +func NewListMembersNotFound() *ListMembersNotFound { + + return &ListMembersNotFound{} +} + +// WriteResponse to the client +func (o *ListMembersNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + +// ListMembersInternalServerErrorCode is the HTTP code returned for type ListMembersInternalServerError +const ListMembersInternalServerErrorCode int = 500 + +/* +ListMembersInternalServerError internal server error + +swagger:response listMembersInternalServerError +*/ +type ListMembersInternalServerError struct { +} + +// NewListMembersInternalServerError creates ListMembersInternalServerError with default headers values +func NewListMembersInternalServerError() *ListMembersInternalServerError { + + return &ListMembersInternalServerError{} +} + +// WriteResponse to the client +func (o *ListMembersInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/metadata/list_members_urlbuilder.go b/rest_server_zrok/operations/metadata/list_members_urlbuilder.go new file mode 100644 index 00000000..f191a954 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_members_urlbuilder.go @@ -0,0 +1,99 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" + "strings" +) + +// ListMembersURL generates an URL for the list members operation +type ListMembersURL struct { + OrganizationToken string + + _basePath string + // avoid unkeyed usage + _ struct{} +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListMembersURL) WithBasePath(bp string) *ListMembersURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListMembersURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *ListMembersURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/members/{organizationToken}" + + organizationToken := o.OrganizationToken + if organizationToken != "" { + _path = strings.Replace(_path, "{organizationToken}", organizationToken, -1) + } else { + return nil, errors.New("organizationToken is required on ListMembersURL") + } + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *ListMembersURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *ListMembersURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *ListMembersURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on ListMembersURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on ListMembersURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *ListMembersURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/metadata/list_org_members.go b/rest_server_zrok/operations/metadata/list_org_members.go new file mode 100644 index 00000000..9206420a --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_org_members.go @@ -0,0 +1,222 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "context" + "net/http" + "strconv" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" + "github.com/go-openapi/swag" + + "github.com/openziti/zrok/rest_model_zrok" +) + +// ListOrgMembersHandlerFunc turns a function with the right signature into a list org members handler +type ListOrgMembersHandlerFunc func(ListOrgMembersParams, *rest_model_zrok.Principal) middleware.Responder + +// Handle executing the request and returning a response +func (fn ListOrgMembersHandlerFunc) Handle(params ListOrgMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + return fn(params, principal) +} + +// ListOrgMembersHandler interface for that can handle valid list org members params +type ListOrgMembersHandler interface { + Handle(ListOrgMembersParams, *rest_model_zrok.Principal) middleware.Responder +} + +// NewListOrgMembers creates a new http.Handler for the list org members operation +func NewListOrgMembers(ctx *middleware.Context, handler ListOrgMembersHandler) *ListOrgMembers { + return &ListOrgMembers{Context: ctx, Handler: handler} +} + +/* + ListOrgMembers swagger:route GET /members/{organizationToken} metadata listOrgMembers + +ListOrgMembers list org members API +*/ +type ListOrgMembers struct { + Context *middleware.Context + Handler ListOrgMembersHandler +} + +func (o *ListOrgMembers) ServeHTTP(rw http.ResponseWriter, r *http.Request) { + route, rCtx, _ := o.Context.RouteInfo(r) + if rCtx != nil { + *r = *rCtx + } + var Params = NewListOrgMembersParams() + uprinc, aCtx, err := o.Context.Authorize(r, route) + if err != nil { + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + if aCtx != nil { + *r = *aCtx + } + var principal *rest_model_zrok.Principal + if uprinc != nil { + principal = uprinc.(*rest_model_zrok.Principal) // this is really a rest_model_zrok.Principal, I promise + } + + if err := o.Context.BindValidRequest(r, route, &Params); err != nil { // bind params + o.Context.Respond(rw, r, route.Produces, route, err) + return + } + + res := o.Handler.Handle(Params, principal) // actually handle the request + o.Context.Respond(rw, r, route.Produces, route, res) + +} + +// ListOrgMembersOKBody list org members o k body +// +// swagger:model ListOrgMembersOKBody +type ListOrgMembersOKBody struct { + + // members + Members []*ListOrgMembersOKBodyMembersItems0 `json:"members"` +} + +// Validate validates this list org members o k body +func (o *ListOrgMembersOKBody) Validate(formats strfmt.Registry) error { + var res []error + + if err := o.validateMembers(formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrgMembersOKBody) validateMembers(formats strfmt.Registry) error { + if swag.IsZero(o.Members) { // not required + return nil + } + + for i := 0; i < len(o.Members); i++ { + if swag.IsZero(o.Members[i]) { // not required + continue + } + + if o.Members[i] != nil { + if err := o.Members[i].Validate(formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// ContextValidate validate this list org members o k body based on the context it is used +func (o *ListOrgMembersOKBody) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + var res []error + + if err := o.contextValidateMembers(ctx, formats); err != nil { + res = append(res, err) + } + + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +func (o *ListOrgMembersOKBody) contextValidateMembers(ctx context.Context, formats strfmt.Registry) error { + + for i := 0; i < len(o.Members); i++ { + + if o.Members[i] != nil { + + if swag.IsZero(o.Members[i]) { // not required + return nil + } + + if err := o.Members[i].ContextValidate(ctx, formats); err != nil { + if ve, ok := err.(*errors.Validation); ok { + return ve.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } else if ce, ok := err.(*errors.CompositeError); ok { + return ce.ValidateName("listOrgMembersOK" + "." + "members" + "." + strconv.Itoa(i)) + } + return err + } + } + + } + + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrgMembersOKBody) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrgMembersOKBody) UnmarshalBinary(b []byte) error { + var res ListOrgMembersOKBody + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} + +// ListOrgMembersOKBodyMembersItems0 list org members o k body members items0 +// +// swagger:model ListOrgMembersOKBodyMembersItems0 +type ListOrgMembersOKBodyMembersItems0 struct { + + // admin + Admin bool `json:"admin,omitempty"` + + // email + Email string `json:"email,omitempty"` +} + +// Validate validates this list org members o k body members items0 +func (o *ListOrgMembersOKBodyMembersItems0) Validate(formats strfmt.Registry) error { + return nil +} + +// ContextValidate validates this list org members o k body members items0 based on context it is used +func (o *ListOrgMembersOKBodyMembersItems0) ContextValidate(ctx context.Context, formats strfmt.Registry) error { + return nil +} + +// MarshalBinary interface implementation +func (o *ListOrgMembersOKBodyMembersItems0) MarshalBinary() ([]byte, error) { + if o == nil { + return nil, nil + } + return swag.WriteJSON(o) +} + +// UnmarshalBinary interface implementation +func (o *ListOrgMembersOKBodyMembersItems0) UnmarshalBinary(b []byte) error { + var res ListOrgMembersOKBodyMembersItems0 + if err := swag.ReadJSON(b, &res); err != nil { + return err + } + *o = res + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_org_members_parameters.go b/rest_server_zrok/operations/metadata/list_org_members_parameters.go new file mode 100644 index 00000000..b83e9ddf --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_org_members_parameters.go @@ -0,0 +1,71 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/errors" + "github.com/go-openapi/runtime/middleware" + "github.com/go-openapi/strfmt" +) + +// NewListOrgMembersParams creates a new ListOrgMembersParams object +// +// There are no default values defined in the spec. +func NewListOrgMembersParams() ListOrgMembersParams { + + return ListOrgMembersParams{} +} + +// ListOrgMembersParams contains all the bound params for the list org members operation +// typically these are obtained from a http.Request +// +// swagger:parameters listOrgMembers +type ListOrgMembersParams struct { + + // HTTP Request Object + HTTPRequest *http.Request `json:"-"` + + /* + Required: true + In: path + */ + OrganizationToken string +} + +// BindRequest both binds and validates a request, it assumes that complex things implement a Validatable(strfmt.Registry) error interface +// for simple values it will use straight method calls. +// +// To ensure default values, the struct must have been initialized with NewListOrgMembersParams() beforehand. +func (o *ListOrgMembersParams) BindRequest(r *http.Request, route *middleware.MatchedRoute) error { + var res []error + + o.HTTPRequest = r + + rOrganizationToken, rhkOrganizationToken, _ := route.Params.GetOK("organizationToken") + if err := o.bindOrganizationToken(rOrganizationToken, rhkOrganizationToken, route.Formats); err != nil { + res = append(res, err) + } + if len(res) > 0 { + return errors.CompositeValidationError(res...) + } + return nil +} + +// bindOrganizationToken binds and validates parameter OrganizationToken from path. +func (o *ListOrgMembersParams) bindOrganizationToken(rawData []string, hasKey bool, formats strfmt.Registry) error { + var raw string + if len(rawData) > 0 { + raw = rawData[len(rawData)-1] + } + + // Required: true + // Parameter is provided by construction from the route + o.OrganizationToken = raw + + return nil +} diff --git a/rest_server_zrok/operations/metadata/list_org_members_responses.go b/rest_server_zrok/operations/metadata/list_org_members_responses.go new file mode 100644 index 00000000..af700800 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_org_members_responses.go @@ -0,0 +1,107 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the swagger generate command + +import ( + "net/http" + + "github.com/go-openapi/runtime" +) + +// ListOrgMembersOKCode is the HTTP code returned for type ListOrgMembersOK +const ListOrgMembersOKCode int = 200 + +/* +ListOrgMembersOK ok + +swagger:response listOrgMembersOK +*/ +type ListOrgMembersOK struct { + + /* + In: Body + */ + Payload *ListOrgMembersOKBody `json:"body,omitempty"` +} + +// NewListOrgMembersOK creates ListOrgMembersOK with default headers values +func NewListOrgMembersOK() *ListOrgMembersOK { + + return &ListOrgMembersOK{} +} + +// WithPayload adds the payload to the list org members o k response +func (o *ListOrgMembersOK) WithPayload(payload *ListOrgMembersOKBody) *ListOrgMembersOK { + o.Payload = payload + return o +} + +// SetPayload sets the payload to the list org members o k response +func (o *ListOrgMembersOK) SetPayload(payload *ListOrgMembersOKBody) { + o.Payload = payload +} + +// WriteResponse to the client +func (o *ListOrgMembersOK) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.WriteHeader(200) + if o.Payload != nil { + payload := o.Payload + if err := producer.Produce(rw, payload); err != nil { + panic(err) // let the recovery middleware deal with this + } + } +} + +// ListOrgMembersNotFoundCode is the HTTP code returned for type ListOrgMembersNotFound +const ListOrgMembersNotFoundCode int = 404 + +/* +ListOrgMembersNotFound not found + +swagger:response listOrgMembersNotFound +*/ +type ListOrgMembersNotFound struct { +} + +// NewListOrgMembersNotFound creates ListOrgMembersNotFound with default headers values +func NewListOrgMembersNotFound() *ListOrgMembersNotFound { + + return &ListOrgMembersNotFound{} +} + +// WriteResponse to the client +func (o *ListOrgMembersNotFound) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(404) +} + +// ListOrgMembersInternalServerErrorCode is the HTTP code returned for type ListOrgMembersInternalServerError +const ListOrgMembersInternalServerErrorCode int = 500 + +/* +ListOrgMembersInternalServerError internal server error + +swagger:response listOrgMembersInternalServerError +*/ +type ListOrgMembersInternalServerError struct { +} + +// NewListOrgMembersInternalServerError creates ListOrgMembersInternalServerError with default headers values +func NewListOrgMembersInternalServerError() *ListOrgMembersInternalServerError { + + return &ListOrgMembersInternalServerError{} +} + +// WriteResponse to the client +func (o *ListOrgMembersInternalServerError) WriteResponse(rw http.ResponseWriter, producer runtime.Producer) { + + rw.Header().Del(runtime.HeaderContentType) //Remove Content-Type on empty responses + + rw.WriteHeader(500) +} diff --git a/rest_server_zrok/operations/metadata/list_org_members_urlbuilder.go b/rest_server_zrok/operations/metadata/list_org_members_urlbuilder.go new file mode 100644 index 00000000..6cc2f165 --- /dev/null +++ b/rest_server_zrok/operations/metadata/list_org_members_urlbuilder.go @@ -0,0 +1,99 @@ +// Code generated by go-swagger; DO NOT EDIT. + +package metadata + +// This file was generated by the swagger tool. +// Editing this file might prove futile when you re-run the generate command + +import ( + "errors" + "net/url" + golangswaggerpaths "path" + "strings" +) + +// ListOrgMembersURL generates an URL for the list org members operation +type ListOrgMembersURL struct { + OrganizationToken string + + _basePath string + // avoid unkeyed usage + _ struct{} +} + +// WithBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrgMembersURL) WithBasePath(bp string) *ListOrgMembersURL { + o.SetBasePath(bp) + return o +} + +// SetBasePath sets the base path for this url builder, only required when it's different from the +// base path specified in the swagger spec. +// When the value of the base path is an empty string +func (o *ListOrgMembersURL) SetBasePath(bp string) { + o._basePath = bp +} + +// Build a url path and query string +func (o *ListOrgMembersURL) Build() (*url.URL, error) { + var _result url.URL + + var _path = "/members/{organizationToken}" + + organizationToken := o.OrganizationToken + if organizationToken != "" { + _path = strings.Replace(_path, "{organizationToken}", organizationToken, -1) + } else { + return nil, errors.New("organizationToken is required on ListOrgMembersURL") + } + + _basePath := o._basePath + if _basePath == "" { + _basePath = "/api/v1" + } + _result.Path = golangswaggerpaths.Join(_basePath, _path) + + return &_result, nil +} + +// Must is a helper function to panic when the url builder returns an error +func (o *ListOrgMembersURL) Must(u *url.URL, err error) *url.URL { + if err != nil { + panic(err) + } + if u == nil { + panic("url can't be nil") + } + return u +} + +// String returns the string representation of the path with query string +func (o *ListOrgMembersURL) String() string { + return o.Must(o.Build()).String() +} + +// BuildFull builds a full url with scheme, host, path and query string +func (o *ListOrgMembersURL) BuildFull(scheme, host string) (*url.URL, error) { + if scheme == "" { + return nil, errors.New("scheme is required for a full url on ListOrgMembersURL") + } + if host == "" { + return nil, errors.New("host is required for a full url on ListOrgMembersURL") + } + + base, err := o.Build() + if err != nil { + return nil, err + } + + base.Scheme = scheme + base.Host = host + return base, nil +} + +// StringFull returns the string representation of a complete url +func (o *ListOrgMembersURL) StringFull(scheme, host string) string { + return o.Must(o.BuildFull(scheme, host)).String() +} diff --git a/rest_server_zrok/operations/zrok_api.go b/rest_server_zrok/operations/zrok_api.go index 1e097b52..defdbf97 100644 --- a/rest_server_zrok/operations/zrok_api.go +++ b/rest_server_zrok/operations/zrok_api.go @@ -121,6 +121,9 @@ func NewZrokAPI(spec *loads.Document) *ZrokAPI { MetadataListMembershipsHandler: metadata.ListMembershipsHandlerFunc(func(params metadata.ListMembershipsParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation metadata.ListMemberships has not yet been implemented") }), + MetadataListOrgMembersHandler: metadata.ListOrgMembersHandlerFunc(func(params metadata.ListOrgMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { + return middleware.NotImplemented("operation metadata.ListOrgMembers has not yet been implemented") + }), AdminListOrganizationMembersHandler: admin.ListOrganizationMembersHandlerFunc(func(params admin.ListOrganizationMembersParams, principal *rest_model_zrok.Principal) middleware.Responder { return middleware.NotImplemented("operation admin.ListOrganizationMembers has not yet been implemented") }), @@ -270,6 +273,8 @@ type ZrokAPI struct { AdminListFrontendsHandler admin.ListFrontendsHandler // MetadataListMembershipsHandler sets the operation handler for the list memberships operation MetadataListMembershipsHandler metadata.ListMembershipsHandler + // MetadataListOrgMembersHandler sets the operation handler for the list org members operation + MetadataListOrgMembersHandler metadata.ListOrgMembersHandler // AdminListOrganizationMembersHandler sets the operation handler for the list organization members operation AdminListOrganizationMembersHandler admin.ListOrganizationMembersHandler // AdminListOrganizationsHandler sets the operation handler for the list organizations operation @@ -457,6 +462,9 @@ func (o *ZrokAPI) Validate() error { if o.MetadataListMembershipsHandler == nil { unregistered = append(unregistered, "metadata.ListMembershipsHandler") } + if o.MetadataListOrgMembersHandler == nil { + unregistered = append(unregistered, "metadata.ListOrgMembersHandler") + } if o.AdminListOrganizationMembersHandler == nil { unregistered = append(unregistered, "admin.ListOrganizationMembersHandler") } @@ -703,6 +711,10 @@ func (o *ZrokAPI) initHandlerCache() { o.handlers["GET"] = make(map[string]http.Handler) } o.handlers["GET"]["/memberships"] = metadata.NewListMemberships(o.context, o.MetadataListMembershipsHandler) + if o.handlers["GET"] == nil { + o.handlers["GET"] = make(map[string]http.Handler) + } + o.handlers["GET"]["/members/{organizationToken}"] = metadata.NewListOrgMembers(o.context, o.MetadataListOrgMembersHandler) if o.handlers["POST"] == nil { o.handlers["POST"] = make(map[string]http.Handler) } diff --git a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts index 5caebf4e..4348628c 100644 --- a/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts +++ b/sdk/nodejs/sdk/src/zrok/api/api/metadataApi.ts @@ -20,6 +20,7 @@ import { Environment } from '../model/environment'; import { EnvironmentAndResources } from '../model/environmentAndResources'; import { Frontend } from '../model/frontend'; import { ListMemberships200Response } from '../model/listMemberships200Response'; +import { ListOrganizationMembers200Response } from '../model/listOrganizationMembers200Response'; import { Metrics } from '../model/metrics'; import { Overview } from '../model/overview'; import { Share } from '../model/share'; @@ -719,6 +720,77 @@ export class MetadataApi { }); }); } + /** + * + * @param organizationToken + */ + public async listOrgMembers (organizationToken: string, options: {headers: {[name: string]: string}} = {headers: {}}) : Promise<{ response: http.IncomingMessage; body: ListOrganizationMembers200Response; }> { + const localVarPath = this.basePath + '/members/{organizationToken}' + .replace('{' + 'organizationToken' + '}', encodeURIComponent(String(organizationToken))); + let localVarQueryParameters: any = {}; + let localVarHeaderParams: any = (Object).assign({}, this._defaultHeaders); + const produces = ['application/zrok.v1+json']; + // give precedence to 'application/json' + if (produces.indexOf('application/json') >= 0) { + localVarHeaderParams.Accept = 'application/json'; + } else { + localVarHeaderParams.Accept = produces.join(','); + } + let localVarFormParams: any = {}; + + // verify required parameter 'organizationToken' is not null or undefined + if (organizationToken === null || organizationToken === undefined) { + throw new Error('Required parameter organizationToken was null or undefined when calling listOrgMembers.'); + } + + (Object).assign(localVarHeaderParams, options.headers); + + let localVarUseFormData = false; + + let localVarRequestOptions: localVarRequest.Options = { + method: 'GET', + qs: localVarQueryParameters, + headers: localVarHeaderParams, + uri: localVarPath, + useQuerystring: this._useQuerystring, + json: true, + }; + + let authenticationPromise = Promise.resolve(); + if (this.authentications.key.apiKey) { + authenticationPromise = authenticationPromise.then(() => this.authentications.key.applyToRequest(localVarRequestOptions)); + } + authenticationPromise = authenticationPromise.then(() => this.authentications.default.applyToRequest(localVarRequestOptions)); + + let interceptorPromise = authenticationPromise; + for (const interceptor of this.interceptors) { + interceptorPromise = interceptorPromise.then(() => interceptor(localVarRequestOptions)); + } + + return interceptorPromise.then(() => { + if (Object.keys(localVarFormParams).length) { + if (localVarUseFormData) { + (localVarRequestOptions).formData = localVarFormParams; + } else { + localVarRequestOptions.form = localVarFormParams; + } + } + return new Promise<{ response: http.IncomingMessage; body: ListOrganizationMembers200Response; }>((resolve, reject) => { + localVarRequest(localVarRequestOptions, (error, response, body) => { + if (error) { + reject(error); + } else { + if (response.statusCode && response.statusCode >= 200 && response.statusCode <= 299) { + body = ObjectSerializer.deserialize(body, "ListOrganizationMembers200Response"); + resolve({ response: response, body: body }); + } else { + reject(new HttpError(response, body, response.statusCode)); + } + } + }); + }); + }); + } /** * * @param organizationToken diff --git a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py index 6798e098..59ab45cb 100644 --- a/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py +++ b/sdk/python/sdk/zrok/zrok_api/api/metadata_api.py @@ -849,6 +849,99 @@ class MetadataApi(object): _request_timeout=params.get('_request_timeout'), collection_formats=collection_formats) + def list_org_members(self, organization_token, **kwargs): # noqa: E501 + """list_org_members # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_org_members(organization_token, async_req=True) + >>> result = thread.get() + + :param async_req bool + :param str organization_token: (required) + :return: InlineResponse2001 + If the method is called asynchronously, + returns the request thread. + """ + kwargs['_return_http_data_only'] = True + if kwargs.get('async_req'): + return self.list_org_members_with_http_info(organization_token, **kwargs) # noqa: E501 + else: + (data) = self.list_org_members_with_http_info(organization_token, **kwargs) # noqa: E501 + return data + + def list_org_members_with_http_info(self, organization_token, **kwargs): # noqa: E501 + """list_org_members # noqa: E501 + + This method makes a synchronous HTTP request by default. To make an + asynchronous HTTP request, please pass async_req=True + >>> thread = api.list_org_members_with_http_info(organization_token, async_req=True) + >>> result = thread.get() + + :param async_req bool + :param str organization_token: (required) + :return: InlineResponse2001 + If the method is called asynchronously, + returns the request thread. + """ + + all_params = ['organization_token'] # noqa: E501 + all_params.append('async_req') + all_params.append('_return_http_data_only') + all_params.append('_preload_content') + all_params.append('_request_timeout') + + params = locals() + for key, val in six.iteritems(params['kwargs']): + if key not in all_params: + raise TypeError( + "Got an unexpected keyword argument '%s'" + " to method list_org_members" % key + ) + params[key] = val + del params['kwargs'] + # verify the required parameter 'organization_token' is set + if ('organization_token' not in params or + params['organization_token'] is None): + raise ValueError("Missing the required parameter `organization_token` when calling `list_org_members`") # noqa: E501 + + collection_formats = {} + + path_params = {} + if 'organization_token' in params: + path_params['organizationToken'] = params['organization_token'] # noqa: E501 + + query_params = [] + + header_params = {} + + form_params = [] + local_var_files = {} + + body_params = None + # HTTP header `Accept` + header_params['Accept'] = self.api_client.select_header_accept( + ['application/zrok.v1+json']) # noqa: E501 + + # Authentication setting + auth_settings = ['key'] # noqa: E501 + + return self.api_client.call_api( + '/members/{organizationToken}', 'GET', + path_params, + query_params, + header_params, + body=body_params, + post_params=form_params, + files=local_var_files, + response_type='InlineResponse2001', # noqa: E501 + auth_settings=auth_settings, + async_req=params.get('async_req'), + _return_http_data_only=params.get('_return_http_data_only'), + _preload_content=params.get('_preload_content', True), + _request_timeout=params.get('_request_timeout'), + collection_formats=collection_formats) + def org_account_overview(self, organization_token, account_email, **kwargs): # noqa: E501 """org_account_overview # noqa: E501 diff --git a/specs/zrok.yml b/specs/zrok.yml index 0dc59f58..8a88e019 100644 --- a/specs/zrok.yml +++ b/specs/zrok.yml @@ -691,6 +691,36 @@ paths: 500: description: internal server error + /members/{organizationToken}: + get: + tags: + - metadata + security: + - key: [] + operationId: listOrgMembers + parameters: + - name: organizationToken + in: path + type: string + required: true + responses: + 200: + description: ok + schema: + properties: + members: + type: array + items: + properties: + email: + type: string + admin: + type: boolean + 404: + description: not found + 500: + description: internal server error + /memberships: get: tags: diff --git a/ui/src/api/metadata.js b/ui/src/api/metadata.js index 73cd6a25..ba1a02e9 100644 --- a/ui/src/api/metadata.js +++ b/ui/src/api/metadata.js @@ -53,6 +53,19 @@ export function getShareDetail(shrToken) { return gateway.request(getShareDetailOperation, parameters) } +/** + * @param {string} organizationToken + * @return {Promise} ok + */ +export function listOrgMembers(organizationToken) { + const parameters = { + path: { + organizationToken + } + } + return gateway.request(listOrgMembersOperation, parameters) +} + /** */ export function listMemberships() { @@ -184,6 +197,16 @@ const getShareDetailOperation = { ] } +const listOrgMembersOperation = { + path: '/members/{organizationToken}', + method: 'get', + security: [ + { + id: 'key' + } + ] +} + const listMembershipsOperation = { path: '/memberships', method: 'get', From 9868058076f9125694b6081b23f05c9cbae8b9e8 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 14:21:36 -0500 Subject: [PATCH 19/32] cli integration for 'zrok org admin list' (#537) --- cmd/zrok/orgAdminList.go | 76 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 cmd/zrok/orgAdminList.go diff --git a/cmd/zrok/orgAdminList.go b/cmd/zrok/orgAdminList.go new file mode 100644 index 00000000..543fbbbd --- /dev/null +++ b/cmd/zrok/orgAdminList.go @@ -0,0 +1,76 @@ +package main + +import ( + "fmt" + httptransport "github.com/go-openapi/runtime/client" + "github.com/jedib0t/go-pretty/v6/table" + "github.com/openziti/zrok/environment" + "github.com/openziti/zrok/rest_client_zrok/metadata" + "github.com/openziti/zrok/tui" + "github.com/spf13/cobra" + "os" +) + +func init() { + organizationAdminCmd.AddCommand(newOrgAdminListCommand().cmd) +} + +type orgAdminListCommand struct { + cmd *cobra.Command +} + +func newOrgAdminListCommand() *orgAdminListCommand { + cmd := &cobra.Command{ + Use: "list ", + Short: "List the members of an organization", + Args: cobra.ExactArgs(1), + } + command := &orgAdminListCommand{cmd} + cmd.Run = command.run + return command +} + +func (c *orgAdminListCommand) run(_ *cobra.Command, args []string) { + root, err := environment.LoadRoot() + if err != nil { + if !panicInstead { + tui.Error("error loading zrokdir", err) + } + panic(err) + } + + if !root.IsEnabled() { + tui.Error("unable to load environment; did you 'zrok enable'?", nil) + } + + zrok, err := root.Client() + if err != nil { + if !panicInstead { + tui.Error("error loading zrokdir", err) + } + panic(err) + } + auth := httptransport.APIKeyAuth("X-TOKEN", "header", root.Environment().Token) + + req := metadata.NewListOrgMembersParams() + req.OrganizationToken = args[0] + + resp, err := zrok.Metadata.ListOrgMembers(req, auth) + if err != nil { + if !panicInstead { + tui.Error("error listing organization members", err) + } + panic(err) + } + + fmt.Println() + t := table.NewWriter() + t.SetOutputMirror(os.Stdout) + t.SetStyle(table.StyleColoredDark) + t.AppendHeader(table.Row{"Email", "Admin?"}) + for _, member := range resp.Payload.Members { + t.AppendRow(table.Row{member.Email, member.Admin}) + } + t.Render() + fmt.Println() +} From ac66c95be05b57362130f9c912184bcce2c6b3ec Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 14:25:32 -0500 Subject: [PATCH 20/32] changelog (#537) --- CHANGELOG.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0c490603..807c751b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,10 @@ ## v0.4.45 +FEATURE: Minimal support for "organizations". Site admin API endpoints provided to create, list, and delete "organizations". Site admin API endpoints provided to add, list, and remove "organization members" (zrok accounts) with the ability to mark accounts as a "organization admin". API endpoints provided for organization admins to list the members of their organizations, and to also see the overview (environments, shares, and accesses) for any account in their organization. API endpoint for end users to see which organizations their account is a member of. (https://github.com/openziti/zrok/issues/593) + +CHANGE: briefly mention the backend modes that apply to public and private share concepts + FIX: Update indirect dependency `github.com/golang-jwt/jwt/v4` to version `v4.5.1` (https://github.com/openziti/zrok/issues/794) FIX: Document unique names @@ -12,7 +16,6 @@ FIX: Docker reserved private share startup error (https://github.com/openziti/zr FIX: Correct the download URL for the armv7 Linux release (https://github.com/openziti/zrok/issues/782) -CHANGE: briefly mention the backend modes that apply to public and private share concepts ## v0.4.44 From d811a31f63ad4cf9f20863f191772fc8a87dd5d4 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 14:30:37 -0500 Subject: [PATCH 21/32] naming lint (#537) --- cmd/zrok/adminListOrganizations.go | 2 +- cmd/zrok/orgMemberships.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/cmd/zrok/adminListOrganizations.go b/cmd/zrok/adminListOrganizations.go index 2bbde476..bf2624d8 100644 --- a/cmd/zrok/adminListOrganizations.go +++ b/cmd/zrok/adminListOrganizations.go @@ -50,7 +50,7 @@ func (c *adminListOrganizationsCommand) run(_ *cobra.Command, _ []string) { t := table.NewWriter() t.SetOutputMirror(os.Stdout) t.SetStyle(table.StyleColoredDark) - t.AppendHeader(table.Row{"Token", "Description"}) + t.AppendHeader(table.Row{"Organization Token", "Description"}) for _, org := range resp.Payload.Organizations { t.AppendRow(table.Row{org.Token, org.Description}) } diff --git a/cmd/zrok/orgMemberships.go b/cmd/zrok/orgMemberships.go index bafcb064..4a247b31 100644 --- a/cmd/zrok/orgMemberships.go +++ b/cmd/zrok/orgMemberships.go @@ -63,7 +63,7 @@ func (c *orgMembershipsCommand) run(_ *cobra.Command, _ []string) { t := table.NewWriter() t.SetOutputMirror(os.Stdout) t.SetStyle(table.StyleColoredDark) - t.AppendHeader(table.Row{"Token", "Description", "Admin?"}) + t.AppendHeader(table.Row{"Organization Token", "Description", "Admin?"}) for _, i := range in.Payload.Memberships { t.AppendRow(table.Row{i.Token, i.Description, i.Admin}) } From 4379799f0e499eeb5d6a0ca50d048900a5fca6e8 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Tue, 10 Dec 2024 14:37:11 -0500 Subject: [PATCH 22/32] changelog lint (#537) --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 807c751b..c690e8d5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,7 +2,7 @@ ## v0.4.45 -FEATURE: Minimal support for "organizations". Site admin API endpoints provided to create, list, and delete "organizations". Site admin API endpoints provided to add, list, and remove "organization members" (zrok accounts) with the ability to mark accounts as a "organization admin". API endpoints provided for organization admins to list the members of their organizations, and to also see the overview (environments, shares, and accesses) for any account in their organization. API endpoint for end users to see which organizations their account is a member of. (https://github.com/openziti/zrok/issues/593) +FEATURE: Minimal support for "organizations". Site admin API endpoints provided to create, list, and delete "organizations". Site admin API endpoints provided to add, list, and remove "organization members" (zrok accounts) with the ability to mark accounts as a "organization admin". API endpoints provided for organization admins to list the members of their organizations, and to also see the overview (environments, shares, and accesses) for any account in their organization. API endpoint for end users to see which organizations their account is a member of. (https://github.com/openziti/zrok/issues/537) CHANGE: briefly mention the backend modes that apply to public and private share concepts From d0c9c454ed0b9a2b6084319a84e4e25ffdef92c6 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 11:41:26 -0500 Subject: [PATCH 23/32] docs (#537) --- docs/guides/organizations.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 docs/guides/organizations.md diff --git a/docs/guides/organizations.md b/docs/guides/organizations.md new file mode 100644 index 00000000..ca41cb78 --- /dev/null +++ b/docs/guides/organizations.md @@ -0,0 +1,13 @@ +--- +sidebar_position: 21 +sidebar_label: Permission Modes +--- + +# Organizations + +zrok (starting with `v0.4.45`) includes support for "organizations". Organizations are groups of related accounts that are typically centrally managed in some capacity. A zrok account can be a member of multiple organizations. Organization membership can also include an "admin" permission. As of `v0.4.45` organization admins are able to retrieve an "overview" (`zrok overview`) from any other account in the organization, allowing the admin to see the details of the environments, shares, and accesses created within that account. + +Future zrok releases will include additional organization features, including `--closed` permission sharing functions. + +## Configuring an Organization + From 7cf29103d8544785f1f9528619f212f38e4736f3 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:23:48 -0500 Subject: [PATCH 24/32] documentation/lint (#537) --- cmd/zrok/orgAdminOverview.go | 2 +- cmd/zrok/orgMemberships.go | 22 +++--- docs/guides/organizations.md | 132 +++++++++++++++++++++++++++++++++++ 3 files changed, 146 insertions(+), 10 deletions(-) diff --git a/cmd/zrok/orgAdminOverview.go b/cmd/zrok/orgAdminOverview.go index 372911d4..a082b622 100644 --- a/cmd/zrok/orgAdminOverview.go +++ b/cmd/zrok/orgAdminOverview.go @@ -21,7 +21,7 @@ type orgAdminOverviewCommand struct { func newOrgAdminOverviewCommand() *orgAdminOverviewCommand { cmd := &cobra.Command{ Use: "overview ", - Short: "Retrieve account overview for organization account (requires admin)", + Short: "Retrieve account overview for organization member account", Args: cobra.ExactArgs(2), } command := &orgAdminOverviewCommand{cmd: cmd} diff --git a/cmd/zrok/orgMemberships.go b/cmd/zrok/orgMemberships.go index 4a247b31..4b9cf58d 100644 --- a/cmd/zrok/orgMemberships.go +++ b/cmd/zrok/orgMemberships.go @@ -59,14 +59,18 @@ func (c *orgMembershipsCommand) run(_ *cobra.Command, _ []string) { panic(err) } - fmt.Println() - t := table.NewWriter() - t.SetOutputMirror(os.Stdout) - t.SetStyle(table.StyleColoredDark) - t.AppendHeader(table.Row{"Organization Token", "Description", "Admin?"}) - for _, i := range in.Payload.Memberships { - t.AppendRow(table.Row{i.Token, i.Description, i.Admin}) + if len(in.Payload.Memberships) > 0 { + fmt.Println() + t := table.NewWriter() + t.SetOutputMirror(os.Stdout) + t.SetStyle(table.StyleColoredDark) + t.AppendHeader(table.Row{"Organization Token", "Description", "Admin?"}) + for _, i := range in.Payload.Memberships { + t.AppendRow(table.Row{i.Token, i.Description, i.Admin}) + } + t.Render() + fmt.Println() + } else { + fmt.Println("no organization memberships.") } - t.Render() - fmt.Println() } diff --git a/docs/guides/organizations.md b/docs/guides/organizations.md index ca41cb78..24bdebbe 100644 --- a/docs/guides/organizations.md +++ b/docs/guides/organizations.md @@ -11,3 +11,135 @@ Future zrok releases will include additional organization features, including `- ## Configuring an Organization +The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](self-hosting/linux/#configure-the-controller) for details on configuring admin tokens. + +### Create an Organization + +The `zrok admin create organization` command is used to create organizations: + +``` +$ zrok admin create organization --help +Create a new organization + +Usage: + zrok admin create organization [flags] + +Aliases: + organization, org + +Flags: + -d, --description string Organization description + -h, --help help for organization + +Global Flags: + -p, --panic Panic instead of showing pretty errors + -v, --verbose Enable verbose logging +``` + +Use the `-d` flag to add a description that shows up in end-user membership listings. + +We'll create an example organization: + +``` +$ zrok admin create organization -d "documentation" +[ 0.006] INFO main.(*adminCreateOrganizationCommand).run: created new organization with token 'gK1XRvthq7ci' +``` + +### List Organizations + +We use the `zrok admin list organizations` command to list our organizations: + +``` +$ zrok admin list organizations + + ORGANIZATION TOKEN DESCRIPTION + gK1XRvthq7ci documentation +``` + +### Add a Member to an Organization + +We use the `zrok admin create org-member` command to add members to organizations: + +``` +$ zrok admin create org-member +Error: accepts 2 arg(s), received 0 +Usage: + zrok admin create org-member [flags] + +Aliases: + org-member, member + +Flags: + --admin Make the new account an admin of the organization + -h, --help help for org-member + +Global Flags: + -p, --panic Panic instead of showing pretty errors + -v, --verbose Enable verbose logging +``` + +Like this: + +``` +$ zrok admin create org-member michael.quigley@netfoundry.io gK1XRvthq7ci +[ 0.006] INFO main.(*adminCreateOrgMemberCommand).run: added 'michael.quigley@netfoundry.io' to organization 'gK1XRvthq7ci +``` + +The `--admin` flag can be added to the `zrok admin create org-member` command to mark the member as an administrator of the organization. + +### List Members of an Organization + +``` +$ zrok admin list org-members gK1XRvthq7ci + + ACCOUNT EMAIL ADMIN? + michael.quigley@netfoundry.io false +``` + +### Removing Organizations and Members + +The `zrok admin delete org-member` and `zrok admin delete organization` commands are available to clean up organizations and their membership lists. + +## End-user Organization Administrator Commands + +When a zrok account is added to an organization as an administrator it allows them to use the `zrok organization admin` commands, which include: + +``` +$ zrok organization admin +Organization admin commands + +Usage: + zrok organization admin [command] + +Available Commands: + list List the members of an organization + overview Retrieve account overview for organization member account + +Flags: + -h, --help help for admin + +Global Flags: + -p, --panic Panic instead of showing pretty errors + -v, --verbose Enable verbose logging + +Use "zrok organization admin [command] --help" for more information about a command. +``` + +The `zrok organization admin list` command is used to list the members of an organization. + +The `zrok organization admin overview` command is used to retrieve an overview of an organization member account. This is functionally equivalent to what the `zrok overview` command does, but it allows an organization admin to retrieve the overview for another zrok account. + +## End-user Organization Commands + +All zrok accounts can use the `zrok organization memberships` command to list the organizations they're a member of: + +``` +$ zrok organization memberships + + ORGANIZATION TOKEN DESCRIPTION ADMIN? + gK1XRvthq7ci documentation false + +``` + + + From 2cf30d8fe1548d6e5a61ddeedfb65ace707cda06 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:25:51 -0500 Subject: [PATCH 25/32] doc links (#537) --- docs/guides/organizations.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/guides/organizations.md b/docs/guides/organizations.md index 24bdebbe..5af3fdb4 100644 --- a/docs/guides/organizations.md +++ b/docs/guides/organizations.md @@ -11,7 +11,7 @@ Future zrok releases will include additional organization features, including `- ## Configuring an Organization -The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](self-hosting/linux/#configure-the-controller) for details on configuring admin tokens. +The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](self-hosting/linux for details on configuring admin tokens. ### Create an Organization From b48f9668b1c07d2d4bd285da898a862ea5d80420 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:27:51 -0500 Subject: [PATCH 26/32] doc lint (#537) --- docs/guides/organizations.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/guides/organizations.md b/docs/guides/organizations.md index 5af3fdb4..31bafab2 100644 --- a/docs/guides/organizations.md +++ b/docs/guides/organizations.md @@ -1,6 +1,6 @@ --- sidebar_position: 21 -sidebar_label: Permission Modes +sidebar_label: Organizations --- # Organizations From eb042105e7102103137956fba16c038950054b38 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:28:38 -0500 Subject: [PATCH 27/32] sidebar position (#537) --- docs/guides/organizations.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/guides/organizations.md b/docs/guides/organizations.md index 31bafab2..420d5ffa 100644 --- a/docs/guides/organizations.md +++ b/docs/guides/organizations.md @@ -1,5 +1,5 @@ --- -sidebar_position: 21 +sidebar_position: 23 sidebar_label: Organizations --- From da8d954456ea3d141e6f2d118f96d19178cf00fa Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:31:44 -0500 Subject: [PATCH 28/32] doc structure lint (#537) --- docs/guides/{ => self-hosting}/organizations.md | 4 ++-- docs/guides/self-hosting/personalized-frontend.md | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) rename docs/guides/{ => self-hosting}/organizations.md (97%) diff --git a/docs/guides/organizations.md b/docs/guides/self-hosting/organizations.md similarity index 97% rename from docs/guides/organizations.md rename to docs/guides/self-hosting/organizations.md index 420d5ffa..1ce9a067 100644 --- a/docs/guides/organizations.md +++ b/docs/guides/self-hosting/organizations.md @@ -1,5 +1,5 @@ --- -sidebar_position: 23 +sidebar_position: 21 sidebar_label: Organizations --- @@ -11,7 +11,7 @@ Future zrok releases will include additional organization features, including `- ## Configuring an Organization -The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](self-hosting/linux for details on configuring admin tokens. +The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](linux) for details on configuring admin tokens. ### Create an Organization diff --git a/docs/guides/self-hosting/personalized-frontend.md b/docs/guides/self-hosting/personalized-frontend.md index af836ec5..7dc20a2a 100644 --- a/docs/guides/self-hosting/personalized-frontend.md +++ b/docs/guides/self-hosting/personalized-frontend.md @@ -1,7 +1,7 @@ --- title: Personalized Frontend sidebar_label: Personalized Frontend -sidebar_position: 19 +sidebar_position: 22 --- This guide describes an approach that enables a zrok user to use a hosted, shared instance (zrok.io) and configure their own personalized frontend, which enables custom DNS and TLS for their shares. @@ -70,4 +70,4 @@ Your protected resources remain disconnected from the internet and are only reac When you use a public frontend (with a simple `zrok share public`) at a hosted zrok instance (like zrok.io), the operators of that service have some amount of visibility into what traffic you're sending to your shares. The load balancers in front of the public frontend maintain logs describing all of the URLs that were accessed, as well as other information (headers, etc.) that contain information about the resource you're sharing. -If you create private shares using `zrok share private` and then run your own `zrok access private` from some other location, the operators of the zrok service instance only know that some amount of data moved between the environment running the `zrok share private` and the `zrok access private`. There is no other information available. \ No newline at end of file +If you create private shares using `zrok share private` and then run your own `zrok access private` from some other location, the operators of the zrok service instance only know that some amount of data moved between the environment running the `zrok share private` and the `zrok access private`. There is no other information available. From 90eb5f834254c77acec546af6ab2ed2e6a4bcd7b Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:34:20 -0500 Subject: [PATCH 29/32] links, again (#537) --- docs/guides/self-hosting/organizations.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/guides/self-hosting/organizations.md b/docs/guides/self-hosting/organizations.md index 1ce9a067..8f0e8b6d 100644 --- a/docs/guides/self-hosting/organizations.md +++ b/docs/guides/self-hosting/organizations.md @@ -11,7 +11,7 @@ Future zrok releases will include additional organization features, including `- ## Configuring an Organization -The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](linux) for details on configuring admin tokens. +The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](linux/index.mdx) for details on configuring admin tokens. ### Create an Organization From 2f14e9798f89978e782d913203c66ae5675895a6 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:35:14 -0500 Subject: [PATCH 30/32] anchor (#537) --- docs/guides/self-hosting/organizations.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/guides/self-hosting/organizations.md b/docs/guides/self-hosting/organizations.md index 8f0e8b6d..6a000498 100644 --- a/docs/guides/self-hosting/organizations.md +++ b/docs/guides/self-hosting/organizations.md @@ -11,7 +11,7 @@ Future zrok releases will include additional organization features, including `- ## Configuring an Organization -The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](linux/index.mdx) for details on configuring admin tokens. +The API endpoints used to manage organizations and their members require a site-level `ZROK_ADMIN_TOKEN` to access. See the [self-hosting guide](linux/index.mdx#configure-the-controller) for details on configuring admin tokens. ### Create an Organization From 8195736d95efc11e514e0d500e0e8e1f918e6b60 Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 12:57:34 -0500 Subject: [PATCH 31/32] lint; sqlite (#537) --- CHANGELOG.md | 2 +- controller/store/sql/sqlite3/030_v0_4_45_organizations.sql | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c690e8d5..2dd8ff2f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,7 +2,7 @@ ## v0.4.45 -FEATURE: Minimal support for "organizations". Site admin API endpoints provided to create, list, and delete "organizations". Site admin API endpoints provided to add, list, and remove "organization members" (zrok accounts) with the ability to mark accounts as a "organization admin". API endpoints provided for organization admins to list the members of their organizations, and to also see the overview (environments, shares, and accesses) for any account in their organization. API endpoint for end users to see which organizations their account is a member of. (https://github.com/openziti/zrok/issues/537) +FEATURE: Minimal support for "organizations". Site admin API endpoints provided to create, list, and delete "organizations". Site admin API endpoints provided to add, list, and remove "organization members" (zrok accounts) with the ability to mark accounts as a "organization admin". API endpoints provided for organization admins to list the members of their organizations, and to also see the overview (environments, shares, and accesses) for any account in their organization. API endpoint for end users to see which organizations their account is a member of (https://github.com/openziti/zrok/issues/537) CHANGE: briefly mention the backend modes that apply to public and private share concepts diff --git a/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql b/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql index 67975605..e26d4c02 100644 --- a/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql +++ b/controller/store/sql/sqlite3/030_v0_4_45_organizations.sql @@ -1,7 +1,7 @@ -- +migrate Up create table organizations ( - id serial primary key, + id integer primary key, token varchar(32) not null, description varchar(128), @@ -14,7 +14,7 @@ create table organizations ( create index organization_token_idx on organizations(token); create table organization_members ( - id serial primary key, + id integer primary key, organization_id integer references organizations(id) not null, account_id integer references accounts(id) not null, From 5c29a654741a14d42a678ddce776565393b70d0c Mon Sep 17 00:00:00 2001 From: Michael Quigley Date: Wed, 11 Dec 2024 13:01:40 -0500 Subject: [PATCH 32/32] slightly more ergonomic CLI ordering (#537) --- cmd/zrok/adminCreateOrgMember.go | 6 +++--- cmd/zrok/adminDeleteOrgMember.go | 6 +++--- docs/guides/self-hosting/organizations.md | 4 ++-- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/cmd/zrok/adminCreateOrgMember.go b/cmd/zrok/adminCreateOrgMember.go index fc15e3a1..e58c2fcd 100644 --- a/cmd/zrok/adminCreateOrgMember.go +++ b/cmd/zrok/adminCreateOrgMember.go @@ -18,7 +18,7 @@ type adminCreateOrgMemberCommand struct { func newAdminCreateOrgMemberCommand() *adminCreateOrgMemberCommand { cmd := &cobra.Command{ - Use: "org-member ", + Use: "org-member ", Aliases: []string{"member"}, Short: "Add an account to an organization", Args: cobra.ExactArgs(2), @@ -41,8 +41,8 @@ func (cmd *adminCreateOrgMemberCommand) run(_ *cobra.Command, args []string) { } req := admin.NewAddOrganizationMemberParams() - req.Body.Email = args[0] - req.Body.Token = args[1] + req.Body.Token = args[0] + req.Body.Email = args[1] req.Body.Admin = cmd.admin _, err = zrok.Admin.AddOrganizationMember(req, mustGetAdminAuth()) diff --git a/cmd/zrok/adminDeleteOrgMember.go b/cmd/zrok/adminDeleteOrgMember.go index 81c38fe2..6659727f 100644 --- a/cmd/zrok/adminDeleteOrgMember.go +++ b/cmd/zrok/adminDeleteOrgMember.go @@ -17,7 +17,7 @@ type adminDeleteOrgMemberCommand struct { func newAdminDeleteOrgMemberCommand() *adminDeleteOrgMemberCommand { cmd := &cobra.Command{ - Use: "org-member ", + Use: "org-member ", Aliases: []string{"member"}, Short: "Remove an account from an organization", Args: cobra.ExactArgs(2), @@ -39,8 +39,8 @@ func (cmd *adminDeleteOrgMemberCommand) run(_ *cobra.Command, args []string) { } req := admin.NewRemoveOrganizationMemberParams() - req.Body.Email = args[0] - req.Body.Token = args[1] + req.Body.Token = args[0] + req.Body.Email = args[1] _, err = zrok.Admin.RemoveOrganizationMember(req, mustGetAdminAuth()) if err != nil { diff --git a/docs/guides/self-hosting/organizations.md b/docs/guides/self-hosting/organizations.md index 6a000498..f67b215a 100644 --- a/docs/guides/self-hosting/organizations.md +++ b/docs/guides/self-hosting/organizations.md @@ -64,7 +64,7 @@ We use the `zrok admin create org-member` command to add members to organization $ zrok admin create org-member Error: accepts 2 arg(s), received 0 Usage: - zrok admin create org-member [flags] + zrok admin create org-member [flags] Aliases: org-member, member @@ -81,7 +81,7 @@ Global Flags: Like this: ``` -$ zrok admin create org-member michael.quigley@netfoundry.io gK1XRvthq7ci +$ zrok admin create org-member gK1XRvthq7ci michael.quigley@netfoundry.io [ 0.006] INFO main.(*adminCreateOrgMemberCommand).run: added 'michael.quigley@netfoundry.io' to organization 'gK1XRvthq7ci ```