package.dist.src.internal.internal-auth-client.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sdk Show documentation
Show all versions of sdk Show documentation
Client SDK for Momento services
The newest version!
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.permissionsFromDisposableTokenScope = exports.permissionsFromTokenScope = exports.InternalAuthClient = void 0;
const generated_types_1 = require("@gomomento/generated-types");
var grpcAuth = generated_types_1.auth.auth;
const headers_interceptor_1 = require("./grpc/headers-interceptor");
const grpc_js_1 = require("@grpc/grpc-js");
const package_json_1 = require("../../package.json");
const cache_service_error_mapper_1 = require("../errors/cache-service-error-mapper");
const utils_1 = require("@gomomento/sdk-core/dist/src/internal/utils");
var Never = grpcAuth._GenerateApiTokenRequest.Never;
var Expires = grpcAuth._GenerateApiTokenRequest.Expires;
const sdk_core_1 = require("@gomomento/sdk-core");
const permission_scope_1 = require("@gomomento/sdk-core/dist/src/auth/tokens/permission-scope");
const permissionmessages_1 = require("@gomomento/generated-types/dist/permissionmessages");
const utils_2 = require("./utils");
const disposable_token_scope_1 = require("@gomomento/sdk-core/dist/src/auth/tokens/disposable-token-scope");
const retry_interceptor_1 = require("./grpc/retry-interceptor");
const index_1 = require("../index");
const utils_3 = require("@gomomento/sdk-core/dist/src/utils");
class InternalAuthClient {
constructor(props) {
var _a, _b;
const configuration = (_a = props.configuration) !== null && _a !== void 0 ? _a : index_1.AuthClientConfigurations.Default.latest();
this.cacheServiceErrorMapper = new cache_service_error_mapper_1.CacheServiceErrorMapper((_b = props.throwOnErrors) !== null && _b !== void 0 ? _b : false);
this.creds = props.credentialProvider;
const headers = [
new headers_interceptor_1.Header('agent', `nodejs:auth:${package_json_1.version}`),
new headers_interceptor_1.Header('runtime-version', `nodejs:${process.versions.node}`),
];
this.interceptors = [
headers_interceptor_1.HeaderInterceptor.createHeadersInterceptor(headers),
retry_interceptor_1.RetryInterceptor.createRetryInterceptor({
clientName: 'AuthClient',
loggerFactory: configuration.getLoggerFactory(),
overallRequestTimeoutMs: InternalAuthClient.REQUEST_TIMEOUT_MS,
}),
];
this.tokenClient = new generated_types_1.token.token.TokenClient(this.creds.getTokenEndpoint(), this.creds.isTokenEndpointSecure()
? grpc_js_1.ChannelCredentials.createSsl()
: grpc_js_1.ChannelCredentials.createInsecure());
this.authClient = new grpcAuth.AuthClient(this.creds.getControlEndpoint(), this.creds.isTokenEndpointSecure()
? grpc_js_1.ChannelCredentials.createSsl()
: grpc_js_1.ChannelCredentials.createInsecure());
}
async generateApiKey(scope, expiresIn) {
let permissions;
try {
permissions = permissionsFromTokenScope(scope);
}
catch (err) {
return this.cacheServiceErrorMapper.returnOrThrowError(err, err => new sdk_core_1.GenerateApiKey.Error(err));
}
const request = new grpcAuth._GenerateApiTokenRequest({
auth_token: this.creds.getAuthToken(),
permissions: permissions,
});
if (expiresIn.doesExpire()) {
try {
(0, utils_1.validateValidForSeconds)(expiresIn.seconds());
}
catch (err) {
return this.cacheServiceErrorMapper.returnOrThrowError(err, err => new sdk_core_1.GenerateApiKey.Error(err));
}
request.expires = new Expires({
valid_for_seconds: expiresIn.seconds(),
});
}
else {
request.never = new Never();
}
return await new Promise((resolve, reject) => {
this.authClient.GenerateApiToken(request, { interceptors: this.interceptors }, (err, resp) => {
if (err || !resp) {
this.cacheServiceErrorMapper.resolveOrRejectError({
err: err,
errorResponseFactoryFn: e => new sdk_core_1.GenerateApiKey.Error(e),
resolveFn: resolve,
rejectFn: reject,
});
}
else {
resolve(new sdk_core_1.GenerateApiKey.Success(resp.api_key, resp.refresh_token, resp.endpoint, sdk_core_1.ExpiresAt.fromEpoch(resp.valid_until)));
}
});
});
}
/**
* @deprecated please use `generateApiKey` instead
*/
generateAuthToken(scope, expiresIn) {
return this.generateApiKey(scope, expiresIn);
}
async refreshApiKey(refreshToken) {
const request = new grpcAuth._RefreshApiTokenRequest({
api_key: this.creds.getAuthToken(),
refresh_token: refreshToken,
});
return await new Promise((resolve, reject) => {
this.authClient.RefreshApiToken(request, { interceptors: this.interceptors }, (err, resp) => {
if (err || !resp) {
this.cacheServiceErrorMapper.resolveOrRejectError({
err: err,
errorResponseFactoryFn: e => new sdk_core_1.RefreshApiKey.Error(e),
resolveFn: resolve,
rejectFn: reject,
});
}
else {
resolve(new sdk_core_1.RefreshApiKey.Success(resp.api_key, resp.refresh_token, resp.endpoint, sdk_core_1.ExpiresAt.fromEpoch(resp.valid_until)));
}
});
});
}
/**
* @deprecated please use `refreshApiKey` instead
*/
refreshAuthToken(refreshToken) {
return this.refreshApiKey(refreshToken);
}
async generateDisposableToken(scope, expiresIn, disposableTokenProps) {
try {
(0, utils_1.validateDisposableTokenExpiry)(expiresIn);
}
catch (err) {
return this.cacheServiceErrorMapper.returnOrThrowError(err, err => new sdk_core_1.GenerateDisposableToken.Error(err));
}
const expires = new generated_types_1.token.token._GenerateDisposableTokenRequest.Expires({
valid_for_seconds: expiresIn.seconds(),
});
let permissions;
try {
permissions = permissionsFromDisposableTokenScope(scope);
}
catch (err) {
return this.cacheServiceErrorMapper.returnOrThrowError(err, err => new sdk_core_1.GenerateDisposableToken.Error(err));
}
const tokenId = disposableTokenProps === null || disposableTokenProps === void 0 ? void 0 : disposableTokenProps.tokenId;
if (tokenId !== undefined) {
try {
(0, utils_1.validateDisposableTokenTokenID)(tokenId);
}
catch (err) {
return this.cacheServiceErrorMapper.returnOrThrowError(err, err => new sdk_core_1.GenerateDisposableToken.Error(err));
}
}
const request = new generated_types_1.token.token._GenerateDisposableTokenRequest({
expires: expires,
auth_token: this.creds.getAuthToken(),
permissions: permissions,
token_id: tokenId,
});
return await new Promise((resolve, reject) => {
this.tokenClient.GenerateDisposableToken(request, { interceptors: this.interceptors }, (err, resp) => {
if (err || !resp) {
this.cacheServiceErrorMapper.resolveOrRejectError({
err: err,
errorResponseFactoryFn: e => new sdk_core_1.GenerateDisposableToken.Error(e),
resolveFn: resolve,
rejectFn: reject,
});
}
else {
resolve(new sdk_core_1.GenerateDisposableToken.Success(resp.api_key, resp.endpoint, sdk_core_1.ExpiresAt.fromEpoch(resp.valid_until)));
}
});
});
}
}
exports.InternalAuthClient = InternalAuthClient;
InternalAuthClient.REQUEST_TIMEOUT_MS = (0, utils_3.secondsToMilliseconds)(60);
function permissionsFromTokenScope(scope) {
const result = new permissionmessages_1.permission_messages.Permissions();
if (scope instanceof utils_1.InternalSuperUserPermissions) {
result.super_user = permissionmessages_1.permission_messages.SuperUserPermissions.SuperUser;
return result;
}
else if ((0, permission_scope_1.isPermissionsObject)(scope)) {
const scopePermissions = (0, permission_scope_1.asPermissionsObject)(scope);
const explicitPermissions = new permissionmessages_1.permission_messages.ExplicitPermissions();
explicitPermissions.permissions = scopePermissions.permissions.map(p => tokenPermissionToGrpcPermission(p));
result.explicit = explicitPermissions;
return result;
}
throw new Error(`Unrecognized token scope: ${JSON.stringify(scope)}`);
}
exports.permissionsFromTokenScope = permissionsFromTokenScope;
function permissionsFromDisposableTokenScope(scope) {
const result = new permissionmessages_1.permission_messages.Permissions();
if (!(scope instanceof permission_scope_1.PredefinedScope) &&
(0, disposable_token_scope_1.isDisposableTokenPermissionsObject)(scope)) {
const scopePermissions = (0, disposable_token_scope_1.asDisposableTokenPermissionsObject)(scope);
const explicitPermissions = new permissionmessages_1.permission_messages.ExplicitPermissions();
explicitPermissions.permissions = scopePermissions.permissions.map(p => disposableTokenPermissionToGrpcPermission(p));
result.explicit = explicitPermissions;
return result;
}
else if ((0, permission_scope_1.isPermissionsObject)(scope)) {
const scopePermissions = (0, permission_scope_1.asPermissionsObject)(scope);
const explicitPermissions = new permissionmessages_1.permission_messages.ExplicitPermissions();
explicitPermissions.permissions = scopePermissions.permissions.map(p => tokenPermissionToGrpcPermission(p));
result.explicit = explicitPermissions;
return result;
}
throw new Error(`Unrecognized token scope: ${JSON.stringify(scope)}`);
}
exports.permissionsFromDisposableTokenScope = permissionsFromDisposableTokenScope;
function tokenPermissionToGrpcPermission(permission) {
const result = new permissionmessages_1.permission_messages.PermissionsType();
if ((0, permission_scope_1.isTopicPermission)(permission)) {
result.topic_permissions = topicPermissionToGrpcPermission((0, permission_scope_1.asTopicPermission)(permission));
return result;
}
else if ((0, permission_scope_1.isCachePermission)(permission)) {
result.cache_permissions = cachePermissionToGrpcPermission((0, permission_scope_1.asCachePermission)(permission));
return result;
}
throw new Error(`Unrecognized token permission: ${JSON.stringify(permission)}`);
}
function topicPermissionToGrpcPermission(permission) {
const grpcPermission = new permissionmessages_1.permission_messages.PermissionsType.TopicPermissions();
switch (permission.role) {
case sdk_core_1.TopicRole.PublishSubscribe: {
grpcPermission.role = permissionmessages_1.permission_messages.TopicRole.TopicReadWrite;
break;
}
case sdk_core_1.TopicRole.SubscribeOnly: {
grpcPermission.role = permissionmessages_1.permission_messages.TopicRole.TopicReadOnly;
break;
}
case sdk_core_1.TopicRole.PublishOnly: {
grpcPermission.role = permissionmessages_1.permission_messages.TopicRole.TopicWriteOnly;
break;
}
default: {
throw new Error(`Unrecognized topic role: ${JSON.stringify(permission)}`);
}
}
if (permission.cache === sdk_core_1.AllCaches) {
grpcPermission.all_caches = new permissionmessages_1.permission_messages.PermissionsType.All();
}
else if (typeof permission.cache === 'string') {
grpcPermission.cache_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheSelector({
cache_name: permission.cache,
});
}
else if ((0, sdk_core_1.isCacheName)(permission.cache)) {
grpcPermission.cache_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheSelector({
cache_name: permission.cache.name,
});
}
else {
throw new Error(`Unrecognized cache specification in topic permission: ${JSON.stringify(permission)}`);
}
if (permission.topic === sdk_core_1.AllTopics) {
grpcPermission.all_topics = new permissionmessages_1.permission_messages.PermissionsType.All();
}
else if (typeof permission.topic === 'string') {
grpcPermission.topic_selector =
new permissionmessages_1.permission_messages.PermissionsType.TopicSelector({
topic_name: permission.topic,
});
}
else if ((0, sdk_core_1.isTopicName)(permission.topic)) {
grpcPermission.topic_selector =
new permissionmessages_1.permission_messages.PermissionsType.TopicSelector({
topic_name: permission.topic.name,
});
}
else {
throw new Error(`Unrecognized topic specification in topic permission: ${JSON.stringify(permission)}`);
}
return grpcPermission;
}
function assignCacheRole(permission, grpcPermission) {
switch (permission.role) {
case sdk_core_1.CacheRole.ReadWrite: {
grpcPermission.role = permissionmessages_1.permission_messages.CacheRole.CacheReadWrite;
break;
}
case sdk_core_1.CacheRole.ReadOnly: {
grpcPermission.role = permissionmessages_1.permission_messages.CacheRole.CacheReadOnly;
break;
}
case sdk_core_1.CacheRole.WriteOnly: {
grpcPermission.role = permissionmessages_1.permission_messages.CacheRole.CacheWriteOnly;
break;
}
default: {
throw new Error(`Unrecognized cache role: ${JSON.stringify(permission)}`);
}
}
return grpcPermission;
}
function assignCacheSelector(permission, grpcPermission) {
if (permission.cache === sdk_core_1.AllCaches) {
grpcPermission.all_caches = new permissionmessages_1.permission_messages.PermissionsType.All();
}
else if (typeof permission.cache === 'string') {
grpcPermission.cache_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheSelector({
cache_name: permission.cache,
});
}
else if ((0, sdk_core_1.isCacheName)(permission.cache)) {
grpcPermission.cache_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheSelector({
cache_name: permission.cache.name,
});
}
else {
throw new Error(`Unrecognized cache specification in cache permission: ${JSON.stringify(permission)}`);
}
return grpcPermission;
}
function assignCacheItemSelector(permission, grpcPermission) {
if (permission.item === sdk_core_1.AllCacheItems) {
grpcPermission.all_items = new permissionmessages_1.permission_messages.PermissionsType.All();
}
else if (typeof permission.item === 'string') {
grpcPermission.item_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheItemSelector({
key: (0, utils_2.convert)(permission.item),
});
}
else if ((0, sdk_core_1.isCacheItemKey)(permission.item)) {
(0, utils_1.validateCacheKeyOrPrefix)(permission.item.key);
grpcPermission.item_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheItemSelector({
key: (0, utils_2.convert)(permission.item.key),
});
}
else if ((0, sdk_core_1.isCacheItemKeyPrefix)(permission.item)) {
(0, utils_1.validateCacheKeyOrPrefix)(permission.item.keyPrefix);
grpcPermission.item_selector =
new permissionmessages_1.permission_messages.PermissionsType.CacheItemSelector({
key_prefix: (0, utils_2.convert)(permission.item.keyPrefix),
});
}
else {
throw new Error(`Unrecognized cache item specification in cache permission: ${JSON.stringify(permission)}`);
}
return grpcPermission;
}
function cachePermissionToGrpcPermission(permission) {
let grpcPermission = new permissionmessages_1.permission_messages.PermissionsType.CachePermissions();
grpcPermission = assignCacheRole(permission, grpcPermission);
grpcPermission = assignCacheSelector(permission, grpcPermission);
return grpcPermission;
}
function disposableTokenPermissionToGrpcPermission(permission) {
const result = new permissionmessages_1.permission_messages.PermissionsType();
if ((0, disposable_token_scope_1.isDisposableTokenCachePermission)(permission)) {
result.cache_permissions = disposableCachePermissionToGrpcPermission((0, disposable_token_scope_1.asDisposableTokenCachePermission)(permission));
return result;
}
throw new Error(`Unrecognized token permission: ${JSON.stringify(permission)}`);
}
function disposableCachePermissionToGrpcPermission(permission) {
let grpcPermission = new permissionmessages_1.permission_messages.PermissionsType.CachePermissions();
grpcPermission = assignCacheRole(permission, grpcPermission);
grpcPermission = assignCacheSelector(permission, grpcPermission);
grpcPermission = assignCacheItemSelector(permission, grpcPermission);
return grpcPermission;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"internal-auth-client.js","sourceRoot":"","sources":["../../../src/internal/internal-auth-client.ts"],"names":[],"mappings":"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","sourcesContent":["import {auth, token} from '@gomomento/generated-types';\nimport grpcAuth = auth.auth;\nimport {Header, HeaderInterceptor} from './grpc/headers-interceptor';\nimport {ChannelCredentials, Interceptor} from '@grpc/grpc-js';\nimport {version} from '../../package.json';\nimport {CacheServiceErrorMapper} from '../errors/cache-service-error-mapper';\nimport {\n  InternalSuperUserPermissions,\n  validateDisposableTokenExpiry,\n  validateValidForSeconds,\n  validateCacheKeyOrPrefix,\n  validateDisposableTokenTokenID,\n} from '@gomomento/sdk-core/dist/src/internal/utils';\nimport Never = grpcAuth._GenerateApiTokenRequest.Never;\nimport Expires = grpcAuth._GenerateApiTokenRequest.Expires;\nimport {\n  ExpiresIn,\n  ExpiresAt,\n  CredentialProvider,\n  RefreshApiKey,\n  GenerateApiKey,\n  PermissionScope,\n  Permissions,\n  Permission,\n  TopicPermission,\n  CachePermission,\n  TopicRole,\n  CacheRole,\n  AllCaches,\n  AllTopics,\n  isCacheName,\n  isTopicName,\n  GenerateDisposableToken,\n  AllCacheItems,\n  isCacheItemKey,\n  isCacheItemKeyPrefix,\n  DisposableTokenScope,\n} from '@gomomento/sdk-core';\nimport {IAuthClient} from '@gomomento/sdk-core/dist/src/internal/clients';\nimport {\n  asCachePermission,\n  asPermissionsObject,\n  asTopicPermission,\n  isCachePermission,\n  isPermissionsObject,\n  isTopicPermission,\n  PredefinedScope,\n} from '@gomomento/sdk-core/dist/src/auth/tokens/permission-scope';\nimport {permission_messages} from '@gomomento/generated-types/dist/permissionmessages';\nimport {convert} from './utils';\nimport {\n  asDisposableTokenCachePermission,\n  asDisposableTokenPermissionsObject,\n  DisposableTokenCachePermission,\n  DisposableTokenProps,\n  isDisposableTokenCachePermission,\n  isDisposableTokenPermissionsObject,\n} from '@gomomento/sdk-core/dist/src/auth/tokens/disposable-token-scope';\nimport {RetryInterceptor} from './grpc/retry-interceptor';\nimport {AuthClientConfigurations} from '../index';\nimport {AuthClientAllProps} from './auth-client-all-props';\nimport {secondsToMilliseconds} from '@gomomento/sdk-core/dist/src/utils';\n\nexport class InternalAuthClient implements IAuthClient {\n  private static readonly REQUEST_TIMEOUT_MS: number =\n    secondsToMilliseconds(60);\n\n  private readonly cacheServiceErrorMapper: CacheServiceErrorMapper;\n  private readonly creds: CredentialProvider;\n  private readonly interceptors: Interceptor[];\n  private readonly tokenClient: token.token.TokenClient;\n  private readonly authClient: grpcAuth.AuthClient;\n\n  constructor(props: AuthClientAllProps) {\n    const configuration =\n      props.configuration ?? AuthClientConfigurations.Default.latest();\n    this.cacheServiceErrorMapper = new CacheServiceErrorMapper(\n      props.throwOnErrors ?? false\n    );\n    this.creds = props.credentialProvider;\n    const headers = [\n      new Header('agent', `nodejs:auth:${version}`),\n      new Header('runtime-version', `nodejs:${process.versions.node}`),\n    ];\n    this.interceptors = [\n      HeaderInterceptor.createHeadersInterceptor(headers),\n      RetryInterceptor.createRetryInterceptor({\n        clientName: 'AuthClient',\n        loggerFactory: configuration.getLoggerFactory(),\n        overallRequestTimeoutMs: InternalAuthClient.REQUEST_TIMEOUT_MS,\n      }),\n    ];\n    this.tokenClient = new token.token.TokenClient(\n      this.creds.getTokenEndpoint(),\n      this.creds.isTokenEndpointSecure()\n        ? ChannelCredentials.createSsl()\n        : ChannelCredentials.createInsecure()\n    );\n    this.authClient = new grpcAuth.AuthClient(\n      this.creds.getControlEndpoint(),\n      this.creds.isTokenEndpointSecure()\n        ? ChannelCredentials.createSsl()\n        : ChannelCredentials.createInsecure()\n    );\n  }\n\n  public async generateApiKey(\n    scope: PermissionScope,\n    expiresIn: ExpiresIn\n  ): Promise<GenerateApiKey.Response> {\n    let permissions;\n    try {\n      permissions = permissionsFromTokenScope(scope);\n    } catch (err) {\n      return this.cacheServiceErrorMapper.returnOrThrowError(\n        err as Error,\n        err => new GenerateApiKey.Error(err)\n      );\n    }\n    const request = new grpcAuth._GenerateApiTokenRequest({\n      auth_token: this.creds.getAuthToken(),\n      permissions: permissions,\n    });\n\n    if (expiresIn.doesExpire()) {\n      try {\n        validateValidForSeconds(expiresIn.seconds());\n      } catch (err) {\n        return this.cacheServiceErrorMapper.returnOrThrowError(\n          err as Error,\n          err => new GenerateApiKey.Error(err)\n        );\n      }\n\n      request.expires = new Expires({\n        valid_for_seconds: expiresIn.seconds(),\n      });\n    } else {\n      request.never = new Never();\n    }\n\n    return await new Promise<GenerateApiKey.Response>((resolve, reject) => {\n      this.authClient.GenerateApiToken(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err || !resp) {\n            this.cacheServiceErrorMapper.resolveOrRejectError({\n              err: err,\n              errorResponseFactoryFn: e => new GenerateApiKey.Error(e),\n              resolveFn: resolve,\n              rejectFn: reject,\n            });\n          } else {\n            resolve(\n              new GenerateApiKey.Success(\n                resp.api_key,\n                resp.refresh_token,\n                resp.endpoint,\n                ExpiresAt.fromEpoch(resp.valid_until)\n              )\n            );\n          }\n        }\n      );\n    });\n  }\n\n  /**\n   * @deprecated please use `generateApiKey` instead\n   */\n  public generateAuthToken(\n    scope: PermissionScope,\n    expiresIn: ExpiresIn\n  ): Promise<GenerateApiKey.Response> {\n    return this.generateApiKey(scope, expiresIn);\n  }\n\n  public async refreshApiKey(\n    refreshToken: string\n  ): Promise<RefreshApiKey.Response> {\n    const request = new grpcAuth._RefreshApiTokenRequest({\n      api_key: this.creds.getAuthToken(),\n      refresh_token: refreshToken,\n    });\n\n    return await new Promise<RefreshApiKey.Response>((resolve, reject) => {\n      this.authClient.RefreshApiToken(\n        request,\n        {interceptors: this.interceptors},\n        (err, resp) => {\n          if (err || !resp) {\n            this.cacheServiceErrorMapper.resolveOrRejectError({\n              err: err,\n              errorResponseFactoryFn: e => new RefreshApiKey.Error(e),\n              resolveFn: resolve,\n              rejectFn: reject,\n            });\n          } else {\n            resolve(\n              new RefreshApiKey.Success(\n                resp.api_key,\n                resp.refresh_token,\n                resp.endpoint,\n                ExpiresAt.fromEpoch(resp.valid_until)\n              )\n            );\n          }\n        }\n      );\n    });\n  }\n\n  /**\n   * @deprecated please use `refreshApiKey` instead\n   */\n  public refreshAuthToken(\n    refreshToken: string\n  ): Promise<RefreshApiKey.Response> {\n    return this.refreshApiKey(refreshToken);\n  }\n\n  public async generateDisposableToken(\n    scope: DisposableTokenScope,\n    expiresIn: ExpiresIn,\n    disposableTokenProps?: DisposableTokenProps\n  ): Promise<GenerateDisposableToken.Response> {\n    try {\n      validateDisposableTokenExpiry(expiresIn);\n    } catch (err) {\n      return this.cacheServiceErrorMapper.returnOrThrowError(\n        err as Error,\n        err => new GenerateDisposableToken.Error(err)\n      );\n    }\n    const expires = new token.token._GenerateDisposableTokenRequest.Expires({\n      valid_for_seconds: expiresIn.seconds(),\n    });\n\n    let permissions;\n    try {\n      permissions = permissionsFromDisposableTokenScope(scope);\n    } catch (err) {\n      return this.cacheServiceErrorMapper.returnOrThrowError(\n        err as Error,\n        err => new GenerateDisposableToken.Error(err)\n      );\n    }\n\n    const tokenId = disposableTokenProps?.tokenId;\n    if (tokenId !== undefined) {\n      try {\n        validateDisposableTokenTokenID(tokenId);\n      } catch (err) {\n        return this.cacheServiceErrorMapper.returnOrThrowError(\n          err as Error,\n          err => new GenerateDisposableToken.Error(err)\n        );\n      }\n    }\n\n    const request = new token.token._GenerateDisposableTokenRequest({\n      expires: expires,\n      auth_token: this.creds.getAuthToken(),\n      permissions: permissions,\n      token_id: tokenId,\n    });\n\n    return await new Promise<GenerateDisposableToken.Response>(\n      (resolve, reject) => {\n        this.tokenClient.GenerateDisposableToken(\n          request,\n          {interceptors: this.interceptors},\n          (err, resp) => {\n            if (err || !resp) {\n              this.cacheServiceErrorMapper.resolveOrRejectError({\n                err: err,\n                errorResponseFactoryFn: e =>\n                  new GenerateDisposableToken.Error(e),\n                resolveFn: resolve,\n                rejectFn: reject,\n              });\n            } else {\n              resolve(\n                new GenerateDisposableToken.Success(\n                  resp.api_key,\n                  resp.endpoint,\n                  ExpiresAt.fromEpoch(resp.valid_until)\n                )\n              );\n            }\n          }\n        );\n      }\n    );\n  }\n}\n\nexport function permissionsFromTokenScope(\n  scope: PermissionScope\n): permission_messages.Permissions {\n  const result = new permission_messages.Permissions();\n  if (scope instanceof InternalSuperUserPermissions) {\n    result.super_user = permission_messages.SuperUserPermissions.SuperUser;\n    return result;\n  } else if (isPermissionsObject(scope)) {\n    const scopePermissions: Permissions = asPermissionsObject(scope);\n    const explicitPermissions = new permission_messages.ExplicitPermissions();\n    explicitPermissions.permissions = scopePermissions.permissions.map(p =>\n      tokenPermissionToGrpcPermission(p)\n    );\n    result.explicit = explicitPermissions;\n    return result;\n  }\n  throw new Error(`Unrecognized token scope: ${JSON.stringify(scope)}`);\n}\n\nexport function permissionsFromDisposableTokenScope(\n  scope: DisposableTokenScope\n): permission_messages.Permissions {\n  const result = new permission_messages.Permissions();\n  if (\n    !(scope instanceof PredefinedScope) &&\n    isDisposableTokenPermissionsObject(scope)\n  ) {\n    const scopePermissions = asDisposableTokenPermissionsObject(scope);\n    const explicitPermissions = new permission_messages.ExplicitPermissions();\n    explicitPermissions.permissions = scopePermissions.permissions.map(p =>\n      disposableTokenPermissionToGrpcPermission(p)\n    );\n    result.explicit = explicitPermissions;\n    return result;\n  } else if (isPermissionsObject(scope)) {\n    const scopePermissions: Permissions = asPermissionsObject(scope);\n    const explicitPermissions = new permission_messages.ExplicitPermissions();\n    explicitPermissions.permissions = scopePermissions.permissions.map(p =>\n      tokenPermissionToGrpcPermission(p)\n    );\n    result.explicit = explicitPermissions;\n    return result;\n  }\n  throw new Error(`Unrecognized token scope: ${JSON.stringify(scope)}`);\n}\n\nfunction tokenPermissionToGrpcPermission(\n  permission: Permission\n): permission_messages.PermissionsType {\n  const result = new permission_messages.PermissionsType();\n  if (isTopicPermission(permission)) {\n    result.topic_permissions = topicPermissionToGrpcPermission(\n      asTopicPermission(permission)\n    );\n    return result;\n  } else if (isCachePermission(permission)) {\n    result.cache_permissions = cachePermissionToGrpcPermission(\n      asCachePermission(permission)\n    );\n    return result;\n  }\n  throw new Error(\n    `Unrecognized token permission: ${JSON.stringify(permission)}`\n  );\n}\n\nfunction topicPermissionToGrpcPermission(\n  permission: TopicPermission\n): permission_messages.PermissionsType.TopicPermissions {\n  const grpcPermission =\n    new permission_messages.PermissionsType.TopicPermissions();\n  switch (permission.role) {\n    case TopicRole.PublishSubscribe: {\n      grpcPermission.role = permission_messages.TopicRole.TopicReadWrite;\n      break;\n    }\n    case TopicRole.SubscribeOnly: {\n      grpcPermission.role = permission_messages.TopicRole.TopicReadOnly;\n      break;\n    }\n    case TopicRole.PublishOnly: {\n      grpcPermission.role = permission_messages.TopicRole.TopicWriteOnly;\n      break;\n    }\n    default: {\n      throw new Error(`Unrecognized topic role: ${JSON.stringify(permission)}`);\n    }\n  }\n\n  if (permission.cache === AllCaches) {\n    grpcPermission.all_caches = new permission_messages.PermissionsType.All();\n  } else if (typeof permission.cache === 'string') {\n    grpcPermission.cache_selector =\n      new permission_messages.PermissionsType.CacheSelector({\n        cache_name: permission.cache,\n      });\n  } else if (isCacheName(permission.cache)) {\n    grpcPermission.cache_selector =\n      new permission_messages.PermissionsType.CacheSelector({\n        cache_name: permission.cache.name,\n      });\n  } else {\n    throw new Error(\n      `Unrecognized cache specification in topic permission: ${JSON.stringify(\n        permission\n      )}`\n    );\n  }\n\n  if (permission.topic === AllTopics) {\n    grpcPermission.all_topics = new permission_messages.PermissionsType.All();\n  } else if (typeof permission.topic === 'string') {\n    grpcPermission.topic_selector =\n      new permission_messages.PermissionsType.TopicSelector({\n        topic_name: permission.topic,\n      });\n  } else if (isTopicName(permission.topic)) {\n    grpcPermission.topic_selector =\n      new permission_messages.PermissionsType.TopicSelector({\n        topic_name: permission.topic.name,\n      });\n  } else {\n    throw new Error(\n      `Unrecognized topic specification in topic permission: ${JSON.stringify(\n        permission\n      )}`\n    );\n  }\n  return grpcPermission;\n}\n\nfunction assignCacheRole(\n  permission: CachePermission | DisposableTokenCachePermission,\n  grpcPermission: permission_messages.PermissionsType.CachePermissions\n): permission_messages.PermissionsType.CachePermissions {\n  switch (permission.role) {\n    case CacheRole.ReadWrite: {\n      grpcPermission.role = permission_messages.CacheRole.CacheReadWrite;\n      break;\n    }\n    case CacheRole.ReadOnly: {\n      grpcPermission.role = permission_messages.CacheRole.CacheReadOnly;\n      break;\n    }\n    case CacheRole.WriteOnly: {\n      grpcPermission.role = permission_messages.CacheRole.CacheWriteOnly;\n      break;\n    }\n    default: {\n      throw new Error(`Unrecognized cache role: ${JSON.stringify(permission)}`);\n    }\n  }\n  return grpcPermission;\n}\n\nfunction assignCacheSelector(\n  permission: CachePermission | DisposableTokenCachePermission,\n  grpcPermission: permission_messages.PermissionsType.CachePermissions\n): permission_messages.PermissionsType.CachePermissions {\n  if (permission.cache === AllCaches) {\n    grpcPermission.all_caches = new permission_messages.PermissionsType.All();\n  } else if (typeof permission.cache === 'string') {\n    grpcPermission.cache_selector =\n      new permission_messages.PermissionsType.CacheSelector({\n        cache_name: permission.cache,\n      });\n  } else if (isCacheName(permission.cache)) {\n    grpcPermission.cache_selector =\n      new permission_messages.PermissionsType.CacheSelector({\n        cache_name: permission.cache.name,\n      });\n  } else {\n    throw new Error(\n      `Unrecognized cache specification in cache permission: ${JSON.stringify(\n        permission\n      )}`\n    );\n  }\n  return grpcPermission;\n}\n\nfunction assignCacheItemSelector(\n  permission: DisposableTokenCachePermission,\n  grpcPermission: permission_messages.PermissionsType.CachePermissions\n): permission_messages.PermissionsType.CachePermissions {\n  if (permission.item === AllCacheItems) {\n    grpcPermission.all_items = new permission_messages.PermissionsType.All();\n  } else if (typeof permission.item === 'string') {\n    grpcPermission.item_selector =\n      new permission_messages.PermissionsType.CacheItemSelector({\n        key: convert(permission.item),\n      });\n  } else if (isCacheItemKey(permission.item)) {\n    validateCacheKeyOrPrefix(permission.item.key);\n    grpcPermission.item_selector =\n      new permission_messages.PermissionsType.CacheItemSelector({\n        key: convert(permission.item.key),\n      });\n  } else if (isCacheItemKeyPrefix(permission.item)) {\n    validateCacheKeyOrPrefix(permission.item.keyPrefix);\n    grpcPermission.item_selector =\n      new permission_messages.PermissionsType.CacheItemSelector({\n        key_prefix: convert(permission.item.keyPrefix),\n      });\n  } else {\n    throw new Error(\n      `Unrecognized cache item specification in cache permission: ${JSON.stringify(\n        permission\n      )}`\n    );\n  }\n  return grpcPermission;\n}\n\nfunction cachePermissionToGrpcPermission(\n  permission: CachePermission\n): permission_messages.PermissionsType.CachePermissions {\n  let grpcPermission =\n    new permission_messages.PermissionsType.CachePermissions();\n  grpcPermission = assignCacheRole(permission, grpcPermission);\n  grpcPermission = assignCacheSelector(permission, grpcPermission);\n  return grpcPermission;\n}\n\nfunction disposableTokenPermissionToGrpcPermission(\n  permission: DisposableTokenCachePermission\n): permission_messages.PermissionsType {\n  const result = new permission_messages.PermissionsType();\n  if (isDisposableTokenCachePermission(permission)) {\n    result.cache_permissions = disposableCachePermissionToGrpcPermission(\n      asDisposableTokenCachePermission(permission)\n    );\n    return result;\n  }\n  throw new Error(\n    `Unrecognized token permission: ${JSON.stringify(permission)}`\n  );\n}\n\nfunction disposableCachePermissionToGrpcPermission(\n  permission: DisposableTokenCachePermission\n): permission_messages.PermissionsType.CachePermissions {\n  let grpcPermission =\n    new permission_messages.PermissionsType.CachePermissions();\n  grpcPermission = assignCacheRole(permission, grpcPermission);\n  grpcPermission = assignCacheSelector(permission, grpcPermission);\n  grpcPermission = assignCacheItemSelector(permission, grpcPermission);\n\n  return grpcPermission;\n}\n"]}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy