/**
 * Backbone Organization Structure API
 *  - alpha: Currently developed API version. Subject to major changes. - beta: A semi-stable early access version. New features can be added. Breaking changes are possible. - stable: The API is recommended for use in production.  [Changelog](https://organization-structure-api.steve.niceshops.com/v2/docs/changelog.html)  All data is transferred in UTF-8 encoding.\\ The API uses stateless HTTP. No cookies have to be kept.\\ Authentication via OAuth2 client credentials flow.  [Privacy Policy](https://www.niceshops.com/en/dienstleistungen/data-privacy-policy)  [Backbone Organization Structure API PHP client @Packagist](https://packagist.org/packages/datenkraft/bb-organization-structure-api-php-client)
 *
 * The version of the OpenAPI document: v2.beta
 *
 *
 * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
 * https://openapi-generator.tech
 * Do not edit the class manually.
 */
import type { Configuration } from '../configuration';
import type { AxiosPromise, AxiosInstance, AxiosRequestConfig } from 'axios';
import { RequestArgs, BaseAPI } from '../base';
import { AuthPermissionRolePaginatedCollection } from '../models';
import { AuthPermissionRoleResource } from '../models';
/**
 * AuthPermissionRoleApi - axios parameter creator
 * @export
 */
export declare const AuthPermissionRoleApiAxiosParamCreator: (configuration?: Configuration) => {
    /**
     * Delete one or more role to permission assignments in this resource server
     * @summary Delete one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} [authPermissionRoleResource] CAUTION If the request is sent with an empty body, all relations are deleted!
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    deleteAuthPermissionRoleCollection: (authPermissionRoleResource?: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig) => Promise<RequestArgs>;
    /**
     * Get all role to permission assignments from this resource server
     * @summary Get all role to permission assignments from this resource server
     * @param {number} [page] The page to read. Default is the first page.
     * @param {number} [pageSize] The maximum size per page is 100. Default is 100.
     * @param {'default' | 'totalCount'} [paginationMode] The paginationMode to use: - default: The total number of items in the collection will not be calculated. - totalCount: The total number of items in the collection will be calculated. This can mean loss of performance.
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    getAuthPermissionRoleCollection: (page?: number, pageSize?: number, paginationMode?: 'default' | 'totalCount', options?: AxiosRequestConfig) => Promise<RequestArgs>;
    /**
     * Create one or more role to permission assignments in this resource server
     * @summary Create one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} authPermissionRoleResource
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    postAuthPermissionRoleCollection: (authPermissionRoleResource: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig) => Promise<RequestArgs>;
};
/**
 * AuthPermissionRoleApi - functional programming interface
 * @export
 */
export declare const AuthPermissionRoleApiFp: (configuration?: Configuration) => {
    /**
     * Delete one or more role to permission assignments in this resource server
     * @summary Delete one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} [authPermissionRoleResource] CAUTION If the request is sent with an empty body, all relations are deleted!
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    deleteAuthPermissionRoleCollection(authPermissionRoleResource?: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise<void>>;
    /**
     * Get all role to permission assignments from this resource server
     * @summary Get all role to permission assignments from this resource server
     * @param {number} [page] The page to read. Default is the first page.
     * @param {number} [pageSize] The maximum size per page is 100. Default is 100.
     * @param {'default' | 'totalCount'} [paginationMode] The paginationMode to use: - default: The total number of items in the collection will not be calculated. - totalCount: The total number of items in the collection will be calculated. This can mean loss of performance.
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    getAuthPermissionRoleCollection(page?: number, pageSize?: number, paginationMode?: 'default' | 'totalCount', options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise<AuthPermissionRolePaginatedCollection>>;
    /**
     * Create one or more role to permission assignments in this resource server
     * @summary Create one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} authPermissionRoleResource
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    postAuthPermissionRoleCollection(authPermissionRoleResource: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise<Array<AuthPermissionRoleResource>>>;
};
/**
 * AuthPermissionRoleApi - factory interface
 * @export
 */
export declare const AuthPermissionRoleApiFactory: (configuration?: Configuration, basePath?: string, axios?: AxiosInstance) => {
    /**
     * Delete one or more role to permission assignments in this resource server
     * @summary Delete one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} [authPermissionRoleResource] CAUTION If the request is sent with an empty body, all relations are deleted!
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    deleteAuthPermissionRoleCollection(authPermissionRoleResource?: Array<AuthPermissionRoleResource>, options?: any): AxiosPromise<void>;
    /**
     * Get all role to permission assignments from this resource server
     * @summary Get all role to permission assignments from this resource server
     * @param {number} [page] The page to read. Default is the first page.
     * @param {number} [pageSize] The maximum size per page is 100. Default is 100.
     * @param {'default' | 'totalCount'} [paginationMode] The paginationMode to use: - default: The total number of items in the collection will not be calculated. - totalCount: The total number of items in the collection will be calculated. This can mean loss of performance.
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    getAuthPermissionRoleCollection(page?: number, pageSize?: number, paginationMode?: 'default' | 'totalCount', options?: any): AxiosPromise<AuthPermissionRolePaginatedCollection>;
    /**
     * Create one or more role to permission assignments in this resource server
     * @summary Create one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} authPermissionRoleResource
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     */
    postAuthPermissionRoleCollection(authPermissionRoleResource: Array<AuthPermissionRoleResource>, options?: any): AxiosPromise<Array<AuthPermissionRoleResource>>;
};
/**
 * AuthPermissionRoleApi - interface
 * @export
 * @interface AuthPermissionRoleApi
 */
export interface AuthPermissionRoleApiInterface {
    /**
     * Delete one or more role to permission assignments in this resource server
     * @summary Delete one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} [authPermissionRoleResource] CAUTION If the request is sent with an empty body, all relations are deleted!
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApiInterface
     */
    deleteAuthPermissionRoleCollection(authPermissionRoleResource?: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): AxiosPromise<void>;
    /**
     * Get all role to permission assignments from this resource server
     * @summary Get all role to permission assignments from this resource server
     * @param {number} [page] The page to read. Default is the first page.
     * @param {number} [pageSize] The maximum size per page is 100. Default is 100.
     * @param {'default' | 'totalCount'} [paginationMode] The paginationMode to use: - default: The total number of items in the collection will not be calculated. - totalCount: The total number of items in the collection will be calculated. This can mean loss of performance.
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApiInterface
     */
    getAuthPermissionRoleCollection(page?: number, pageSize?: number, paginationMode?: 'default' | 'totalCount', options?: AxiosRequestConfig): AxiosPromise<AuthPermissionRolePaginatedCollection>;
    /**
     * Create one or more role to permission assignments in this resource server
     * @summary Create one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} authPermissionRoleResource
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApiInterface
     */
    postAuthPermissionRoleCollection(authPermissionRoleResource: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): AxiosPromise<Array<AuthPermissionRoleResource>>;
}
/**
 * AuthPermissionRoleApi - object-oriented interface
 * @export
 * @class AuthPermissionRoleApi
 * @extends {BaseAPI}
 */
export declare class AuthPermissionRoleApi extends BaseAPI implements AuthPermissionRoleApiInterface {
    /**
     * Delete one or more role to permission assignments in this resource server
     * @summary Delete one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} [authPermissionRoleResource] CAUTION If the request is sent with an empty body, all relations are deleted!
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApi
     */
    deleteAuthPermissionRoleCollection(authPermissionRoleResource?: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): Promise<import("axios").AxiosResponse<void, any>>;
    /**
     * Get all role to permission assignments from this resource server
     * @summary Get all role to permission assignments from this resource server
     * @param {number} [page] The page to read. Default is the first page.
     * @param {number} [pageSize] The maximum size per page is 100. Default is 100.
     * @param {'default' | 'totalCount'} [paginationMode] The paginationMode to use: - default: The total number of items in the collection will not be calculated. - totalCount: The total number of items in the collection will be calculated. This can mean loss of performance.
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApi
     */
    getAuthPermissionRoleCollection(page?: number, pageSize?: number, paginationMode?: 'default' | 'totalCount', options?: AxiosRequestConfig): Promise<import("axios").AxiosResponse<AuthPermissionRolePaginatedCollection, any>>;
    /**
     * Create one or more role to permission assignments in this resource server
     * @summary Create one or more role to permission assignments in this resource server
     * @param {Array<AuthPermissionRoleResource>} authPermissionRoleResource
     * @param {*} [options] Override http request option.
     * @throws {RequiredError}
     * @memberof AuthPermissionRoleApi
     */
    postAuthPermissionRoleCollection(authPermissionRoleResource: Array<AuthPermissionRoleResource>, options?: AxiosRequestConfig): Promise<import("axios").AxiosResponse<AuthPermissionRoleResource[], any>>;
}
