UNPKG

@asgardeo/javascript

Version:
120 lines (119 loc) 3.76 kB
/** * Copyright (c) 2025, WSO2 LLC. (https://www.wso2.com). * * WSO2 LLC. licenses this file to you under the Apache License, * Version 2.0 (the "License"); you may not use this file except * in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ import { Organization } from '../models/organization'; /** * Configuration for the getMeOrganizations request */ export interface GetMeOrganizationsConfig extends Omit<RequestInit, 'method'> { /** * The base URL for the API endpoint. */ baseUrl: string; /** * Base64 encoded cursor value for forward pagination */ after?: string; /** * Authorized application name filter */ authorizedAppName?: string; /** * Base64 encoded cursor value for backward pagination */ before?: string; /** * Filter expression for organizations */ filter?: string; /** * Maximum number of organizations to return */ limit?: number; /** * Whether to include child organizations recursively */ recursive?: boolean; /** * Optional custom fetcher function. * If not provided, native fetch will be used */ fetcher?: (url: string, config: RequestInit) => Promise<Response>; } /** * Retrieves the organizations associated with the current user. * * @param config - Configuration object containing baseUrl, optional query parameters, and request config. * @returns A promise that resolves with the organizations information. * @example * ```typescript * // Using default fetch * try { * const organizations = await getMeOrganizations({ * baseUrl: "https://api.asgardeo.io/t/<ORGANIZATION>", * after: "", * before: "", * filter: "", * limit: 10, * recursive: false * }); * console.log(organizations); * } catch (error) { * if (error instanceof AsgardeoAPIError) { * console.error('Failed to get organizations:', error.message); * } * } * ``` * * @example * ```typescript * // Using custom fetcher (e.g., axios-based httpClient) * try { * const organizations = await getMeOrganizations({ * baseUrl: "https://api.asgardeo.io/t/<ORGANIZATION>", * after: "", * before: "", * filter: "", * limit: 10, * recursive: false, * fetcher: async (url, config) => { * const response = await httpClient({ * url, * method: config.method, * headers: config.headers, * ...config * }); * // Convert axios-like response to fetch-like Response * return { * ok: response.status >= 200 && response.status < 300, * status: response.status, * statusText: response.statusText, * json: () => Promise.resolve(response.data), * text: () => Promise.resolve(typeof response.data === 'string' ? response.data : JSON.stringify(response.data)) * } as Response; * } * }); * console.log(organizations); * } catch (error) { * if (error instanceof AsgardeoAPIError) { * console.error('Failed to get organizations:', error.message); * } * } * ``` */ declare const getMeOrganizations: ({ baseUrl, after, authorizedAppName, before, filter, limit, recursive, fetcher, ...requestConfig }: GetMeOrganizationsConfig) => Promise<Organization[]>; export default getMeOrganizations;