mirror of
https://github.com/musix-org/musix-oss
synced 2025-01-14 23:43:08 +00:00
140 lines
5.8 KiB
JavaScript
140 lines
5.8 KiB
JavaScript
|
/*! firebase-admin v8.9.2 */
|
||
|
"use strict";
|
||
|
/*!
|
||
|
* Copyright 2019 Google Inc.
|
||
|
*
|
||
|
* Licensed 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.
|
||
|
*/
|
||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||
|
var auth_api_request_1 = require("./auth-api-request");
|
||
|
var auth_1 = require("./auth");
|
||
|
var tenant_1 = require("./tenant");
|
||
|
var error_1 = require("../utils/error");
|
||
|
var validator = require("../utils/validator");
|
||
|
/**
|
||
|
* Data structure used to help manage tenant related operations.
|
||
|
* This includes:
|
||
|
* - The ability to create, update, list, get and delete tenants for the underlying project.
|
||
|
* - Getting a TenantAwareAuth instance for running Auth related operations (user mgmt, provider config mgmt, etc)
|
||
|
* in the context of a specified tenant.
|
||
|
*/
|
||
|
var TenantManager = /** @class */ (function () {
|
||
|
/**
|
||
|
* Initializes a TenantManager instance for a specified FirebaseApp.
|
||
|
* @param app The app for this TenantManager instance.
|
||
|
*/
|
||
|
function TenantManager(app) {
|
||
|
this.app = app;
|
||
|
this.authRequestHandler = new auth_api_request_1.AuthRequestHandler(app);
|
||
|
this.tenantsMap = {};
|
||
|
}
|
||
|
/**
|
||
|
* Returns a TenantAwareAuth instance for the corresponding tenant ID.
|
||
|
*
|
||
|
* @param tenantId The tenant ID whose TenantAwareAuth is to be returned.
|
||
|
* @return The corresponding TenantAwareAuth instance.
|
||
|
*/
|
||
|
TenantManager.prototype.authForTenant = function (tenantId) {
|
||
|
if (!validator.isNonEmptyString(tenantId)) {
|
||
|
throw new error_1.FirebaseAuthError(error_1.AuthClientErrorCode.INVALID_TENANT_ID);
|
||
|
}
|
||
|
if (typeof this.tenantsMap[tenantId] === 'undefined') {
|
||
|
this.tenantsMap[tenantId] = new auth_1.TenantAwareAuth(this.app, tenantId);
|
||
|
}
|
||
|
return this.tenantsMap[tenantId];
|
||
|
};
|
||
|
/**
|
||
|
* Looks up the tenant identified by the provided tenant ID and returns a promise that is
|
||
|
* fulfilled with the corresponding tenant if it is found.
|
||
|
*
|
||
|
* @param tenantId The tenant ID of the tenant to look up.
|
||
|
* @return A promise that resolves with the corresponding tenant.
|
||
|
*/
|
||
|
TenantManager.prototype.getTenant = function (tenantId) {
|
||
|
return this.authRequestHandler.getTenant(tenantId)
|
||
|
.then(function (response) {
|
||
|
return new tenant_1.Tenant(response);
|
||
|
});
|
||
|
};
|
||
|
/**
|
||
|
* Exports a batch of tenant accounts. Batch size is determined by the maxResults argument.
|
||
|
* Starting point of the batch is determined by the pageToken argument.
|
||
|
*
|
||
|
* @param maxResults The page size, 1000 if undefined. This is also the maximum
|
||
|
* allowed limit.
|
||
|
* @param pageToken The next page token. If not specified, returns users starting
|
||
|
* without any offset.
|
||
|
* @return A promise that resolves with
|
||
|
* the current batch of downloaded tenants and the next page token. For the last page, an
|
||
|
* empty list of tenants and no page token are returned.
|
||
|
*/
|
||
|
TenantManager.prototype.listTenants = function (maxResults, pageToken) {
|
||
|
return this.authRequestHandler.listTenants(maxResults, pageToken)
|
||
|
.then(function (response) {
|
||
|
// List of tenants to return.
|
||
|
var tenants = [];
|
||
|
// Convert each user response to a Tenant.
|
||
|
response.tenants.forEach(function (tenantResponse) {
|
||
|
tenants.push(new tenant_1.Tenant(tenantResponse));
|
||
|
});
|
||
|
// Return list of tenants and the next page token if available.
|
||
|
var result = {
|
||
|
tenants: tenants,
|
||
|
pageToken: response.nextPageToken,
|
||
|
};
|
||
|
// Delete result.pageToken if undefined.
|
||
|
if (typeof result.pageToken === 'undefined') {
|
||
|
delete result.pageToken;
|
||
|
}
|
||
|
return result;
|
||
|
});
|
||
|
};
|
||
|
/**
|
||
|
* Deletes the tenant identified by the provided tenant ID and returns a promise that is
|
||
|
* fulfilled when the tenant is found and successfully deleted.
|
||
|
*
|
||
|
* @param tenantId The tenant ID of the tenant to delete.
|
||
|
* @return A promise that resolves when the tenant is successfully deleted.
|
||
|
*/
|
||
|
TenantManager.prototype.deleteTenant = function (tenantId) {
|
||
|
return this.authRequestHandler.deleteTenant(tenantId);
|
||
|
};
|
||
|
/**
|
||
|
* Creates a new tenant with the properties provided.
|
||
|
*
|
||
|
* @param tenantOptions The properties to set on the new tenant to be created.
|
||
|
* @return A promise that resolves with the newly created tenant.
|
||
|
*/
|
||
|
TenantManager.prototype.createTenant = function (tenantOptions) {
|
||
|
return this.authRequestHandler.createTenant(tenantOptions)
|
||
|
.then(function (response) {
|
||
|
return new tenant_1.Tenant(response);
|
||
|
});
|
||
|
};
|
||
|
/**
|
||
|
* Updates an existing tenant identified by the tenant ID with the properties provided.
|
||
|
*
|
||
|
* @param tenantId The tenant identifier of the tenant to update.
|
||
|
* @param tenantOptions The properties to update on the existing tenant.
|
||
|
* @return A promise that resolves with the modified tenant.
|
||
|
*/
|
||
|
TenantManager.prototype.updateTenant = function (tenantId, tenantOptions) {
|
||
|
return this.authRequestHandler.updateTenant(tenantId, tenantOptions)
|
||
|
.then(function (response) {
|
||
|
return new tenant_1.Tenant(response);
|
||
|
});
|
||
|
};
|
||
|
return TenantManager;
|
||
|
}());
|
||
|
exports.TenantManager = TenantManager;
|