@gomomento/sdk-core 1.42.1 → 1.44.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/auth/tokens/disposable-token-scope.d.ts +3 -0
- package/dist/src/auth/tokens/disposable-token-scope.js +1 -1
- package/dist/src/clients/IAuthClient.d.ts +2 -1
- package/dist/src/clients/IAuthClient.js +1 -1
- package/dist/src/clients/ILeaderboard.d.ts +7 -7
- package/dist/src/clients/ILeaderboard.js +1 -1
- package/dist/src/internal/clients/auth/AbstractAuthClient.d.ts +3 -1
- package/dist/src/internal/clients/auth/AbstractAuthClient.js +4 -3
- package/dist/src/internal/clients/leaderboard/AbstractLeaderboard.d.ts +18 -19
- package/dist/src/internal/clients/leaderboard/AbstractLeaderboard.js +26 -27
- package/dist/src/internal/clients/leaderboard/ILeaderboardDataClient.d.ts +7 -7
- package/dist/src/internal/clients/leaderboard/ILeaderboardDataClient.js +1 -1
- package/dist/src/internal/utils/validators.d.ts +1 -0
- package/dist/src/internal/utils/validators.js +8 -2
- package/dist/src/messages/responses/leaderboard/leaderboard-fetch.d.ts +9 -18
- package/dist/src/messages/responses/leaderboard/leaderboard-fetch.js +7 -16
- package/dist/src/messages/responses/leaderboard/leaderboard-length.d.ts +8 -17
- package/dist/src/messages/responses/leaderboard/leaderboard-length.js +6 -15
- package/dist/src/messages/responses/vector/vector-search.d.ts +1 -1
- package/dist/src/messages/responses/vector/vector-search.js +1 -1
- package/dist/src/messages/vector-index.d.ts +1 -1
- package/dist/src/messages/vector-index.js +1 -1
- package/dist/src/utils/cache-call-options.d.ts +0 -14
- package/dist/src/utils/cache-call-options.js +1 -1
- package/package.json +1 -1
@@ -20,5 +20,8 @@ export interface DisposableTokenCachePermissions {
|
|
20
20
|
permissions: Array<DisposableTokenCachePermission>;
|
21
21
|
}
|
22
22
|
export type DisposableTokenScope = Permissions | PredefinedScope | DisposableTokenCachePermissions;
|
23
|
+
export interface DisposableTokenProps {
|
24
|
+
tokenId?: string;
|
25
|
+
}
|
23
26
|
export declare function isDisposableTokenPermissionsObject(scope: DisposableTokenScope): boolean;
|
24
27
|
export declare function asDisposableTokenPermissionsObject(scope: DisposableTokenScope): DisposableTokenCachePermissions;
|
@@ -51,4 +51,4 @@ function asDisposableTokenPermissionsObject(scope) {
|
|
51
51
|
return scope;
|
52
52
|
}
|
53
53
|
exports.asDisposableTokenPermissionsObject = asDisposableTokenPermissionsObject;
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcG9zYWJsZS10b2tlbi1zY29wZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hdXRoL3Rva2Vucy9kaXNwb3NhYmxlLXRva2VuLXNjb3BlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlEQU00QjtBQVU1QixTQUFnQixjQUFjLENBQzVCLFNBQTRCO0lBRTVCLElBQUksU0FBUyxLQUFLLGdDQUFhLEVBQUU7UUFDL0IsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELElBQUksT0FBTyxTQUFTLEtBQUssUUFBUSxFQUFFO1FBQ2pDLE9BQU8sSUFBSSxDQUFDO0tBQ2I7SUFDRCxPQUFPLEtBQUssSUFBSSxTQUFTLENBQUM7QUFDNUIsQ0FBQztBQVZELHdDQVVDO0FBRUQsU0FBZ0Isb0JBQW9CLENBQ2xDLFNBQTRCO0lBRTVCLElBQUksU0FBUyxLQUFLLGdDQUFhLEVBQUU7UUFDL0IsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELElBQUksT0FBTyxTQUFTLEtBQUssUUFBUSxFQUFFO1FBQ2pDLE9BQU8sS0FBSyxDQUFDO0tBQ2Q7SUFDRCxPQUFPLFdBQVcsSUFBSSxTQUFTLENBQUM7QUFDbEMsQ0FBQztBQVZELG9EQVVDO0FBZUQsU0FBZ0IsZ0NBQWdDLENBQUMsQ0FBYTtJQUM1RCxPQUFPLE1BQU0sSUFBSSxDQUFDLElBQUksT0FBTyxJQUFJLENBQUMsSUFBSSxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUM7QUFDdkUsQ0FBQztBQUZELDRFQUVDO0FBRUQsU0FBZ0IsZ0NBQWdDLENBQzlDLENBQWE7SUFFYixJQUFJLENBQUMsZ0NBQWdDLENBQUMsQ0FBQyxDQUFDLEVBQUU7UUFDeEMsTUFBTSxJQUFJLEtBQUssQ0FDYiw4REFBOEQsSUFBSSxDQUFDLFNBQVMsQ0FDMUUsQ0FBQyxDQUNGLEVBQUUsQ0FDSixDQUFDO0tBQ0g7SUFDRCxPQUFPLENBQW1DLENBQUM7QUFDN0MsQ0FBQztBQVhELDRFQVdDO0FBZUQsU0FBUyxpQ0FBaUMsQ0FBQyxDQUFhO0lBQ3RELE9BQU8sZ0NBQWdDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDN0MsQ0FBQztBQUVELFNBQWdCLGtDQUFrQyxDQUNoRCxLQUEyQjtJQUUzQixJQUFJLENBQUMsQ0FBQyxhQUFhLElBQUksS0FBSyxDQUFDLEVBQUU7UUFDN0IsT0FBTyxLQUFLLENBQUM7S0FDZDtJQUNELE1BQU0sV0FBVyxHQUFHLEtBQUssQ0FBQyxXQUFXLENBQUM7SUFDdEMsT0FBTyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsaUNBQWlDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUN0RSxDQUFDO0FBUkQsZ0ZBUUM7QUFFRCxTQUFnQixrQ0FBa0MsQ0FDaEQsS0FBMkI7SUFFM0IsSUFBSSxDQUFDLGtDQUFrQyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQzlDLE1BQU0sSUFBSSxLQUFLLENBQ2IsZ0VBQWdFLElBQUksQ0FBQyxTQUFTLENBQzVFLEtBQUssQ0FDTixFQUFFLENBQ0osQ0FBQztLQUNIO0lBQ0QsT0FBTyxLQUF3QyxDQUFDO0FBQ2xELENBQUM7QUFYRCxnRkFXQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFsbENhY2hlSXRlbXMsXG4gIENhY2hlUGVybWlzc2lvbixcbiAgUGVybWlzc2lvbixcbiAgUGVybWlzc2lvbnMsXG4gIFByZWRlZmluZWRTY29wZSxcbn0gZnJvbSAnLi9wZXJtaXNzaW9uLXNjb3BlJztcblxuZXhwb3J0IGludGVyZmFjZSBDYWNoZUl0ZW1LZXkge1xuICBrZXk6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDYWNoZUl0ZW1LZXlQcmVmaXgge1xuICBrZXlQcmVmaXg6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2FjaGVJdGVtS2V5KFxuICBjYWNoZUl0ZW06IENhY2hlSXRlbVNlbGVjdG9yXG4pOiBjYWNoZUl0ZW0gaXMgQ2FjaGVJdGVtS2V5IHtcbiAgaWYgKGNhY2hlSXRlbSA9PT0gQWxsQ2FjaGVJdGVtcykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBpZiAodHlwZW9mIGNhY2hlSXRlbSA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICByZXR1cm4gJ2tleScgaW4gY2FjaGVJdGVtO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNDYWNoZUl0ZW1LZXlQcmVmaXgoXG4gIGNhY2hlSXRlbTogQ2FjaGVJdGVtU2VsZWN0b3Jcbik6IGNhY2hlSXRlbSBpcyBDYWNoZUl0ZW1LZXlQcmVmaXgge1xuICBpZiAoY2FjaGVJdGVtID09PSBBbGxDYWNoZUl0ZW1zKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIGlmICh0eXBlb2YgY2FjaGVJdGVtID09PSAnc3RyaW5nJykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gJ2tleVByZWZpeCcgaW4gY2FjaGVJdGVtO1xufVxuXG5leHBvcnQgdHlwZSBDYWNoZUl0ZW1TZWxlY3RvciA9XG4gIHwgdHlwZW9mIEFsbENhY2hlSXRlbXNcbiAgfCBDYWNoZUl0ZW1LZXlcbiAgfCBDYWNoZUl0ZW1LZXlQcmVmaXhcbiAgfCBzdHJpbmc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9uIGV4dGVuZHMgQ2FjaGVQZXJtaXNzaW9uIHtcbiAgLyoqXG4gICAqIFNjb3BlIHRoZSB0b2tlbiBwZXJtaXNzaW9ucyB0byBzZWxlY3QgY2FjaGUgaXRlbXNcbiAgICovXG4gIGl0ZW06IENhY2hlSXRlbVNlbGVjdG9yO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb24ocDogUGVybWlzc2lvbik6IGJvb2xlYW4ge1xuICByZXR1cm4gJ3JvbGUnIGluIHAgJiYgJ2NhY2hlJyBpbiBwICYmICdpdGVtJyBpbiBwICYmICEoJ3RvcGljJyBpbiBwKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9uKFxuICBwOiBQZXJtaXNzaW9uXG4pOiBEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb24ge1xuICBpZiAoIWlzRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9uKHApKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgYHBlcm1pc3Npb24gaXMgbm90IGEgRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9uIG9iamVjdDogJHtKU09OLnN0cmluZ2lmeShcbiAgICAgICAgcFxuICAgICAgKX1gXG4gICAgKTtcbiAgfVxuICByZXR1cm4gcCBhcyBEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9ucyB7XG4gIHBlcm1pc3Npb25zOiBBcnJheTxEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb24+O1xufVxuXG5leHBvcnQgdHlwZSBEaXNwb3NhYmxlVG9rZW5TY29wZSA9XG4gIHwgUGVybWlzc2lvbnNcbiAgfCBQcmVkZWZpbmVkU2NvcGVcbiAgfCBEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb25zO1xuXG5leHBvcnQgaW50ZXJmYWNlIERpc3Bvc2FibGVUb2tlblByb3BzIHtcbiAgdG9rZW5JZD86IHN0cmluZztcbn1cblxuZnVuY3Rpb24gaXNEaXNwb3NhYmxlVG9rZW5QZXJtaXNzaW9uT2JqZWN0KHA6IFBlcm1pc3Npb24pOiBib29sZWFuIHtcbiAgcmV0dXJuIGlzRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9uKHApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNEaXNwb3NhYmxlVG9rZW5QZXJtaXNzaW9uc09iamVjdChcbiAgc2NvcGU6IERpc3Bvc2FibGVUb2tlblNjb3BlXG4pOiBib29sZWFuIHtcbiAgaWYgKCEoJ3Blcm1pc3Npb25zJyBpbiBzY29wZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgY29uc3QgcGVybWlzc2lvbnMgPSBzY29wZS5wZXJtaXNzaW9ucztcbiAgcmV0dXJuIHBlcm1pc3Npb25zLmV2ZXJ5KHAgPT4gaXNEaXNwb3NhYmxlVG9rZW5QZXJtaXNzaW9uT2JqZWN0KHApKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzRGlzcG9zYWJsZVRva2VuUGVybWlzc2lvbnNPYmplY3QoXG4gIHNjb3BlOiBEaXNwb3NhYmxlVG9rZW5TY29wZVxuKTogRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9ucyB7XG4gIGlmICghaXNEaXNwb3NhYmxlVG9rZW5QZXJtaXNzaW9uc09iamVjdChzY29wZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgVG9rZW4gc2NvcGUgaXMgbm90IGEgRGlzcG9zYWJsZVRva2VuQ2FjaGVQZXJtaXNzaW9ucyBvYmplY3Q6ICR7SlNPTi5zdHJpbmdpZnkoXG4gICAgICAgIHNjb3BlXG4gICAgICApfWBcbiAgICApO1xuICB9XG4gIHJldHVybiBzY29wZSBhcyBEaXNwb3NhYmxlVG9rZW5DYWNoZVBlcm1pc3Npb25zO1xufVxuIl19
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import { DisposableTokenScope, ExpiresIn, GenerateApiKey, GenerateDisposableToken, RefreshApiKey } from '../index';
|
2
2
|
import { PermissionScope } from '../auth/tokens/permission-scope';
|
3
|
+
import { DisposableTokenProps } from '../auth/tokens/disposable-token-scope';
|
3
4
|
export interface IAuthClient {
|
4
5
|
generateApiKey(scope: PermissionScope, expiresIn: ExpiresIn): Promise<GenerateApiKey.Response>;
|
5
6
|
/**
|
@@ -11,5 +12,5 @@ export interface IAuthClient {
|
|
11
12
|
* @deprecated please use `refreshApiKey` instead
|
12
13
|
*/
|
13
14
|
refreshAuthToken(refreshToken: string): Promise<RefreshApiKey.Response>;
|
14
|
-
generateDisposableToken(scope: DisposableTokenScope, expiresIn: ExpiresIn): Promise<GenerateDisposableToken.Response>;
|
15
|
+
generateDisposableToken(scope: DisposableTokenScope, expiresIn: ExpiresIn, props?: DisposableTokenProps): Promise<GenerateDisposableToken.Response>;
|
15
16
|
}
|
@@ -1,3 +1,3 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUF1dGhDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2xpZW50cy9JQXV0aENsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRGlzcG9zYWJsZVRva2VuU2NvcGUsXG4gIEV4cGlyZXNJbixcbiAgR2VuZXJhdGVBcGlLZXksXG4gIEdlbmVyYXRlRGlzcG9zYWJsZVRva2VuLFxuICBSZWZyZXNoQXBpS2V5LFxufSBmcm9tICcuLi9pbmRleCc7XG5pbXBvcnQge1Blcm1pc3Npb25TY29wZX0gZnJvbSAnLi4vYXV0aC90b2tlbnMvcGVybWlzc2lvbi1zY29wZSc7XG5pbXBvcnQge0Rpc3Bvc2FibGVUb2tlblByb3BzfSBmcm9tICcuLi9hdXRoL3Rva2Vucy9kaXNwb3NhYmxlLXRva2VuLXNjb3BlJztcblxuZXhwb3J0IGludGVyZmFjZSBJQXV0aENsaWVudCB7XG4gIGdlbmVyYXRlQXBpS2V5KFxuICAgIHNjb3BlOiBQZXJtaXNzaW9uU2NvcGUsXG4gICAgZXhwaXJlc0luOiBFeHBpcmVzSW5cbiAgKTogUHJvbWlzZTxHZW5lcmF0ZUFwaUtleS5SZXNwb25zZT47XG5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHBsZWFzZSB1c2UgYGdlbmVyYXRlQXBpS2V5YCBpbnN0ZWFkXG4gICAqL1xuICBnZW5lcmF0ZUF1dGhUb2tlbihcbiAgICBzY29wZTogUGVybWlzc2lvblNjb3BlLFxuICAgIGV4cGlyZXNJbjogRXhwaXJlc0luXG4gICk6IFByb21pc2U8R2VuZXJhdGVBcGlLZXkuUmVzcG9uc2U+O1xuXG4gIHJlZnJlc2hBcGlLZXkocmVmcmVzaFRva2VuOiBzdHJpbmcpOiBQcm9taXNlPFJlZnJlc2hBcGlLZXkuUmVzcG9uc2U+O1xuXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBwbGVhc2UgdXNlIGByZWZyZXNoQXBpS2V5YCBpbnN0ZWFkXG4gICAqL1xuICByZWZyZXNoQXV0aFRva2VuKHJlZnJlc2hUb2tlbjogc3RyaW5nKTogUHJvbWlzZTxSZWZyZXNoQXBpS2V5LlJlc3BvbnNlPjtcblxuICBnZW5lcmF0ZURpc3Bvc2FibGVUb2tlbihcbiAgICBzY29wZTogRGlzcG9zYWJsZVRva2VuU2NvcGUsXG4gICAgZXhwaXJlc0luOiBFeHBpcmVzSW4sXG4gICAgcHJvcHM/OiBEaXNwb3NhYmxlVG9rZW5Qcm9wc1xuICApOiBQcm9taXNlPEdlbmVyYXRlRGlzcG9zYWJsZVRva2VuLlJlc3BvbnNlPjtcbn1cbiJdfQ==
|
@@ -1,12 +1,12 @@
|
|
1
1
|
import { LeaderboardDelete, LeaderboardFetch, LeaderboardLength, LeaderboardRemoveElements, LeaderboardUpsert } from '../messages/responses/leaderboard';
|
2
2
|
import { LeaderboardFetchByRankCallOptions, LeaderboardFetchByScoreCallOptions, LeaderboardGetRankCallOptions, LeaderboardOrder } from '../utils/cache-call-options';
|
3
3
|
export interface ILeaderboard {
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
4
|
+
upsert(elements: Record<number, number> | Map<number, number>): Promise<LeaderboardUpsert.Response>;
|
5
|
+
fetchByScore(options?: LeaderboardFetchByScoreCallOptions): Promise<LeaderboardFetch.Response>;
|
6
|
+
fetchByRank(startRank: number, endRank: number, options?: LeaderboardFetchByRankCallOptions): Promise<LeaderboardFetch.Response>;
|
7
|
+
getRank(ids: Array<number>, options?: LeaderboardGetRankCallOptions): Promise<LeaderboardFetch.Response>;
|
8
|
+
length(): Promise<LeaderboardLength.Response>;
|
9
|
+
removeElements(ids: Array<number>): Promise<LeaderboardRemoveElements.Response>;
|
10
|
+
delete(): Promise<LeaderboardDelete.Response>;
|
11
11
|
}
|
12
12
|
export { LeaderboardFetchByRankCallOptions, LeaderboardFetchByScoreCallOptions, LeaderboardGetRankCallOptions, LeaderboardOrder, };
|
@@ -3,4 +3,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.LeaderboardOrder = void 0;
|
4
4
|
const cache_call_options_1 = require("../utils/cache-call-options");
|
5
5
|
Object.defineProperty(exports, "LeaderboardOrder", { enumerable: true, get: function () { return cache_call_options_1.LeaderboardOrder; } });
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUxlYWRlcmJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NsaWVudHMvSUxlYWRlcmJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQU9BLG9FQUtxQztBQTRCbkMsaUdBN0JBLHFDQUFnQixPQTZCQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIExlYWRlcmJvYXJkRGVsZXRlLFxuICBMZWFkZXJib2FyZEZldGNoLFxuICBMZWFkZXJib2FyZExlbmd0aCxcbiAgTGVhZGVyYm9hcmRSZW1vdmVFbGVtZW50cyxcbiAgTGVhZGVyYm9hcmRVcHNlcnQsXG59IGZyb20gJy4uL21lc3NhZ2VzL3Jlc3BvbnNlcy9sZWFkZXJib2FyZCc7XG5pbXBvcnQge1xuICBMZWFkZXJib2FyZEZldGNoQnlSYW5rQ2FsbE9wdGlvbnMsXG4gIExlYWRlcmJvYXJkRmV0Y2hCeVNjb3JlQ2FsbE9wdGlvbnMsXG4gIExlYWRlcmJvYXJkR2V0UmFua0NhbGxPcHRpb25zLFxuICBMZWFkZXJib2FyZE9yZGVyLFxufSBmcm9tICcuLi91dGlscy9jYWNoZS1jYWxsLW9wdGlvbnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElMZWFkZXJib2FyZCB7XG4gIHVwc2VydChcbiAgICBlbGVtZW50czogUmVjb3JkPG51bWJlciwgbnVtYmVyPiB8IE1hcDxudW1iZXIsIG51bWJlcj5cbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZFVwc2VydC5SZXNwb25zZT47XG4gIGZldGNoQnlTY29yZShcbiAgICBvcHRpb25zPzogTGVhZGVyYm9hcmRGZXRjaEJ5U2NvcmVDYWxsT3B0aW9uc1xuICApOiBQcm9taXNlPExlYWRlcmJvYXJkRmV0Y2guUmVzcG9uc2U+O1xuICBmZXRjaEJ5UmFuayhcbiAgICBzdGFydFJhbms6IG51bWJlcixcbiAgICBlbmRSYW5rOiBudW1iZXIsXG4gICAgb3B0aW9ucz86IExlYWRlcmJvYXJkRmV0Y2hCeVJhbmtDYWxsT3B0aW9uc1xuICApOiBQcm9taXNlPExlYWRlcmJvYXJkRmV0Y2guUmVzcG9uc2U+O1xuICBnZXRSYW5rKFxuICAgIGlkczogQXJyYXk8bnVtYmVyPixcbiAgICBvcHRpb25zPzogTGVhZGVyYm9hcmRHZXRSYW5rQ2FsbE9wdGlvbnNcbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZEZldGNoLlJlc3BvbnNlPjtcbiAgbGVuZ3RoKCk6IFByb21pc2U8TGVhZGVyYm9hcmRMZW5ndGguUmVzcG9uc2U+O1xuICByZW1vdmVFbGVtZW50cyhcbiAgICBpZHM6IEFycmF5PG51bWJlcj5cbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZFJlbW92ZUVsZW1lbnRzLlJlc3BvbnNlPjtcbiAgZGVsZXRlKCk6IFByb21pc2U8TGVhZGVyYm9hcmREZWxldGUuUmVzcG9uc2U+O1xufVxuZXhwb3J0IHtcbiAgTGVhZGVyYm9hcmRGZXRjaEJ5UmFua0NhbGxPcHRpb25zLFxuICBMZWFkZXJib2FyZEZldGNoQnlTY29yZUNhbGxPcHRpb25zLFxuICBMZWFkZXJib2FyZEdldFJhbmtDYWxsT3B0aW9ucyxcbiAgTGVhZGVyYm9hcmRPcmRlcixcbn07XG4iXX0=
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { GenerateApiKey, ExpiresIn, RefreshApiKey, GenerateDisposableToken, DisposableTokenScope } from '../../../index';
|
2
2
|
import { IAuthClient } from '../../../clients/IAuthClient';
|
3
3
|
import { PermissionScope } from '../../../auth/tokens/permission-scope';
|
4
|
+
import { DisposableTokenProps } from '../../../auth/tokens/disposable-token-scope';
|
4
5
|
export interface BaseAuthClientProps {
|
5
6
|
createAuthClient: () => IAuthClient;
|
6
7
|
}
|
@@ -42,9 +43,10 @@ export declare abstract class AbstractAuthClient implements IAuthClient {
|
|
42
43
|
*
|
43
44
|
* @param {DisposableTokenScope} scope - controls the permissions that the new token will have
|
44
45
|
* @param {string} expiresIn - How long the token is valid for in epoch timestamp.
|
46
|
+
* @param {DisposableTokenProps} disposableTokenProps - Additional properties for the API
|
45
47
|
* @returns {Promise<GenerateDisposableToken.Response>} -
|
46
48
|
* {@link GenerateDisposableToken.Success} containing the api token, origin and epoch timestamp when token expires.
|
47
49
|
* {@link GenerateDisposableToken.Error} on failure.
|
48
50
|
*/
|
49
|
-
generateDisposableToken(scope: DisposableTokenScope, expiresIn: ExpiresIn): Promise<GenerateDisposableToken.Response>;
|
51
|
+
generateDisposableToken(scope: DisposableTokenScope, expiresIn: ExpiresIn, disposableTokenProps?: DisposableTokenProps): Promise<GenerateDisposableToken.Response>;
|
50
52
|
}
|
@@ -48,13 +48,14 @@ class AbstractAuthClient {
|
|
48
48
|
*
|
49
49
|
* @param {DisposableTokenScope} scope - controls the permissions that the new token will have
|
50
50
|
* @param {string} expiresIn - How long the token is valid for in epoch timestamp.
|
51
|
+
* @param {DisposableTokenProps} disposableTokenProps - Additional properties for the API
|
51
52
|
* @returns {Promise<GenerateDisposableToken.Response>} -
|
52
53
|
* {@link GenerateDisposableToken.Success} containing the api token, origin and epoch timestamp when token expires.
|
53
54
|
* {@link GenerateDisposableToken.Error} on failure.
|
54
55
|
*/
|
55
|
-
async generateDisposableToken(scope, expiresIn) {
|
56
|
-
return await this.authClient.generateDisposableToken(scope, expiresIn);
|
56
|
+
async generateDisposableToken(scope, expiresIn, disposableTokenProps) {
|
57
|
+
return await this.authClient.generateDisposableToken(scope, expiresIn, disposableTokenProps);
|
57
58
|
}
|
58
59
|
}
|
59
60
|
exports.AbstractAuthClient = AbstractAuthClient;
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWJzdHJhY3RBdXRoQ2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2ludGVybmFsL2NsaWVudHMvYXV0aC9BYnN0cmFjdEF1dGhDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBY0EsTUFBc0Isa0JBQWtCO0lBSXRDLFlBQXNCLEtBQTBCO1FBQzlDLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDN0MsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNJLEtBQUssQ0FBQyxjQUFjLENBQ3pCLEtBQXNCLEVBQ3RCLFNBQW9CO1FBRXBCLE9BQU8sTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLGlCQUFpQixDQUM1QixLQUFzQixFQUN0QixTQUFvQjtRQUVwQixPQUFPLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNJLEtBQUssQ0FBQyxhQUFhLENBQ3hCLFlBQW9CO1FBRXBCLE9BQU8sTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxLQUFLLENBQUMsZ0JBQWdCLENBQzNCLFlBQW9CO1FBRXBCLE9BQU8sTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRDs7Ozs7Ozs7O09BU0c7SUFDSSxLQUFLLENBQUMsdUJBQXVCLENBQ2xDLEtBQTJCLEVBQzNCLFNBQW9CLEVBQ3BCLG9CQUEyQztRQUUzQyxPQUFPLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyx1QkFBdUIsQ0FDbEQsS0FBSyxFQUNMLFNBQVMsRUFDVCxvQkFBb0IsQ0FDckIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQWpGRCxnREFpRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBHZW5lcmF0ZUFwaUtleSxcbiAgRXhwaXJlc0luLFxuICBSZWZyZXNoQXBpS2V5LFxuICBHZW5lcmF0ZURpc3Bvc2FibGVUb2tlbixcbiAgRGlzcG9zYWJsZVRva2VuU2NvcGUsXG59IGZyb20gJy4uLy4uLy4uL2luZGV4JztcbmltcG9ydCB7SUF1dGhDbGllbnR9IGZyb20gJy4uLy4uLy4uL2NsaWVudHMvSUF1dGhDbGllbnQnO1xuaW1wb3J0IHtQZXJtaXNzaW9uU2NvcGV9IGZyb20gJy4uLy4uLy4uL2F1dGgvdG9rZW5zL3Blcm1pc3Npb24tc2NvcGUnO1xuaW1wb3J0IHtEaXNwb3NhYmxlVG9rZW5Qcm9wc30gZnJvbSAnLi4vLi4vLi4vYXV0aC90b2tlbnMvZGlzcG9zYWJsZS10b2tlbi1zY29wZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZUF1dGhDbGllbnRQcm9wcyB7XG4gIGNyZWF0ZUF1dGhDbGllbnQ6ICgpID0+IElBdXRoQ2xpZW50O1xufVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0QXV0aENsaWVudCBpbXBsZW1lbnRzIElBdXRoQ2xpZW50IHtcbiAgLy8gbWFraW5nIHRoZXNlIHByb3RlY3RlZCB1bnRpbCB3ZSBmdWxseSBhYnN0cmFjdCBhd2F5IHRoZSBub2RlanMgY2xpZW50XG4gIHByb3RlY3RlZCByZWFkb25seSBhdXRoQ2xpZW50OiBJQXV0aENsaWVudDtcblxuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IocHJvcHM6IEJhc2VBdXRoQ2xpZW50UHJvcHMpIHtcbiAgICB0aGlzLmF1dGhDbGllbnQgPSBwcm9wcy5jcmVhdGVBdXRoQ2xpZW50KCk7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGVzIGEgbmV3IEFQSSBrZXksIGFsb25nIHdpdGggYSByZWZyZXNoIHRva2VuIHRvIHJlZnJlc2ggdGhlIEFQSSBrZXkgYmVmb3JlIGV4cGlyeS5cbiAgICpcbiAgICogQHBhcmFtIHtQZXJtaXNzaW9uU2NvcGV9IHNjb3BlIC0gY29udHJvbHMgdGhlIHBlcm1pc3Npb25zIHRoYXQgdGhlIG5ldyBrZXkgd2lsbCBoYXZlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBleHBpcmVzSW4gLSBIb3cgbG9uZyB0aGUgQVBJIGtleSBzaG91bGQgYmUgdmFsaWQgZm9yIGluIGVwb2NoIHRpbWVzdGFtcC5cbiAgICogQHJldHVybnMge1Byb21pc2U8R2VuZXJhdGVBcGlLZXkuUmVzcG9uc2U+fSAtXG4gICAqIHtAbGluayBHZW5lcmF0ZUFwaUtleS5TdWNjZXNzfSBjb250YWluaW5nIHRoZSBBUEkga2V5LCByZWZyZXNoIHRva2VuLCBvcmlnaW4gYW5kIGVwb2NoIHRpbWVzdGFtcCB3aGVuIHRva2VuIGV4cGlyZXMuXG4gICAqIElmIHRoZSBBUEkga2V5IG5ldmVyIGV4cGlyZXMsIHRoZW4gbm8gcmVmcmVzaCB0b2tlbiB3aWxsIGJlIHJldHVybmVkIGFuZCBleHBpcmVzIGF0IHRpbWVzdGFtcCB3aWxsIGJlIGluZmluaXRlLlxuICAgKiB7QGxpbmsgR2VuZXJhdGVBcGlLZXkuRXJyb3J9IG9uIGZhaWx1cmUuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2VuZXJhdGVBcGlLZXkoXG4gICAgc2NvcGU6IFBlcm1pc3Npb25TY29wZSxcbiAgICBleHBpcmVzSW46IEV4cGlyZXNJblxuICApOiBQcm9taXNlPEdlbmVyYXRlQXBpS2V5LlJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuYXV0aENsaWVudC5nZW5lcmF0ZUFwaUtleShzY29wZSwgZXhwaXJlc0luKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBwbGVhc2UgdXNlIGBnZW5lcmF0ZUFwaUtleWAgaW5zdGVhZFxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdlbmVyYXRlQXV0aFRva2VuKFxuICAgIHNjb3BlOiBQZXJtaXNzaW9uU2NvcGUsXG4gICAgZXhwaXJlc0luOiBFeHBpcmVzSW5cbiAgKTogUHJvbWlzZTxHZW5lcmF0ZUFwaUtleS5SZXNwb25zZT4ge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLmdlbmVyYXRlQXBpS2V5KHNjb3BlLCBleHBpcmVzSW4pO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlZnJlc2hlcyBhbiBBUEkga2V5LiAgUmV0dXJucyBhIG5ldyBBUEkga2V5IGFuZCByZWZyZXNoIHRva2VuLCB0aGF0IHdpbGwgYmUgYWJsZSB0byBiZSByZWZyZXNoZWQgYWdhaW4gaW4gdGhlIGZ1dHVyZS5cbiAgICogVGhlIG5ldyBBUEkga2V5IHdpbGwgYmUgdmFsaWQgZm9yIHRoZSBzYW1lIGxlbmd0aCBvZiB0aW1lIGFzIHRoZSBvcmlnaW5hbCBrZXksIHN0YXJ0aW5nIGZyb20gdGhlIHRpbWUgb2YgcmVmcmVzaC5cbiAgICogVGhlIG9yaWdpbmFsIGFwaSBrZXkgd2lsbCBzdGlsbCB3b3JrIHVudGlsIGl0cyBleHBpcmVkLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gcmVmcmVzaFRva2VuIC0gUmVmcmVzaCB0b2tlbiB1c2VkIHRvIHJlZnJlc2ggdGhlIEFQSSBrZXkuXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPFJlZnJlc2hBcGlLZXkuUmVzcG9uc2U+fSAtXG4gICAqIHtAbGluayBSZWZyZXNoQXBpS2V5LlN1Y2Nlc3N9IGNvbnRhaW5pbmcgdGhlIG5ldyBBUEkga2V5LCByZWZyZXNoIHRva2VuLCBvcmlnaW4gYW5kIGVwb2NoIHRpbWVzdGFtcCB3aGVuIHRoZSBBUEkga2V5IGV4cGlyZXMuXG4gICAqIHtAbGluayBSZWZyZXNoQXBpS2V5LkVycm9yfSBvbiBmYWlsdXJlLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIHJlZnJlc2hBcGlLZXkoXG4gICAgcmVmcmVzaFRva2VuOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxSZWZyZXNoQXBpS2V5LlJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuYXV0aENsaWVudC5yZWZyZXNoQXBpS2V5KHJlZnJlc2hUb2tlbik7XG4gIH1cblxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgcGxlYXNlIHVzZSBgcmVmcmVzaEFwaUtleWAgaW5zdGVhZFxuICAgKi9cbiAgcHVibGljIGFzeW5jIHJlZnJlc2hBdXRoVG9rZW4oXG4gICAgcmVmcmVzaFRva2VuOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxSZWZyZXNoQXBpS2V5LlJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMucmVmcmVzaEFwaUtleShyZWZyZXNoVG9rZW4pO1xuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlcyBhIG5ldyBkaXNwb3NhYmxlLCBmaW5lLWdyYWluZWQgYWNjZXNzIHRva2VuLlxuICAgKlxuICAgKiBAcGFyYW0ge0Rpc3Bvc2FibGVUb2tlblNjb3BlfSBzY29wZSAtIGNvbnRyb2xzIHRoZSBwZXJtaXNzaW9ucyB0aGF0IHRoZSBuZXcgdG9rZW4gd2lsbCBoYXZlXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBleHBpcmVzSW4gLSBIb3cgbG9uZyB0aGUgdG9rZW4gaXMgdmFsaWQgZm9yIGluIGVwb2NoIHRpbWVzdGFtcC5cbiAgICogQHBhcmFtIHtEaXNwb3NhYmxlVG9rZW5Qcm9wc30gZGlzcG9zYWJsZVRva2VuUHJvcHMgLSBBZGRpdGlvbmFsIHByb3BlcnRpZXMgZm9yIHRoZSBBUElcbiAgICogQHJldHVybnMge1Byb21pc2U8R2VuZXJhdGVEaXNwb3NhYmxlVG9rZW4uUmVzcG9uc2U+fSAtXG4gICAqIHtAbGluayBHZW5lcmF0ZURpc3Bvc2FibGVUb2tlbi5TdWNjZXNzfSBjb250YWluaW5nIHRoZSBhcGkgdG9rZW4sIG9yaWdpbiBhbmQgZXBvY2ggdGltZXN0YW1wIHdoZW4gdG9rZW4gZXhwaXJlcy5cbiAgICoge0BsaW5rIEdlbmVyYXRlRGlzcG9zYWJsZVRva2VuLkVycm9yfSBvbiBmYWlsdXJlLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdlbmVyYXRlRGlzcG9zYWJsZVRva2VuKFxuICAgIHNjb3BlOiBEaXNwb3NhYmxlVG9rZW5TY29wZSxcbiAgICBleHBpcmVzSW46IEV4cGlyZXNJbixcbiAgICBkaXNwb3NhYmxlVG9rZW5Qcm9wcz86IERpc3Bvc2FibGVUb2tlblByb3BzXG4gICk6IFByb21pc2U8R2VuZXJhdGVEaXNwb3NhYmxlVG9rZW4uUmVzcG9uc2U+IHtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy5hdXRoQ2xpZW50LmdlbmVyYXRlRGlzcG9zYWJsZVRva2VuKFxuICAgICAgc2NvcGUsXG4gICAgICBleHBpcmVzSW4sXG4gICAgICBkaXNwb3NhYmxlVG9rZW5Qcm9wc1xuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
@@ -16,7 +16,7 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
16
16
|
* {@link LeaderboardUpsert.Success} on success.
|
17
17
|
* {@link LeaderboardUpsert.Error} on failure.
|
18
18
|
*/
|
19
|
-
|
19
|
+
upsert(elements: Record<number, number> | Map<number, number>): Promise<LeaderboardUpsert.Response>;
|
20
20
|
/**
|
21
21
|
* Fetch the elements in the given leaderboard by score.
|
22
22
|
* Note: can fetch a maximum of 8192 elements at a time.
|
@@ -35,31 +35,31 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
35
35
|
* @param {number} [options.count] - The maximum number of elements to return.
|
36
36
|
* Defaults to 8192, which is the maximum that can be fetched at a time.
|
37
37
|
* @returns {Promise<LeaderboardFetch.Response>} -
|
38
|
-
* {@link LeaderboardFetch.
|
39
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
38
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
40
39
|
* {@link LeaderboardFetch.Error} on failure.
|
41
40
|
*/
|
42
|
-
|
41
|
+
fetchByScore(options?: LeaderboardFetchByScoreCallOptions): Promise<LeaderboardFetch.Response>;
|
43
42
|
/**
|
44
43
|
* Fetch the elements in the given leaderboard by index (rank).
|
45
44
|
* Note: can fetch a maximum of 8192 elements at a time and rank
|
46
45
|
* is 0-based (index begins at 0).
|
47
46
|
*
|
48
|
-
* @param {
|
49
|
-
*
|
50
|
-
*
|
51
|
-
*
|
52
|
-
* @param {number} [
|
47
|
+
* @param {number} [startRank] - The rank of the first element to
|
48
|
+
* fetch. This rank is inclusive, ie the element at this rank
|
49
|
+
* will be fetched. Ranks can be used to manually paginate through the leaderboard
|
50
|
+
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).
|
51
|
+
* @param {number} [endRank] - The rank of the last element to fetch.
|
53
52
|
* This rank is exclusive, ie the element at this rank will not be fetched.
|
54
|
-
*
|
53
|
+
* Ranks can be used to manually paginate through the leaderboard
|
54
|
+
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).
|
55
|
+
* @param {LeaderboardFetchByRankOptions} options
|
55
56
|
* @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.
|
56
57
|
* Defaults to ascending, meaning 0 is the lowest-scoring rank.
|
57
58
|
* @returns {Promise<LeaderboardFetch.Response>} -
|
58
|
-
* {@link LeaderboardFetch.
|
59
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
59
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
60
60
|
* {@link LeaderboardFetch.Error} on failure.
|
61
61
|
*/
|
62
|
-
|
62
|
+
fetchByRank(startRank: number, endRank: number, options?: LeaderboardFetchByRankCallOptions): Promise<LeaderboardFetch.Response>;
|
63
63
|
/**
|
64
64
|
* Look up the rank of an element in the leaderboard given the element id.
|
65
65
|
* Note: rank is 0-based (index begins at 0).
|
@@ -69,11 +69,10 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
69
69
|
* @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.
|
70
70
|
* Defaults to ascending, meaning 0 is the lowest-scoring rank.
|
71
71
|
* @returns {Promise<LeaderboardFetch.Response>}
|
72
|
-
* {@link LeaderboardFetch.
|
73
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
72
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
74
73
|
* {@link LeaderboardFetch.Error} on failure.
|
75
74
|
*/
|
76
|
-
|
75
|
+
getRank(ids: Array<number>, options?: LeaderboardGetRankCallOptions): Promise<LeaderboardFetch.Response>;
|
77
76
|
/**
|
78
77
|
* Fetch length (number of items) of leaderboard
|
79
78
|
*
|
@@ -81,7 +80,7 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
81
80
|
* {@link LeaderboardLength.Success} containing the length if the leaderboard exists.
|
82
81
|
* {@link LeaderboardLength.Error} on failure.
|
83
82
|
*/
|
84
|
-
|
83
|
+
length(): Promise<LeaderboardLength.Response>;
|
85
84
|
/**
|
86
85
|
* Remove multiple elements from the given leaderboard
|
87
86
|
* Note: can remove a maximum of 8192 elements at a time.
|
@@ -91,7 +90,7 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
91
90
|
* {@link LeaderboardRemoveElements.Success} if the elements were successfully removed.
|
92
91
|
* {@link LeaderboardRemoveElements.Error} on failure.
|
93
92
|
*/
|
94
|
-
|
93
|
+
removeElements(ids: Array<number>): Promise<LeaderboardRemoveElements.Response>;
|
95
94
|
/**
|
96
95
|
* Delete the given leaderboard
|
97
96
|
*
|
@@ -99,5 +98,5 @@ export declare abstract class AbstractLeaderboard implements ILeaderboard {
|
|
99
98
|
* {@link LeaderboardDelete.Success} on success.
|
100
99
|
* {@link LeaderboardDelete.Error} on failure.
|
101
100
|
*/
|
102
|
-
|
101
|
+
delete(): Promise<LeaderboardDelete.Response>;
|
103
102
|
}
|
@@ -17,8 +17,8 @@ class AbstractLeaderboard {
|
|
17
17
|
* {@link LeaderboardUpsert.Success} on success.
|
18
18
|
* {@link LeaderboardUpsert.Error} on failure.
|
19
19
|
*/
|
20
|
-
async
|
21
|
-
return await this.dataClient.
|
20
|
+
async upsert(elements) {
|
21
|
+
return await this.dataClient.upsert(this.cacheName, this.leaderboardName, elements);
|
22
22
|
}
|
23
23
|
/**
|
24
24
|
* Fetch the elements in the given leaderboard by score.
|
@@ -38,34 +38,34 @@ class AbstractLeaderboard {
|
|
38
38
|
* @param {number} [options.count] - The maximum number of elements to return.
|
39
39
|
* Defaults to 8192, which is the maximum that can be fetched at a time.
|
40
40
|
* @returns {Promise<LeaderboardFetch.Response>} -
|
41
|
-
* {@link LeaderboardFetch.
|
42
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
41
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
43
42
|
* {@link LeaderboardFetch.Error} on failure.
|
44
43
|
*/
|
45
|
-
async
|
46
|
-
return await this.dataClient.
|
44
|
+
async fetchByScore(options) {
|
45
|
+
return await this.dataClient.fetchByScore(this.cacheName, this.leaderboardName, options === null || options === void 0 ? void 0 : options.minScore, options === null || options === void 0 ? void 0 : options.maxScore, options === null || options === void 0 ? void 0 : options.order, options === null || options === void 0 ? void 0 : options.offset, options === null || options === void 0 ? void 0 : options.count);
|
47
46
|
}
|
48
47
|
/**
|
49
48
|
* Fetch the elements in the given leaderboard by index (rank).
|
50
49
|
* Note: can fetch a maximum of 8192 elements at a time and rank
|
51
50
|
* is 0-based (index begins at 0).
|
52
51
|
*
|
53
|
-
* @param {
|
54
|
-
*
|
55
|
-
*
|
56
|
-
*
|
57
|
-
* @param {number} [
|
52
|
+
* @param {number} [startRank] - The rank of the first element to
|
53
|
+
* fetch. This rank is inclusive, ie the element at this rank
|
54
|
+
* will be fetched. Ranks can be used to manually paginate through the leaderboard
|
55
|
+
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).
|
56
|
+
* @param {number} [endRank] - The rank of the last element to fetch.
|
58
57
|
* This rank is exclusive, ie the element at this rank will not be fetched.
|
59
|
-
*
|
58
|
+
* Ranks can be used to manually paginate through the leaderboard
|
59
|
+
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).
|
60
|
+
* @param {LeaderboardFetchByRankOptions} options
|
60
61
|
* @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.
|
61
62
|
* Defaults to ascending, meaning 0 is the lowest-scoring rank.
|
62
63
|
* @returns {Promise<LeaderboardFetch.Response>} -
|
63
|
-
* {@link LeaderboardFetch.
|
64
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
64
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
65
65
|
* {@link LeaderboardFetch.Error} on failure.
|
66
66
|
*/
|
67
|
-
async
|
68
|
-
return await this.dataClient.
|
67
|
+
async fetchByRank(startRank, endRank, options) {
|
68
|
+
return await this.dataClient.fetchByRank(this.cacheName, this.leaderboardName, startRank, endRank, options === null || options === void 0 ? void 0 : options.order);
|
69
69
|
}
|
70
70
|
/**
|
71
71
|
* Look up the rank of an element in the leaderboard given the element id.
|
@@ -76,12 +76,11 @@ class AbstractLeaderboard {
|
|
76
76
|
* @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.
|
77
77
|
* Defaults to ascending, meaning 0 is the lowest-scoring rank.
|
78
78
|
* @returns {Promise<LeaderboardFetch.Response>}
|
79
|
-
* {@link LeaderboardFetch.
|
80
|
-
* {@link LeaderboardFetch.NotFound} when requested elements were not found.
|
79
|
+
* {@link LeaderboardFetch.Success} containing the requested elements.
|
81
80
|
* {@link LeaderboardFetch.Error} on failure.
|
82
81
|
*/
|
83
|
-
async
|
84
|
-
return await this.dataClient.
|
82
|
+
async getRank(ids, options) {
|
83
|
+
return await this.dataClient.getRank(this.cacheName, this.leaderboardName, ids, options === null || options === void 0 ? void 0 : options.order);
|
85
84
|
}
|
86
85
|
/**
|
87
86
|
* Fetch length (number of items) of leaderboard
|
@@ -90,8 +89,8 @@ class AbstractLeaderboard {
|
|
90
89
|
* {@link LeaderboardLength.Success} containing the length if the leaderboard exists.
|
91
90
|
* {@link LeaderboardLength.Error} on failure.
|
92
91
|
*/
|
93
|
-
async
|
94
|
-
return await this.dataClient.
|
92
|
+
async length() {
|
93
|
+
return await this.dataClient.length(this.cacheName, this.leaderboardName);
|
95
94
|
}
|
96
95
|
/**
|
97
96
|
* Remove multiple elements from the given leaderboard
|
@@ -102,8 +101,8 @@ class AbstractLeaderboard {
|
|
102
101
|
* {@link LeaderboardRemoveElements.Success} if the elements were successfully removed.
|
103
102
|
* {@link LeaderboardRemoveElements.Error} on failure.
|
104
103
|
*/
|
105
|
-
async
|
106
|
-
return await this.dataClient.
|
104
|
+
async removeElements(ids) {
|
105
|
+
return await this.dataClient.removeElements(this.cacheName, this.leaderboardName, ids);
|
107
106
|
}
|
108
107
|
/**
|
109
108
|
* Delete the given leaderboard
|
@@ -112,9 +111,9 @@ class AbstractLeaderboard {
|
|
112
111
|
* {@link LeaderboardDelete.Success} on success.
|
113
112
|
* {@link LeaderboardDelete.Error} on failure.
|
114
113
|
*/
|
115
|
-
async
|
116
|
-
return await this.dataClient.
|
114
|
+
async delete() {
|
115
|
+
return await this.dataClient.delete(this.cacheName, this.leaderboardName);
|
117
116
|
}
|
118
117
|
}
|
119
118
|
exports.AbstractLeaderboard = AbstractLeaderboard;
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractLeaderboard.js","sourceRoot":"","sources":["../../../../../src/internal/clients/leaderboard/AbstractLeaderboard.ts"],"names":[],"mappings":";;;AAeA,MAAsB,mBAAmB;IAKvC,YACE,SAAiB,EACjB,eAAuB,EACvB,UAAkC;QAElC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED;;;;;;;;;OASG;IACI,KAAK,CAAC,iBAAiB,CAC5B,QAA6B;QAE7B,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAC5C,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,QAAQ,CACT,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;OAqBG;IACI,KAAK,CAAC,uBAAuB,CAClC,OAA4C;QAE5C,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAClD,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,EACjB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,EACjB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,EACd,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,EACf,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;OAkBG;IACI,KAAK,CAAC,sBAAsB,CACjC,OAA2C;QAE3C,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,sBAAsB,CACjD,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,EAClB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,EAChB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,KAAK,CAAC,kBAAkB,CAC7B,GAAkB,EAClB,OAAuC;QAEvC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAC7C,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,GAAG,EACH,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,iBAAiB;QAC5B,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAC5C,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,CACrB,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACI,KAAK,CAAC,yBAAyB,CACpC,GAAkB;QAElB,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,yBAAyB,CACpD,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,GAAG,CACJ,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,iBAAiB;QAC5B,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAC5C,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,CACrB,CAAC;IACJ,CAAC;CACF;AA7KD,kDA6KC","sourcesContent":["import {\n  ILeaderboard,\n  LeaderboardFetchByRankCallOptions,\n  LeaderboardFetchByScoreCallOptions,\n  LeaderboardGetRankCallOptions,\n} from '../../../clients/ILeaderboard';\nimport {\n  LeaderboardDelete,\n  LeaderboardFetch,\n  LeaderboardLength,\n  LeaderboardRemoveElements,\n  LeaderboardUpsert,\n} from '../../../messages/responses/leaderboard';\nimport {ILeaderboardDataClient} from './ILeaderboardDataClient';\n\nexport abstract class AbstractLeaderboard implements ILeaderboard {\n  protected readonly cacheName: string;\n  protected readonly leaderboardName: string;\n  protected readonly dataClient: ILeaderboardDataClient;\n\n  protected constructor(\n    cacheName: string,\n    leaderboardName: string,\n    dataClient: ILeaderboardDataClient\n  ) {\n    this.cacheName = cacheName;\n    this.leaderboardName = leaderboardName;\n    this.dataClient = dataClient;\n  }\n\n  /**\n   * Updates elements in a leaderboard or inserts elements if they do not already exist.\n   * The leaderboard is also created if it does not already exist.\n   * Note: can upsert a maximum of 8192 elements at a time.\n   *\n   * @param {Map<number, number>} elements - The ID->score pairs to add to the leaderboard.\n   * @returns {Promise<LeaderboardUpsert.Response>} -\n   * {@link LeaderboardUpsert.Success} on success.\n   * {@link LeaderboardUpsert.Error} on failure.\n   */\n  public async leaderboardUpsert(\n    elements: Map<number, number>\n  ): Promise<LeaderboardUpsert.Response> {\n    return await this.dataClient.leaderboardUpsert(\n      this.cacheName,\n      this.leaderboardName,\n      elements\n    );\n  }\n\n  /**\n   * Fetch the elements in the given leaderboard by score.\n   * Note: can fetch a maximum of 8192 elements at a time.\n   *\n   * @param {LeaderboardFetchByScoreCallOptions} options\n   * @param {number} [options.minScore] - The minimum score (inclusive) of the\n   * elements to fetch. Defaults to negative infinity.\n   * @param {number} [options.maxScore] - The maximum score (exclusive) of the\n   * elements to fetch. Defaults to positive infinity.\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @param {number} [options.offset] - The number of elements to skip before\n   * returning the first element. Defaults to 0. Note: this is not the score of\n   * the first element to return, but the number of elements of the result set\n   * to skip before returning the first element.\n   * @param {number} [options.count] - The maximum number of elements to return.\n   * Defaults to 8192, which is the maximum that can be fetched at a time.\n   * @returns {Promise<LeaderboardFetch.Response>} -\n   * {@link LeaderboardFetch.Found} containing the requested elements.\n   * {@link LeaderboardFetch.NotFound} when requested elements were not found.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async leaderboardFetchByScore(\n    options?: LeaderboardFetchByScoreCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.leaderboardFetchByScore(\n      this.cacheName,\n      this.leaderboardName,\n      options?.minScore,\n      options?.maxScore,\n      options?.order,\n      options?.offset,\n      options?.count\n    );\n  }\n\n  /**\n   * Fetch the elements in the given leaderboard by index (rank).\n   * Note: can fetch a maximum of 8192 elements at a time and rank\n   * is 0-based (index begins at 0).\n   *\n   * @param {LeaderboardFetchByRankOptions} options\n   * @param {number} [options.startRank] - The rank of the first element to\n   * fetch. Defaults to 0. This rank is inclusive, ie the element at this rank\n   * will be fetched.\n   * @param {number} [options.endRank] - The rank of the last element to fetch.\n   * This rank is exclusive, ie the element at this rank will not be fetched.\n   * Defaults to startRank + 8192 in order to fetch the maximum 8192 elements per request.\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @returns {Promise<LeaderboardFetch.Response>} -\n   * {@link LeaderboardFetch.Found} containing the requested elements.\n   * {@link LeaderboardFetch.NotFound} when requested elements were not found.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async leaderboardFetchByRank(\n    options?: LeaderboardFetchByRankCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.leaderboardFetchByRank(\n      this.cacheName,\n      this.leaderboardName,\n      options?.startRank,\n      options?.endRank,\n      options?.order\n    );\n  }\n\n  /**\n   * Look up the rank of an element in the leaderboard given the element id.\n   * Note: rank is 0-based (index begins at 0).\n   *\n   * @param {number} ids - The ids of the elements whose rank we are retrieving.\n   * @param {LeaderboardGetRankCallOptions} options\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @returns {Promise<LeaderboardFetch.Response>}\n   * {@link LeaderboardFetch.Found} containing the requested elements.\n   * {@link LeaderboardFetch.NotFound} when requested elements were not found.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async leaderboardGetRank(\n    ids: Array<number>,\n    options?: LeaderboardGetRankCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.leaderboardGetRank(\n      this.cacheName,\n      this.leaderboardName,\n      ids,\n      options?.order\n    );\n  }\n\n  /**\n   * Fetch length (number of items) of leaderboard\n   *\n   * @returns {Promise<LeaderboardLength.Response>}\n   * {@link LeaderboardLength.Success} containing the length if the leaderboard exists.\n   * {@link LeaderboardLength.Error} on failure.\n   */\n  public async leaderboardLength(): Promise<LeaderboardLength.Response> {\n    return await this.dataClient.leaderboardLength(\n      this.cacheName,\n      this.leaderboardName\n    );\n  }\n\n  /**\n   * Remove multiple elements from the given leaderboard\n   * Note: can remove a maximum of 8192 elements at a time.\n   *\n   * @param {Array<number>} ids - The IDs of the elements to remove from the leaderboard.\n   * @returns {Promise<LeaderboardRemoveElements.Response>}\n   * {@link LeaderboardRemoveElements.Success} if the elements were successfully removed.\n   * {@link LeaderboardRemoveElements.Error} on failure.\n   */\n  public async leaderboardRemoveElements(\n    ids: Array<number>\n  ): Promise<LeaderboardRemoveElements.Response> {\n    return await this.dataClient.leaderboardRemoveElements(\n      this.cacheName,\n      this.leaderboardName,\n      ids\n    );\n  }\n\n  /**\n   * Delete the given leaderboard\n   *\n   * @returns {Promise<LeaderboardDelete.Response>}\n   * {@link LeaderboardDelete.Success} on success.\n   * {@link LeaderboardDelete.Error} on failure.\n   */\n  public async leaderboardDelete(): Promise<LeaderboardDelete.Response> {\n    return await this.dataClient.leaderboardDelete(\n      this.cacheName,\n      this.leaderboardName\n    );\n  }\n}\n"]}
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractLeaderboard.js","sourceRoot":"","sources":["../../../../../src/internal/clients/leaderboard/AbstractLeaderboard.ts"],"names":[],"mappings":";;;AAeA,MAAsB,mBAAmB;IAKvC,YACE,SAAiB,EACjB,eAAuB,EACvB,UAAkC;QAElC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED;;;;;;;;;OASG;IACI,KAAK,CAAC,MAAM,CACjB,QAAsD;QAEtD,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CACjC,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,QAAQ,CACT,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;;OAoBG;IACI,KAAK,CAAC,YAAY,CACvB,OAA4C;QAE5C,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,YAAY,CACvC,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,EACjB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,EACjB,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,EACd,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,EACf,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;OAmBG;IACI,KAAK,CAAC,WAAW,CACtB,SAAiB,EACjB,OAAe,EACf,OAA2C;QAE3C,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CACtC,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,SAAS,EACT,OAAO,EACP,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;OAWG;IACI,KAAK,CAAC,OAAO,CAClB,GAAkB,EAClB,OAAuC;QAEvC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAClC,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,GAAG,EACH,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CACf,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,MAAM;QACjB,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;;;;OAQG;IACI,KAAK,CAAC,cAAc,CACzB,GAAkB;QAElB,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,cAAc,CACzC,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,eAAe,EACpB,GAAG,CACJ,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,MAAM;QACjB,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IAC5E,CAAC;CACF;AAxKD,kDAwKC","sourcesContent":["import {\n  ILeaderboard,\n  LeaderboardFetchByRankCallOptions,\n  LeaderboardFetchByScoreCallOptions,\n  LeaderboardGetRankCallOptions,\n} from '../../../clients/ILeaderboard';\nimport {\n  LeaderboardDelete,\n  LeaderboardFetch,\n  LeaderboardLength,\n  LeaderboardRemoveElements,\n  LeaderboardUpsert,\n} from '../../../messages/responses/leaderboard';\nimport {ILeaderboardDataClient} from './ILeaderboardDataClient';\n\nexport abstract class AbstractLeaderboard implements ILeaderboard {\n  protected readonly cacheName: string;\n  protected readonly leaderboardName: string;\n  protected readonly dataClient: ILeaderboardDataClient;\n\n  protected constructor(\n    cacheName: string,\n    leaderboardName: string,\n    dataClient: ILeaderboardDataClient\n  ) {\n    this.cacheName = cacheName;\n    this.leaderboardName = leaderboardName;\n    this.dataClient = dataClient;\n  }\n\n  /**\n   * Updates elements in a leaderboard or inserts elements if they do not already exist.\n   * The leaderboard is also created if it does not already exist.\n   * Note: can upsert a maximum of 8192 elements at a time.\n   *\n   * @param {Map<number, number>} elements - The ID->score pairs to add to the leaderboard.\n   * @returns {Promise<LeaderboardUpsert.Response>} -\n   * {@link LeaderboardUpsert.Success} on success.\n   * {@link LeaderboardUpsert.Error} on failure.\n   */\n  public async upsert(\n    elements: Record<number, number> | Map<number, number>\n  ): Promise<LeaderboardUpsert.Response> {\n    return await this.dataClient.upsert(\n      this.cacheName,\n      this.leaderboardName,\n      elements\n    );\n  }\n\n  /**\n   * Fetch the elements in the given leaderboard by score.\n   * Note: can fetch a maximum of 8192 elements at a time.\n   *\n   * @param {LeaderboardFetchByScoreCallOptions} options\n   * @param {number} [options.minScore] - The minimum score (inclusive) of the\n   * elements to fetch. Defaults to negative infinity.\n   * @param {number} [options.maxScore] - The maximum score (exclusive) of the\n   * elements to fetch. Defaults to positive infinity.\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @param {number} [options.offset] - The number of elements to skip before\n   * returning the first element. Defaults to 0. Note: this is not the score of\n   * the first element to return, but the number of elements of the result set\n   * to skip before returning the first element.\n   * @param {number} [options.count] - The maximum number of elements to return.\n   * Defaults to 8192, which is the maximum that can be fetched at a time.\n   * @returns {Promise<LeaderboardFetch.Response>} -\n   * {@link LeaderboardFetch.Success} containing the requested elements.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async fetchByScore(\n    options?: LeaderboardFetchByScoreCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.fetchByScore(\n      this.cacheName,\n      this.leaderboardName,\n      options?.minScore,\n      options?.maxScore,\n      options?.order,\n      options?.offset,\n      options?.count\n    );\n  }\n\n  /**\n   * Fetch the elements in the given leaderboard by index (rank).\n   * Note: can fetch a maximum of 8192 elements at a time and rank\n   * is 0-based (index begins at 0).\n   *\n   * @param {number} [startRank] - The rank of the first element to\n   * fetch. This rank is inclusive, ie the element at this rank\n   * will be fetched. Ranks can be used to manually paginate through the leaderboard\n   * in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).\n   * @param {number} [endRank] - The rank of the last element to fetch.\n   * This rank is exclusive, ie the element at this rank will not be fetched.\n   * Ranks can be used to manually paginate through the leaderboard\n   * in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc).\n   * @param {LeaderboardFetchByRankOptions} options\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @returns {Promise<LeaderboardFetch.Response>} -\n   * {@link LeaderboardFetch.Success} containing the requested elements.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async fetchByRank(\n    startRank: number,\n    endRank: number,\n    options?: LeaderboardFetchByRankCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.fetchByRank(\n      this.cacheName,\n      this.leaderboardName,\n      startRank,\n      endRank,\n      options?.order\n    );\n  }\n\n  /**\n   * Look up the rank of an element in the leaderboard given the element id.\n   * Note: rank is 0-based (index begins at 0).\n   *\n   * @param {number} ids - The ids of the elements whose rank we are retrieving.\n   * @param {LeaderboardGetRankCallOptions} options\n   * @param {LeaderboardOrder} [options.order] - The order to fetch the elements in.\n   * Defaults to ascending, meaning 0 is the lowest-scoring rank.\n   * @returns {Promise<LeaderboardFetch.Response>}\n   * {@link LeaderboardFetch.Success} containing the requested elements.\n   * {@link LeaderboardFetch.Error} on failure.\n   */\n  public async getRank(\n    ids: Array<number>,\n    options?: LeaderboardGetRankCallOptions\n  ): Promise<LeaderboardFetch.Response> {\n    return await this.dataClient.getRank(\n      this.cacheName,\n      this.leaderboardName,\n      ids,\n      options?.order\n    );\n  }\n\n  /**\n   * Fetch length (number of items) of leaderboard\n   *\n   * @returns {Promise<LeaderboardLength.Response>}\n   * {@link LeaderboardLength.Success} containing the length if the leaderboard exists.\n   * {@link LeaderboardLength.Error} on failure.\n   */\n  public async length(): Promise<LeaderboardLength.Response> {\n    return await this.dataClient.length(this.cacheName, this.leaderboardName);\n  }\n\n  /**\n   * Remove multiple elements from the given leaderboard\n   * Note: can remove a maximum of 8192 elements at a time.\n   *\n   * @param {Array<number>} ids - The IDs of the elements to remove from the leaderboard.\n   * @returns {Promise<LeaderboardRemoveElements.Response>}\n   * {@link LeaderboardRemoveElements.Success} if the elements were successfully removed.\n   * {@link LeaderboardRemoveElements.Error} on failure.\n   */\n  public async removeElements(\n    ids: Array<number>\n  ): Promise<LeaderboardRemoveElements.Response> {\n    return await this.dataClient.removeElements(\n      this.cacheName,\n      this.leaderboardName,\n      ids\n    );\n  }\n\n  /**\n   * Delete the given leaderboard\n   *\n   * @returns {Promise<LeaderboardDelete.Response>}\n   * {@link LeaderboardDelete.Success} on success.\n   * {@link LeaderboardDelete.Error} on failure.\n   */\n  public async delete(): Promise<LeaderboardDelete.Response> {\n    return await this.dataClient.delete(this.cacheName, this.leaderboardName);\n  }\n}\n"]}
|
@@ -1,11 +1,11 @@
|
|
1
1
|
import { LeaderboardDelete, LeaderboardFetch, LeaderboardLength, LeaderboardRemoveElements, LeaderboardUpsert } from '../../../messages/responses/leaderboard';
|
2
2
|
import { LeaderboardOrder } from '../../../utils';
|
3
3
|
export interface ILeaderboardDataClient {
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
4
|
+
upsert(cacheName: string, leaderboardName: string, elements: Record<number, number> | Map<number, number>): Promise<LeaderboardUpsert.Response>;
|
5
|
+
fetchByScore(cacheName: string, leaderboardName: string, minScore?: number, maxScore?: number, order?: LeaderboardOrder, offset?: number, count?: number): Promise<LeaderboardFetch.Response>;
|
6
|
+
fetchByRank(cacheName: string, leaderboardName: string, startRank: number, endRank: number, order?: LeaderboardOrder): Promise<LeaderboardFetch.Response>;
|
7
|
+
getRank(cacheName: string, leaderboardName: string, ids: Array<number>, order?: LeaderboardOrder): Promise<LeaderboardFetch.Response>;
|
8
|
+
length(cacheName: string, leaderboardName: string): Promise<LeaderboardLength.Response>;
|
9
|
+
removeElements(cacheName: string, leaderboardName: string, ids: Array<number>): Promise<LeaderboardRemoveElements.Response>;
|
10
|
+
delete(cacheName: string, leaderboardName: string): Promise<LeaderboardDelete.Response>;
|
11
11
|
}
|
@@ -1,3 +1,3 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUxlYWRlcmJvYXJkRGF0YUNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC9jbGllbnRzL2xlYWRlcmJvYXJkL0lMZWFkZXJib2FyZERhdGFDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIExlYWRlcmJvYXJkRGVsZXRlLFxuICBMZWFkZXJib2FyZEZldGNoLFxuICBMZWFkZXJib2FyZExlbmd0aCxcbiAgTGVhZGVyYm9hcmRSZW1vdmVFbGVtZW50cyxcbiAgTGVhZGVyYm9hcmRVcHNlcnQsXG59IGZyb20gJy4uLy4uLy4uL21lc3NhZ2VzL3Jlc3BvbnNlcy9sZWFkZXJib2FyZCc7XG5pbXBvcnQge0xlYWRlcmJvYXJkT3JkZXJ9IGZyb20gJy4uLy4uLy4uL3V0aWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBJTGVhZGVyYm9hcmREYXRhQ2xpZW50IHtcbiAgdXBzZXJ0KFxuICAgIGNhY2hlTmFtZTogc3RyaW5nLFxuICAgIGxlYWRlcmJvYXJkTmFtZTogc3RyaW5nLFxuICAgIGVsZW1lbnRzOiBSZWNvcmQ8bnVtYmVyLCBudW1iZXI+IHwgTWFwPG51bWJlciwgbnVtYmVyPlxuICApOiBQcm9taXNlPExlYWRlcmJvYXJkVXBzZXJ0LlJlc3BvbnNlPjtcbiAgZmV0Y2hCeVNjb3JlKFxuICAgIGNhY2hlTmFtZTogc3RyaW5nLFxuICAgIGxlYWRlcmJvYXJkTmFtZTogc3RyaW5nLFxuICAgIG1pblNjb3JlPzogbnVtYmVyLFxuICAgIG1heFNjb3JlPzogbnVtYmVyLFxuICAgIG9yZGVyPzogTGVhZGVyYm9hcmRPcmRlcixcbiAgICBvZmZzZXQ/OiBudW1iZXIsXG4gICAgY291bnQ/OiBudW1iZXJcbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZEZldGNoLlJlc3BvbnNlPjtcbiAgZmV0Y2hCeVJhbmsoXG4gICAgY2FjaGVOYW1lOiBzdHJpbmcsXG4gICAgbGVhZGVyYm9hcmROYW1lOiBzdHJpbmcsXG4gICAgc3RhcnRSYW5rOiBudW1iZXIsXG4gICAgZW5kUmFuazogbnVtYmVyLFxuICAgIG9yZGVyPzogTGVhZGVyYm9hcmRPcmRlclxuICApOiBQcm9taXNlPExlYWRlcmJvYXJkRmV0Y2guUmVzcG9uc2U+O1xuICBnZXRSYW5rKFxuICAgIGNhY2hlTmFtZTogc3RyaW5nLFxuICAgIGxlYWRlcmJvYXJkTmFtZTogc3RyaW5nLFxuICAgIGlkczogQXJyYXk8bnVtYmVyPixcbiAgICBvcmRlcj86IExlYWRlcmJvYXJkT3JkZXJcbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZEZldGNoLlJlc3BvbnNlPjtcbiAgbGVuZ3RoKFxuICAgIGNhY2hlTmFtZTogc3RyaW5nLFxuICAgIGxlYWRlcmJvYXJkTmFtZTogc3RyaW5nXG4gICk6IFByb21pc2U8TGVhZGVyYm9hcmRMZW5ndGguUmVzcG9uc2U+O1xuICByZW1vdmVFbGVtZW50cyhcbiAgICBjYWNoZU5hbWU6IHN0cmluZyxcbiAgICBsZWFkZXJib2FyZE5hbWU6IHN0cmluZyxcbiAgICBpZHM6IEFycmF5PG51bWJlcj5cbiAgKTogUHJvbWlzZTxMZWFkZXJib2FyZFJlbW92ZUVsZW1lbnRzLlJlc3BvbnNlPjtcbiAgZGVsZXRlKFxuICAgIGNhY2hlTmFtZTogc3RyaW5nLFxuICAgIGxlYWRlcmJvYXJkTmFtZTogc3RyaW5nXG4gICk6IFByb21pc2U8TGVhZGVyYm9hcmREZWxldGUuUmVzcG9uc2U+O1xufVxuIl19
|
@@ -18,6 +18,7 @@ export declare function validateTtlMinutes(ttlMinutes: number): void;
|
|
18
18
|
export declare function validateValidForSeconds(validForSeconds: number): void;
|
19
19
|
export declare function validateTimeout(timeout: number): void;
|
20
20
|
export declare function validateDisposableTokenExpiry(expiresIn: ExpiresIn): void;
|
21
|
+
export declare function validateDisposableTokenTokenID(tokenId: string): void;
|
21
22
|
export declare function isBase64(str: string): boolean;
|
22
23
|
export declare function validateLeaderboardName(name: string): void;
|
23
24
|
export declare function validateLeaderboardRanks(start_rank: number, end_rank: number): void;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.validateLeaderboardNumberOfElements = exports.validateLeaderboardCount = exports.validateLeaderboardOffset = exports.validateLeaderboardRanks = exports.validateLeaderboardName = exports.isBase64 = exports.validateDisposableTokenExpiry = exports.validateTimeout = exports.validateValidForSeconds = exports.validateTtlMinutes = exports.validateTopK = exports.validateNumDimensions = exports.validateIndexName = exports.validateTopicName = exports.validateListSliceStartEnd = exports.validateListName = exports.validateDictionaryName = exports.validateSortedSetCount = exports.validateSortedSetOffset = exports.validateSortedSetScores = exports.validateSortedSetRanks = exports.validateSortedSetName = exports.validateSetName = exports.validateCacheKeyOrPrefix = exports.validateCacheName = void 0;
|
3
|
+
exports.validateLeaderboardNumberOfElements = exports.validateLeaderboardCount = exports.validateLeaderboardOffset = exports.validateLeaderboardRanks = exports.validateLeaderboardName = exports.isBase64 = exports.validateDisposableTokenTokenID = exports.validateDisposableTokenExpiry = exports.validateTimeout = exports.validateValidForSeconds = exports.validateTtlMinutes = exports.validateTopK = exports.validateNumDimensions = exports.validateIndexName = exports.validateTopicName = exports.validateListSliceStartEnd = exports.validateListName = exports.validateDictionaryName = exports.validateSortedSetCount = exports.validateSortedSetOffset = exports.validateSortedSetScores = exports.validateSortedSetRanks = exports.validateSortedSetName = exports.validateSetName = exports.validateCacheKeyOrPrefix = exports.validateCacheName = void 0;
|
4
4
|
const errors_1 = require("../../errors");
|
5
5
|
const string_1 = require("./string");
|
6
6
|
function validateCacheName(name) {
|
@@ -139,6 +139,12 @@ function validateDisposableTokenExpiry(expiresIn) {
|
|
139
139
|
}
|
140
140
|
}
|
141
141
|
exports.validateDisposableTokenExpiry = validateDisposableTokenExpiry;
|
142
|
+
function validateDisposableTokenTokenID(tokenId) {
|
143
|
+
if (tokenId.length > 64) {
|
144
|
+
throw new errors_1.InvalidArgumentError('TokenID must be less than or equal to 64 characters.');
|
145
|
+
}
|
146
|
+
}
|
147
|
+
exports.validateDisposableTokenTokenID = validateDisposableTokenTokenID;
|
142
148
|
function isEmpty(str) {
|
143
149
|
return !str.trim();
|
144
150
|
}
|
@@ -184,4 +190,4 @@ function validateLeaderboardNumberOfElements(numElements) {
|
|
184
190
|
}
|
185
191
|
}
|
186
192
|
exports.validateLeaderboardNumberOfElements = validateLeaderboardNumberOfElements;
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../src/internal/utils/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import {InvalidArgumentError} from '../../errors';\nimport {ExpiresIn} from '../../utils';\nimport {decodeFromBase64, encodeToBase64} from './string';\n\nexport function validateCacheName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('cache name must not be empty');\n  }\n}\n\nexport function validateCacheKeyOrPrefix(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('cache key or key prefix must not be empty');\n  }\n}\n\nexport function validateSetName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('set name must not be empty');\n  }\n}\n\nexport function validateSortedSetName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('sorted set name must not be empty');\n  }\n}\n\nexport function validateSortedSetRanks(start_rank: number, end_rank?: number) {\n  if (end_rank === undefined) {\n    return;\n  }\n  if (start_rank > 0 && end_rank > 0 && start_rank > end_rank) {\n    throw new InvalidArgumentError('start rank must be less than end rank');\n  }\n  if (start_rank < 0 && end_rank < 0 && start_rank >= end_rank) {\n    throw new InvalidArgumentError(\n      'negative start rank must be less than negative end rank'\n    );\n  }\n}\n\nexport function validateSortedSetScores(minScore?: number, maxScore?: number) {\n  if (minScore === undefined) return;\n  if (maxScore === undefined) return;\n  if (minScore > maxScore) {\n    throw new InvalidArgumentError(\n      'minScore must be less than or equal to maxScore'\n    );\n  }\n}\n\nexport function validateSortedSetOffset(offset: number) {\n  if (offset < 0) {\n    throw new InvalidArgumentError('offset must be non-negative (>= 0)');\n  }\n}\n\nexport function validateSortedSetCount(count: number) {\n  if (count < 1) {\n    throw new InvalidArgumentError('count must be strictly positive (> 0)');\n  }\n}\n\nexport function validateDictionaryName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('dictionary name must not be empty');\n  }\n}\n\nexport function validateListName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('list name must not be empty');\n  }\n}\n\nexport function validateListSliceStartEnd(\n  startIndex?: number,\n  endIndex?: number\n) {\n  if (startIndex === undefined || endIndex === undefined) return;\n  // can't validate bounds for start and index of either or are negative without list length\n  if (startIndex > 0 || endIndex < 0) return;\n  if (endIndex <= startIndex) {\n    throw new InvalidArgumentError(\n      'endIndex (exclusive) must be larger than startIndex (inclusive)'\n    );\n  }\n}\n\nexport function validateTopicName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('topic name must not be empty');\n  }\n}\n\nexport function validateIndexName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('index name must not be empty');\n  }\n}\n\nexport function validateNumDimensions(numDimensions: number) {\n  if (numDimensions <= 0) {\n    throw new InvalidArgumentError('numDimensions must be greater than zero');\n  }\n}\n\nexport function validateTopK(topK: number) {\n  if (topK <= 0) {\n    throw new InvalidArgumentError('topK must be greater than zero');\n  }\n}\n\nexport function validateTtlMinutes(ttlMinutes: number) {\n  if (ttlMinutes < 0) {\n    throw new InvalidArgumentError('ttlMinutes must be positive');\n  }\n}\n\nexport function validateValidForSeconds(validForSeconds: number) {\n  if (validForSeconds < 0) {\n    throw new InvalidArgumentError('validForSeconds must be positive');\n  }\n}\n\nexport function validateTimeout(timeout: number) {\n  if (timeout < 0) {\n    throw new InvalidArgumentError('timeout must be positive');\n  }\n}\n\nexport function validateDisposableTokenExpiry(expiresIn: ExpiresIn) {\n  if (!expiresIn.doesExpire()) {\n    throw new InvalidArgumentError('disposable tokens must have an expiry');\n  }\n  if (expiresIn.seconds() < 0) {\n    throw new InvalidArgumentError('disposable token expiry must be positive');\n  }\n  if (expiresIn.seconds() > 60 * 60) {\n    // 60 seconds * 60 minutes\n    throw new InvalidArgumentError(\n      'disposable tokens must expire within 1 hour'\n    );\n  }\n}\n\nfunction isEmpty(str: string): boolean {\n  return !str.trim();\n}\n\nexport function isBase64(str: string): boolean {\n  try {\n    return encodeToBase64(decodeFromBase64(str)) === str;\n  } catch (e) {\n    return false;\n  }\n}\n\nexport function validateLeaderboardName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('leaderboard name must not be empty');\n  }\n}\n\nexport function validateLeaderboardRanks(start_rank: number, end_rank: number) {\n  if (start_rank > 0 && end_rank > 0 && start_rank >= end_rank) {\n    throw new InvalidArgumentError('start rank must be less than end rank');\n  }\n  if (start_rank < 0 || end_rank < 0) {\n    throw new InvalidArgumentError('ranks must be positive');\n  }\n}\n\nexport function validateLeaderboardOffset(offset: number) {\n  if (offset < 0) {\n    throw new InvalidArgumentError('offset must be non-negative (>= 0)');\n  }\n}\n\nexport function validateLeaderboardCount(count: number) {\n  if (count < 1) {\n    throw new InvalidArgumentError('count must be strictly positive (> 0)');\n  }\n}\n\nexport function validateLeaderboardNumberOfElements(numElements: number) {\n  if (numElements < 1) {\n    throw new InvalidArgumentError('must provide at least one element');\n  }\n}\n"]}
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../src/internal/utils/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import {InvalidArgumentError} from '../../errors';\nimport {ExpiresIn} from '../../utils';\nimport {decodeFromBase64, encodeToBase64} from './string';\n\nexport function validateCacheName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('cache name must not be empty');\n  }\n}\n\nexport function validateCacheKeyOrPrefix(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('cache key or key prefix must not be empty');\n  }\n}\n\nexport function validateSetName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('set name must not be empty');\n  }\n}\n\nexport function validateSortedSetName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('sorted set name must not be empty');\n  }\n}\n\nexport function validateSortedSetRanks(start_rank: number, end_rank?: number) {\n  if (end_rank === undefined) {\n    return;\n  }\n  if (start_rank > 0 && end_rank > 0 && start_rank > end_rank) {\n    throw new InvalidArgumentError('start rank must be less than end rank');\n  }\n  if (start_rank < 0 && end_rank < 0 && start_rank >= end_rank) {\n    throw new InvalidArgumentError(\n      'negative start rank must be less than negative end rank'\n    );\n  }\n}\n\nexport function validateSortedSetScores(minScore?: number, maxScore?: number) {\n  if (minScore === undefined) return;\n  if (maxScore === undefined) return;\n  if (minScore > maxScore) {\n    throw new InvalidArgumentError(\n      'minScore must be less than or equal to maxScore'\n    );\n  }\n}\n\nexport function validateSortedSetOffset(offset: number) {\n  if (offset < 0) {\n    throw new InvalidArgumentError('offset must be non-negative (>= 0)');\n  }\n}\n\nexport function validateSortedSetCount(count: number) {\n  if (count < 1) {\n    throw new InvalidArgumentError('count must be strictly positive (> 0)');\n  }\n}\n\nexport function validateDictionaryName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('dictionary name must not be empty');\n  }\n}\n\nexport function validateListName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('list name must not be empty');\n  }\n}\n\nexport function validateListSliceStartEnd(\n  startIndex?: number,\n  endIndex?: number\n) {\n  if (startIndex === undefined || endIndex === undefined) return;\n  // can't validate bounds for start and index of either or are negative without list length\n  if (startIndex > 0 || endIndex < 0) return;\n  if (endIndex <= startIndex) {\n    throw new InvalidArgumentError(\n      'endIndex (exclusive) must be larger than startIndex (inclusive)'\n    );\n  }\n}\n\nexport function validateTopicName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('topic name must not be empty');\n  }\n}\n\nexport function validateIndexName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('index name must not be empty');\n  }\n}\n\nexport function validateNumDimensions(numDimensions: number) {\n  if (numDimensions <= 0) {\n    throw new InvalidArgumentError('numDimensions must be greater than zero');\n  }\n}\n\nexport function validateTopK(topK: number) {\n  if (topK <= 0) {\n    throw new InvalidArgumentError('topK must be greater than zero');\n  }\n}\n\nexport function validateTtlMinutes(ttlMinutes: number) {\n  if (ttlMinutes < 0) {\n    throw new InvalidArgumentError('ttlMinutes must be positive');\n  }\n}\n\nexport function validateValidForSeconds(validForSeconds: number) {\n  if (validForSeconds < 0) {\n    throw new InvalidArgumentError('validForSeconds must be positive');\n  }\n}\n\nexport function validateTimeout(timeout: number) {\n  if (timeout < 0) {\n    throw new InvalidArgumentError('timeout must be positive');\n  }\n}\n\nexport function validateDisposableTokenExpiry(expiresIn: ExpiresIn) {\n  if (!expiresIn.doesExpire()) {\n    throw new InvalidArgumentError('disposable tokens must have an expiry');\n  }\n  if (expiresIn.seconds() < 0) {\n    throw new InvalidArgumentError('disposable token expiry must be positive');\n  }\n  if (expiresIn.seconds() > 60 * 60) {\n    // 60 seconds * 60 minutes\n    throw new InvalidArgumentError(\n      'disposable tokens must expire within 1 hour'\n    );\n  }\n}\n\nexport function validateDisposableTokenTokenID(tokenId: string) {\n  if (tokenId.length > 64) {\n    throw new InvalidArgumentError(\n      'TokenID must be less than or equal to 64 characters.'\n    );\n  }\n}\n\nfunction isEmpty(str: string): boolean {\n  return !str.trim();\n}\n\nexport function isBase64(str: string): boolean {\n  try {\n    return encodeToBase64(decodeFromBase64(str)) === str;\n  } catch (e) {\n    return false;\n  }\n}\n\nexport function validateLeaderboardName(name: string) {\n  if (isEmpty(name)) {\n    throw new InvalidArgumentError('leaderboard name must not be empty');\n  }\n}\n\nexport function validateLeaderboardRanks(start_rank: number, end_rank: number) {\n  if (start_rank > 0 && end_rank > 0 && start_rank >= end_rank) {\n    throw new InvalidArgumentError('start rank must be less than end rank');\n  }\n  if (start_rank < 0 || end_rank < 0) {\n    throw new InvalidArgumentError('ranks must be positive');\n  }\n}\n\nexport function validateLeaderboardOffset(offset: number) {\n  if (offset < 0) {\n    throw new InvalidArgumentError('offset must be non-negative (>= 0)');\n  }\n}\n\nexport function validateLeaderboardCount(count: number) {\n  if (count < 1) {\n    throw new InvalidArgumentError('count must be strictly positive (> 0)');\n  }\n}\n\nexport function validateLeaderboardNumberOfElements(numElements: number) {\n  if (numElements < 1) {\n    throw new InvalidArgumentError('must provide at least one element');\n  }\n}\n"]}
|
@@ -6,8 +6,7 @@ import { ResponseBase } from '../response-base';
|
|
6
6
|
* response object is resolved to a type-safe object of one of
|
7
7
|
* the following subtypes:
|
8
8
|
*
|
9
|
-
* - {
|
10
|
-
* - {NotFound}
|
9
|
+
* - {Success}
|
11
10
|
* - {Error}
|
12
11
|
*
|
13
12
|
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
@@ -23,7 +22,7 @@ import { ResponseBase } from '../response-base';
|
|
23
22
|
*/
|
24
23
|
export declare abstract class Response extends ResponseBase {
|
25
24
|
}
|
26
|
-
declare class
|
25
|
+
declare class _Success extends Response {
|
27
26
|
private readonly _elements;
|
28
27
|
constructor(elements: _RankedElement[]);
|
29
28
|
/**
|
@@ -36,23 +35,15 @@ declare class _Found extends Response {
|
|
36
35
|
rank: number;
|
37
36
|
}[];
|
38
37
|
}
|
39
|
-
declare const
|
40
|
-
new (...args: any[]): {
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
*/
|
45
|
-
export declare class Found extends Found_base {
|
46
|
-
}
|
47
|
-
declare class _NotFound extends Response {
|
48
|
-
}
|
49
|
-
declare const NotFound_base: {
|
50
|
-
new (...args: any[]): {};
|
51
|
-
} & typeof _NotFound;
|
38
|
+
declare const Success_base: {
|
39
|
+
new (...args: any[]): {
|
40
|
+
readonly is_success: boolean;
|
41
|
+
};
|
42
|
+
} & typeof _Success;
|
52
43
|
/**
|
53
|
-
* Indicates
|
44
|
+
* Indicates a Successful leaderboard fetch request.
|
54
45
|
*/
|
55
|
-
export declare class
|
46
|
+
export declare class Success extends Success_base {
|
56
47
|
}
|
57
48
|
declare class _Error extends Response {
|
58
49
|
protected _innerException: SdkError;
|
@@ -1,14 +1,13 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.Error = exports.
|
3
|
+
exports.Error = exports.Success = exports.Response = void 0;
|
4
4
|
const response_base_1 = require("../response-base");
|
5
5
|
/**
|
6
6
|
* Parent response type for a leaderboard fetch by rank or by score request. The
|
7
7
|
* response object is resolved to a type-safe object of one of
|
8
8
|
* the following subtypes:
|
9
9
|
*
|
10
|
-
* - {
|
11
|
-
* - {NotFound}
|
10
|
+
* - {Success}
|
12
11
|
* - {Error}
|
13
12
|
*
|
14
13
|
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
@@ -25,7 +24,7 @@ const response_base_1 = require("../response-base");
|
|
25
24
|
class Response extends response_base_1.ResponseBase {
|
26
25
|
}
|
27
26
|
exports.Response = Response;
|
28
|
-
class
|
27
|
+
class _Success extends Response {
|
29
28
|
constructor(elements) {
|
30
29
|
super();
|
31
30
|
this._elements = elements;
|
@@ -45,19 +44,11 @@ class _Found extends Response {
|
|
45
44
|
}
|
46
45
|
}
|
47
46
|
/**
|
48
|
-
* Indicates a Successful leaderboard fetch
|
47
|
+
* Indicates a Successful leaderboard fetch request.
|
49
48
|
*/
|
50
|
-
class
|
49
|
+
class Success extends (0, response_base_1.ResponseSuccess)(_Success) {
|
51
50
|
}
|
52
|
-
exports.
|
53
|
-
class _NotFound extends Response {
|
54
|
-
}
|
55
|
-
/**
|
56
|
-
* Indicates that the requested data was not available in the cache.
|
57
|
-
*/
|
58
|
-
class NotFound extends (0, response_base_1.ResponseNotFound)(_NotFound) {
|
59
|
-
}
|
60
|
-
exports.NotFound = NotFound;
|
51
|
+
exports.Success = Success;
|
61
52
|
class _Error extends Response {
|
62
53
|
constructor(_innerException) {
|
63
54
|
super();
|
@@ -77,4 +68,4 @@ class _Error extends Response {
|
|
77
68
|
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
78
69
|
}
|
79
70
|
exports.Error = Error;
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVhZGVyYm9hcmQtZmV0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbWVzc2FnZXMvcmVzcG9uc2VzL2xlYWRlcmJvYXJkL2xlYWRlcmJvYXJkLWZldGNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLG9EQUE4RTtBQUU5RTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JHO0FBQ0gsTUFBc0IsUUFBUyxTQUFRLDRCQUFZO0NBQUc7QUFBdEQsNEJBQXNEO0FBRXRELE1BQU0sUUFBUyxTQUFRLFFBQVE7SUFHN0IsWUFBWSxRQUEwQjtRQUNwQyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO0lBQzVCLENBQUM7SUFFRDs7O09BR0c7SUFDSSxNQUFNO1FBQ1gsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUMvQixPQUFPO2dCQUNMLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRTtnQkFDWCxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7Z0JBQ2pCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTthQUNoQixDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILE1BQWEsT0FBUSxTQUFRLElBQUEsK0JBQWUsRUFBQyxRQUFRLENBQUM7Q0FBRztBQUF6RCwwQkFBeUQ7QUFFekQsTUFBTSxNQUFPLFNBQVEsUUFBUTtJQUMzQixZQUFzQixlQUF5QjtRQUM3QyxLQUFLLEVBQUUsQ0FBQztRQURZLG9CQUFlLEdBQWYsZUFBZSxDQUFVO0lBRS9DLENBQUM7Q0FDRjtBQUVEOzs7Ozs7Ozs7R0FTRztBQUNILE1BQWEsS0FBTSxTQUFRLElBQUEsNkJBQWEsRUFBQyxNQUFNLENBQUM7Q0FBRztBQUFuRCxzQkFBbUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1Nka0Vycm9yfSBmcm9tICcuLi8uLi8uLi9lcnJvcnMnO1xuaW1wb3J0IHtfUmFua2VkRWxlbWVudH0gZnJvbSAnLi4vZ3JwYy1yZXNwb25zZS10eXBlcyc7XG5pbXBvcnQge1Jlc3BvbnNlQmFzZSwgUmVzcG9uc2VFcnJvciwgUmVzcG9uc2VTdWNjZXNzfSBmcm9tICcuLi9yZXNwb25zZS1iYXNlJztcblxuLyoqXG4gKiBQYXJlbnQgcmVzcG9uc2UgdHlwZSBmb3IgYSBsZWFkZXJib2FyZCBmZXRjaCBieSByYW5rIG9yIGJ5IHNjb3JlIHJlcXVlc3QuICBUaGVcbiAqIHJlc3BvbnNlIG9iamVjdCBpcyByZXNvbHZlZCB0byBhIHR5cGUtc2FmZSBvYmplY3Qgb2Ygb25lIG9mXG4gKiB0aGUgZm9sbG93aW5nIHN1YnR5cGVzOlxuICpcbiAqIC0ge1N1Y2Nlc3N9XG4gKiAtIHtFcnJvcn1cbiAqXG4gKiBgaW5zdGFuY2VvZmAgdHlwZSBndWFyZHMgY2FuIGJlIHVzZWQgdG8gb3BlcmF0ZSBvbiB0aGUgYXBwcm9wcmlhdGUgc3VidHlwZS5cbiAqIEBleGFtcGxlXG4gKiBGb3IgZXhhbXBsZTpcbiAqIGBgYFxuICogaWYgKHJlc3BvbnNlIGluc3RhbmNlb2YgTGVhZGVyYm9hcmRGZXRjaEJ5U2NvcmUuRXJyb3IpIHtcbiAqICAgLy8gSGFuZGxlIGVycm9yIGFzIGFwcHJvcHJpYXRlLiAgVGhlIGNvbXBpbGVyIHdpbGwgc21hcnQtY2FzdCBgcmVzcG9uc2VgIHRvIHR5cGVcbiAqICAgLy8gYExlYWRlcmJvYXJkRmV0Y2hCeVNjb3JlLkVycm9yYCBpbiB0aGlzIGJsb2NrLCBzbyB5b3Ugd2lsbCBoYXZlIGFjY2VzcyB0byB0aGUgcHJvcGVydGllc1xuICogICAvLyBvZiB0aGUgRXJyb3IgY2xhc3M7IGUuZy4gYHJlc3BvbnNlLmVycm9yQ29kZSgpYC5cbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUmVzcG9uc2UgZXh0ZW5kcyBSZXNwb25zZUJhc2Uge31cblxuY2xhc3MgX1N1Y2Nlc3MgZXh0ZW5kcyBSZXNwb25zZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2VsZW1lbnRzOiBfUmFua2VkRWxlbWVudFtdO1xuXG4gIGNvbnN0cnVjdG9yKGVsZW1lbnRzOiBfUmFua2VkRWxlbWVudFtdKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLl9lbGVtZW50cyA9IGVsZW1lbnRzO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGVsZW1lbnRzIGFzIGFuIGFycmF5IG9mIG9iamVjdHMsIGVhY2ggY29udGFpbmluZyBhbiBgaWRgLCBgc2NvcmVgLCBhbmQgYHJhbmtgIGZpZWxkLlxuICAgKiBAcmV0dXJucyB7e2lkOiBudW1iZXIsIHNjb3JlOiBudW1iZXIsIHJhbms6IG51bWJlcn1bXX1cbiAgICovXG4gIHB1YmxpYyB2YWx1ZXMoKToge2lkOiBudW1iZXI7IHNjb3JlOiBudW1iZXI7IHJhbms6IG51bWJlcn1bXSB7XG4gICAgcmV0dXJuIHRoaXMuX2VsZW1lbnRzLm1hcChpdGVtID0+IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBpdGVtLmlkLFxuICAgICAgICBzY29yZTogaXRlbS5zY29yZSxcbiAgICAgICAgcmFuazogaXRlbS5yYW5rLFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEluZGljYXRlcyBhIFN1Y2Nlc3NmdWwgbGVhZGVyYm9hcmQgZmV0Y2ggcmVxdWVzdC5cbiAqL1xuZXhwb3J0IGNsYXNzIFN1Y2Nlc3MgZXh0ZW5kcyBSZXNwb25zZVN1Y2Nlc3MoX1N1Y2Nlc3MpIHt9XG5cbmNsYXNzIF9FcnJvciBleHRlbmRzIFJlc3BvbnNlIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIF9pbm5lckV4Y2VwdGlvbjogU2RrRXJyb3IpIHtcbiAgICBzdXBlcigpO1xuICB9XG59XG5cbi8qKlxuICogSW5kaWNhdGVzIHRoYXQgYW4gZXJyb3Igb2NjdXJyZWQgZHVyaW5nIHRoZSBsZWFkZXJib2FyZCBmZXRjaCBieSByYW5rIG9yIGJ5IHNjb3JlIHJlcXVlc3QuXG4gKlxuICogVGhpcyByZXNwb25zZSBvYmplY3QgaW5jbHVkZXMgdGhlIGZvbGxvd2luZyBmaWVsZHMgdGhhdCB5b3UgY2FuIHVzZSB0byBkZXRlcm1pbmVcbiAqIGhvdyB5b3Ugd291bGQgbGlrZSB0byBoYW5kbGUgdGhlIGVycm9yOlxuICpcbiAqIC0gYGVycm9yQ29kZSgpYCAtIGEgdW5pcXVlIE1vbWVudG8gZXJyb3IgY29kZSBpbmRpY2F0aW5nIHRoZSB0eXBlIG9mIGVycm9yIHRoYXQgb2NjdXJyZWQuXG4gKiAtIGBtZXNzYWdlKClgIC0gYSBodW1hbi1yZWFkYWJsZSBkZXNjcmlwdGlvbiBvZiB0aGUgZXJyb3JcbiAqIC0gYGlubmVyRXhjZXB0aW9uKClgIC0gdGhlIG9yaWdpbmFsIGVycm9yIHRoYXQgY2F1c2VkIHRoZSBmYWlsdXJlOyBjYW4gYmUgcmUtdGhyb3duLlxuICovXG5leHBvcnQgY2xhc3MgRXJyb3IgZXh0ZW5kcyBSZXNwb25zZUVycm9yKF9FcnJvcikge31cbiJdfQ==
|
@@ -5,8 +5,7 @@ import { ResponseBase } from '../response-base';
|
|
5
5
|
* response object is resolved to a type-safe object of one of
|
6
6
|
* the following subtypes:
|
7
7
|
*
|
8
|
-
* - {
|
9
|
-
* - {NotFound}
|
8
|
+
* - {Success}
|
10
9
|
* - {Error}
|
11
10
|
*
|
12
11
|
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
@@ -22,7 +21,7 @@ import { ResponseBase } from '../response-base';
|
|
22
21
|
*/
|
23
22
|
export declare abstract class Response extends ResponseBase {
|
24
23
|
}
|
25
|
-
declare class
|
24
|
+
declare class _Success extends Response {
|
26
25
|
private readonly _length;
|
27
26
|
constructor(length: number);
|
28
27
|
/**
|
@@ -32,23 +31,15 @@ declare class _Found extends Response {
|
|
32
31
|
length(): number;
|
33
32
|
toString(): string;
|
34
33
|
}
|
35
|
-
declare const
|
36
|
-
new (...args: any[]): {
|
37
|
-
|
34
|
+
declare const Success_base: {
|
35
|
+
new (...args: any[]): {
|
36
|
+
readonly is_success: boolean;
|
37
|
+
};
|
38
|
+
} & typeof _Success;
|
38
39
|
/**
|
39
40
|
* Indicates a successful leaderboard length request.
|
40
41
|
*/
|
41
|
-
export declare class
|
42
|
-
}
|
43
|
-
declare class _NotFound extends Response {
|
44
|
-
}
|
45
|
-
declare const NotFound_base: {
|
46
|
-
new (...args: any[]): {};
|
47
|
-
} & typeof _NotFound;
|
48
|
-
/**
|
49
|
-
* Indicates that the requested data was not available in the cache.
|
50
|
-
*/
|
51
|
-
export declare class NotFound extends NotFound_base {
|
42
|
+
export declare class Success extends Success_base {
|
52
43
|
}
|
53
44
|
declare class _Error extends Response {
|
54
45
|
protected _innerException: SdkError;
|
@@ -1,14 +1,13 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.Error = exports.
|
3
|
+
exports.Error = exports.Success = exports.Response = void 0;
|
4
4
|
const response_base_1 = require("../response-base");
|
5
5
|
/**
|
6
6
|
* Parent response type for a leaderboard length request. The
|
7
7
|
* response object is resolved to a type-safe object of one of
|
8
8
|
* the following subtypes:
|
9
9
|
*
|
10
|
-
* - {
|
11
|
-
* - {NotFound}
|
10
|
+
* - {Success}
|
12
11
|
* - {Error}
|
13
12
|
*
|
14
13
|
* `instanceof` type guards can be used to operate on the appropriate subtype.
|
@@ -25,7 +24,7 @@ const response_base_1 = require("../response-base");
|
|
25
24
|
class Response extends response_base_1.ResponseBase {
|
26
25
|
}
|
27
26
|
exports.Response = Response;
|
28
|
-
class
|
27
|
+
class _Success extends Response {
|
29
28
|
constructor(length) {
|
30
29
|
super();
|
31
30
|
this._length = length;
|
@@ -44,17 +43,9 @@ class _Found extends Response {
|
|
44
43
|
/**
|
45
44
|
* Indicates a successful leaderboard length request.
|
46
45
|
*/
|
47
|
-
class
|
46
|
+
class Success extends (0, response_base_1.ResponseSuccess)(_Success) {
|
48
47
|
}
|
49
|
-
exports.
|
50
|
-
class _NotFound extends Response {
|
51
|
-
}
|
52
|
-
/**
|
53
|
-
* Indicates that the requested data was not available in the cache.
|
54
|
-
*/
|
55
|
-
class NotFound extends (0, response_base_1.ResponseNotFound)(_NotFound) {
|
56
|
-
}
|
57
|
-
exports.NotFound = NotFound;
|
48
|
+
exports.Success = Success;
|
58
49
|
class _Error extends Response {
|
59
50
|
constructor(_innerException) {
|
60
51
|
super();
|
@@ -74,4 +65,4 @@ class _Error extends Response {
|
|
74
65
|
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
75
66
|
}
|
76
67
|
exports.Error = Error;
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVhZGVyYm9hcmQtbGVuZ3RoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL21lc3NhZ2VzL3Jlc3BvbnNlcy9sZWFkZXJib2FyZC9sZWFkZXJib2FyZC1sZW5ndGgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0Esb0RBQThFO0FBRTlFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQkc7QUFDSCxNQUFzQixRQUFTLFNBQVEsNEJBQVk7Q0FBRztBQUF0RCw0QkFBc0Q7QUFFdEQsTUFBTSxRQUFTLFNBQVEsUUFBUTtJQUU3QixZQUFZLE1BQWM7UUFDeEIsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUN4QixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksTUFBTTtRQUNYLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRWUsUUFBUTtRQUN0QixPQUFPLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBRSxZQUFZLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUN2RCxDQUFDO0NBQ0Y7QUFFRDs7R0FFRztBQUNILE1BQWEsT0FBUSxTQUFRLElBQUEsK0JBQWUsRUFBQyxRQUFRLENBQUM7Q0FBRztBQUF6RCwwQkFBeUQ7QUFFekQsTUFBTSxNQUFPLFNBQVEsUUFBUTtJQUMzQixZQUFzQixlQUF5QjtRQUM3QyxLQUFLLEVBQUUsQ0FBQztRQURZLG9CQUFlLEdBQWYsZUFBZSxDQUFVO0lBRS9DLENBQUM7Q0FDRjtBQUVEOzs7Ozs7Ozs7R0FTRztBQUNILE1BQWEsS0FBTSxTQUFRLElBQUEsNkJBQWEsRUFBQyxNQUFNLENBQUM7Q0FBRztBQUFuRCxzQkFBbUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1Nka0Vycm9yfSBmcm9tICcuLi8uLi8uLi9lcnJvcnMnO1xuaW1wb3J0IHtSZXNwb25zZUJhc2UsIFJlc3BvbnNlRXJyb3IsIFJlc3BvbnNlU3VjY2Vzc30gZnJvbSAnLi4vcmVzcG9uc2UtYmFzZSc7XG5cbi8qKlxuICogUGFyZW50IHJlc3BvbnNlIHR5cGUgZm9yIGEgbGVhZGVyYm9hcmQgbGVuZ3RoIHJlcXVlc3QuICBUaGVcbiAqIHJlc3BvbnNlIG9iamVjdCBpcyByZXNvbHZlZCB0byBhIHR5cGUtc2FmZSBvYmplY3Qgb2Ygb25lIG9mXG4gKiB0aGUgZm9sbG93aW5nIHN1YnR5cGVzOlxuICpcbiAqIC0ge1N1Y2Nlc3N9XG4gKiAtIHtFcnJvcn1cbiAqXG4gKiBgaW5zdGFuY2VvZmAgdHlwZSBndWFyZHMgY2FuIGJlIHVzZWQgdG8gb3BlcmF0ZSBvbiB0aGUgYXBwcm9wcmlhdGUgc3VidHlwZS5cbiAqIEBleGFtcGxlXG4gKiBGb3IgZXhhbXBsZTpcbiAqIGBgYFxuICogaWYgKHJlc3BvbnNlIGluc3RhbmNlb2YgTGVhZGVyYm9hcmRMZW5ndGguRXJyb3IpIHtcbiAqICAgLy8gSGFuZGxlIGVycm9yIGFzIGFwcHJvcHJpYXRlLiAgVGhlIGNvbXBpbGVyIHdpbGwgc21hcnQtY2FzdCBgcmVzcG9uc2VgIHRvIHR5cGVcbiAqICAgLy8gYExlYWRlcmJvYXJkTGVuZ3RoLkVycm9yYCBpbiB0aGlzIGJsb2NrLCBzbyB5b3Ugd2lsbCBoYXZlIGFjY2VzcyB0byB0aGUgcHJvcGVydGllc1xuICogICAvLyBvZiB0aGUgRXJyb3IgY2xhc3M7IGUuZy4gYHJlc3BvbnNlLmVycm9yQ29kZSgpYC5cbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUmVzcG9uc2UgZXh0ZW5kcyBSZXNwb25zZUJhc2Uge31cblxuY2xhc3MgX1N1Y2Nlc3MgZXh0ZW5kcyBSZXNwb25zZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2xlbmd0aDogbnVtYmVyO1xuICBjb25zdHJ1Y3RvcihsZW5ndGg6IG51bWJlcikge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5fbGVuZ3RoID0gbGVuZ3RoO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGxlbmd0aCBvZiB0aGUgbGVhZGVyYm9hcmRcbiAgICogQHJldHVybnMge251bWJlcn1cbiAgICovXG4gIHB1YmxpYyBsZW5ndGgoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5fbGVuZ3RoO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIHRvU3RyaW5nKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3N1cGVyLnRvU3RyaW5nKCl9OiBsZW5ndGggJHt0aGlzLl9sZW5ndGh9YDtcbiAgfVxufVxuXG4vKipcbiAqIEluZGljYXRlcyBhIHN1Y2Nlc3NmdWwgbGVhZGVyYm9hcmQgbGVuZ3RoIHJlcXVlc3QuXG4gKi9cbmV4cG9ydCBjbGFzcyBTdWNjZXNzIGV4dGVuZHMgUmVzcG9uc2VTdWNjZXNzKF9TdWNjZXNzKSB7fVxuXG5jbGFzcyBfRXJyb3IgZXh0ZW5kcyBSZXNwb25zZSB7XG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBfaW5uZXJFeGNlcHRpb246IFNka0Vycm9yKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxufVxuXG4vKipcbiAqIEluZGljYXRlcyB0aGF0IGFuIGVycm9yIG9jY3VycmVkIGR1cmluZyB0aGUgbGVhZGVyYm9hcmQgbGVuZ3RoIHJlcXVlc3QuXG4gKlxuICogVGhpcyByZXNwb25zZSBvYmplY3QgaW5jbHVkZXMgdGhlIGZvbGxvd2luZyBmaWVsZHMgdGhhdCB5b3UgY2FuIHVzZSB0byBkZXRlcm1pbmVcbiAqIGhvdyB5b3Ugd291bGQgbGlrZSB0byBoYW5kbGUgdGhlIGVycm9yOlxuICpcbiAqIC0gYGVycm9yQ29kZSgpYCAtIGEgdW5pcXVlIE1vbWVudG8gZXJyb3IgY29kZSBpbmRpY2F0aW5nIHRoZSB0eXBlIG9mIGVycm9yIHRoYXQgb2NjdXJyZWQuXG4gKiAtIGBtZXNzYWdlKClgIC0gYSBodW1hbi1yZWFkYWJsZSBkZXNjcmlwdGlvbiBvZiB0aGUgZXJyb3JcbiAqIC0gYGlubmVyRXhjZXB0aW9uKClgIC0gdGhlIG9yaWdpbmFsIGVycm9yIHRoYXQgY2F1c2VkIHRoZSBmYWlsdXJlOyBjYW4gYmUgcmUtdGhyb3duLlxuICovXG5leHBvcnQgY2xhc3MgRXJyb3IgZXh0ZW5kcyBSZXNwb25zZUVycm9yKF9FcnJvcikge31cbiJdfQ==
|
@@ -3,7 +3,7 @@ import { ResponseBase } from '../response-base';
|
|
3
3
|
export interface SearchHit {
|
4
4
|
id: string;
|
5
5
|
distance: number;
|
6
|
-
metadata: Record<string, string
|
6
|
+
metadata: Record<string, string | number | boolean | Array<string>>;
|
7
7
|
}
|
8
8
|
/**
|
9
9
|
* Parent response type for a VectorSearch request. The
|
@@ -64,4 +64,4 @@ class _Error extends Response {
|
|
64
64
|
class Error extends (0, response_base_1.ResponseError)(_Error) {
|
65
65
|
}
|
66
66
|
exports.Error = Error;
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLXNlYXJjaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9tZXNzYWdlcy9yZXNwb25zZXMvdmVjdG9yL3ZlY3Rvci1zZWFyY2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0Esb0RBQThFO0FBUTlFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQkc7QUFDSCxNQUFzQixRQUFTLFNBQVEsNEJBQVk7SUFDakQsSUFBSTtRQUNGLElBQUksSUFBSSxZQUFZLE9BQU8sRUFBRTtZQUMzQixPQUFPLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNwQjtRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQVBELDRCQU9DO0FBRUQsTUFBTSxRQUFTLFNBQVEsUUFBUTtDQUFHO0FBRWxDOztHQUVHO0FBQ0gsTUFBYSxPQUFRLFNBQVEsSUFBQSwrQkFBZSxFQUFDLFFBQVEsQ0FBQztJQUVwRCxZQUFZLElBQXNCO1FBQ2hDLEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7SUFDcEIsQ0FBQztJQUNELElBQUk7UUFDRixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztDQUNGO0FBVEQsMEJBU0M7QUFFRCxNQUFNLE1BQU8sU0FBUSxRQUFRO0lBQzNCLFlBQXNCLGVBQXlCO1FBQzdDLEtBQUssRUFBRSxDQUFDO1FBRFksb0JBQWUsR0FBZixlQUFlLENBQVU7SUFFL0MsQ0FBQztDQUNGO0FBRUQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxLQUFNLFNBQVEsSUFBQSw2QkFBYSxFQUFDLE1BQU0sQ0FBQztDQUFHO0FBQW5ELHNCQUFtRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7U2RrRXJyb3J9IGZyb20gJy4uLy4uLy4uL2Vycm9ycyc7XG5pbXBvcnQge1Jlc3BvbnNlQmFzZSwgUmVzcG9uc2VFcnJvciwgUmVzcG9uc2VTdWNjZXNzfSBmcm9tICcuLi9yZXNwb25zZS1iYXNlJztcblxuZXhwb3J0IGludGVyZmFjZSBTZWFyY2hIaXQge1xuICBpZDogc3RyaW5nO1xuICBkaXN0YW5jZTogbnVtYmVyO1xuICBtZXRhZGF0YTogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8IEFycmF5PHN0cmluZz4+O1xufVxuXG4vKipcbiAqIFBhcmVudCByZXNwb25zZSB0eXBlIGZvciBhIFZlY3RvclNlYXJjaCByZXF1ZXN0LiAgVGhlXG4gKiByZXNwb25zZSBvYmplY3QgaXMgcmVzb2x2ZWQgdG8gYSB0eXBlLXNhZmUgb2JqZWN0IG9mIG9uZSBvZlxuICogdGhlIGZvbGxvd2luZyBzdWJ0eXBlczpcbiAqXG4gKiAtIHtTdWNjZXNzfVxuICogLSB7RXJyb3J9XG4gKlxuICogYGluc3RhbmNlb2ZgIHR5cGUgZ3VhcmRzIGNhbiBiZSB1c2VkIHRvIG9wZXJhdGUgb24gdGhlIGFwcHJvcHJpYXRlIHN1YnR5cGUuXG4gKiBAZXhhbXBsZVxuICogRm9yIGV4YW1wbGU6XG4gKiBgYGBcbiAqIGlmIChyZXNwb25zZSBpbnN0YW5jZW9mIFZlY3RvclNlYXJjaC5FcnJvcikge1xuICogICAvLyBIYW5kbGUgZXJyb3IgYXMgYXBwcm9wcmlhdGUuICBUaGUgY29tcGlsZXIgd2lsbCBzbWFydC1jYXN0IGByZXNwb25zZWAgdG8gdHlwZVxuICogICAvLyBgVmVjdG9yU2VhcmNoLkVycm9yYCBpbiB0aGlzIGJsb2NrLCBzbyB5b3Ugd2lsbCBoYXZlIGFjY2VzcyB0byB0aGUgcHJvcGVydGllc1xuICogICAvLyBvZiB0aGUgRXJyb3IgY2xhc3M7IGUuZy4gYHJlc3BvbnNlLmVycm9yQ29kZSgpYC5cbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUmVzcG9uc2UgZXh0ZW5kcyBSZXNwb25zZUJhc2Uge1xuICBoaXRzKCk6IEFycmF5PFNlYXJjaEhpdD4gfCB1bmRlZmluZWQge1xuICAgIGlmICh0aGlzIGluc3RhbmNlb2YgU3VjY2Vzcykge1xuICAgICAgcmV0dXJuIHRoaXMuaGl0cygpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmNsYXNzIF9TdWNjZXNzIGV4dGVuZHMgUmVzcG9uc2Uge31cblxuLyoqXG4gKiBJbmRpY2F0ZXMgYSBTdWNjZXNzZnVsIFZlY3RvclNlYXJjaCByZXF1ZXN0LlxuICovXG5leHBvcnQgY2xhc3MgU3VjY2VzcyBleHRlbmRzIFJlc3BvbnNlU3VjY2VzcyhfU3VjY2Vzcykge1xuICBwcml2YXRlIHJlYWRvbmx5IF9oaXRzOiBBcnJheTxTZWFyY2hIaXQ+O1xuICBjb25zdHJ1Y3RvcihoaXRzOiBBcnJheTxTZWFyY2hIaXQ+KSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLl9oaXRzID0gaGl0cztcbiAgfVxuICBoaXRzKCk6IEFycmF5PFNlYXJjaEhpdD4ge1xuICAgIHJldHVybiB0aGlzLl9oaXRzO1xuICB9XG59XG5cbmNsYXNzIF9FcnJvciBleHRlbmRzIFJlc3BvbnNlIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIF9pbm5lckV4Y2VwdGlvbjogU2RrRXJyb3IpIHtcbiAgICBzdXBlcigpO1xuICB9XG59XG5cbi8qKlxuICogSW5kaWNhdGVzIHRoYXQgYW4gZXJyb3Igb2NjdXJyZWQgZHVyaW5nIHRoZSBWZWN0b3JTZWFyY2ggcmVxdWVzdC5cbiAqXG4gKiBUaGlzIHJlc3BvbnNlIG9iamVjdCBpbmNsdWRlcyB0aGUgZm9sbG93aW5nIGZpZWxkcyB0aGF0IHlvdSBjYW4gdXNlIHRvIGRldGVybWluZVxuICogaG93IHlvdSB3b3VsZCBsaWtlIHRvIGhhbmRsZSB0aGUgZXJyb3I6XG4gKlxuICogLSBgZXJyb3JDb2RlKClgIC0gYSB1bmlxdWUgTW9tZW50byBlcnJvciBjb2RlIGluZGljYXRpbmcgdGhlIHR5cGUgb2YgZXJyb3IgdGhhdCBvY2N1cnJlZC5cbiAqIC0gYG1lc3NhZ2UoKWAgLSBhIGh1bWFuLXJlYWRhYmxlIGRlc2NyaXB0aW9uIG9mIHRoZSBlcnJvclxuICogLSBgaW5uZXJFeGNlcHRpb24oKWAgLSB0aGUgb3JpZ2luYWwgZXJyb3IgdGhhdCBjYXVzZWQgdGhlIGZhaWx1cmU7IGNhbiBiZSByZS10aHJvd24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFcnJvciBleHRlbmRzIFJlc3BvbnNlRXJyb3IoX0Vycm9yKSB7fVxuIl19
|
@@ -1,3 +1,3 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLWluZGV4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21lc3NhZ2VzL3ZlY3Rvci1pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBWZWN0b3JJbmRleEl0ZW0ge1xuICBpZDogc3RyaW5nO1xuICB2ZWN0b3I6IEFycmF5PG51bWJlcj47XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8IEFycmF5PHN0cmluZz4+O1xufVxuIl19
|
@@ -123,20 +123,6 @@ export interface LeaderboardGetRankCallOptions {
|
|
123
123
|
order?: LeaderboardOrder;
|
124
124
|
}
|
125
125
|
export interface LeaderboardFetchByRankCallOptions {
|
126
|
-
/**
|
127
|
-
* The rank of the first element to return, inclusive.
|
128
|
-
* If the rank is not specified, defaults to 0.
|
129
|
-
* Ranks can be used to manually paginate through the leaderboard
|
130
|
-
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc)
|
131
|
-
*/
|
132
|
-
startRank?: number;
|
133
|
-
/**
|
134
|
-
* The rank of the last element to return, exclusive.
|
135
|
-
* If the rank is not specified, defaults to 8192.
|
136
|
-
* Ranks can be used to manually paginate through the leaderboard
|
137
|
-
* in batches of 8192 elements (e.g. request 0-8192, then 8192-16384, etc)
|
138
|
-
*/
|
139
|
-
endRank?: number;
|
140
126
|
/**
|
141
127
|
* The order in which to return the elements.
|
142
128
|
* If the order is not specified, the elements are returned in ascending order.
|
@@ -11,4 +11,4 @@ var LeaderboardOrder;
|
|
11
11
|
LeaderboardOrder["Ascending"] = "ASC";
|
12
12
|
LeaderboardOrder["Descending"] = "DESC";
|
13
13
|
})(LeaderboardOrder = exports.LeaderboardOrder || (exports.LeaderboardOrder = {}));
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGUtY2FsbC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2NhY2hlLWNhbGwtb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUE4QkEsSUFBWSxjQUdYO0FBSEQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHFDQUFtQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxjQUFjLEdBQWQsc0JBQWMsS0FBZCxzQkFBYyxRQUd6QjtBQTBGRCxJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDMUIscUNBQWlCLENBQUE7SUFDakIsdUNBQW1CLENBQUE7QUFDckIsQ0FBQyxFQUhXLGdCQUFnQixHQUFoQix3QkFBZ0IsS0FBaEIsd0JBQWdCLFFBRzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb2xsZWN0aW9uVHRsfSBmcm9tICcuL2NvbGxlY3Rpb24tdHRsJztcblxuZXhwb3J0IGludGVyZmFjZSBTY2FsYXJDYWxsT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgdGltZSB0byBsaXZlIGluIHNlY29uZHMgb2YgdGhlIG9iamVjdCBiZWluZyBtb2RpZmllZC5cbiAgICovXG4gIHR0bD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2xsZWN0aW9uQ2FsbE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIGxlbmd0aCBvZiB0aGUgVFRMIGFuZCB3aGV0aGVyIGl0IHNob3VsZCBiZSByZWZyZXNoZWQgd2hlbiB0aGUgY29sbGVjdGlvbiBpcyBtb2RpZmllZC5cbiAgICovXG4gIHR0bD86IENvbGxlY3Rpb25UdGw7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRnJvbnRUcnVuY2F0YWJsZUNhbGxPcHRpb25zIGV4dGVuZHMgQ29sbGVjdGlvbkNhbGxPcHRpb25zIHtcbiAgLyoqXG4gICAqIElmIHRoZSBjb2xsZWN0aW9uIGV4Y2VlZHMgdGhpcyBsZW5ndGgsIHJlbW92ZSBleGNlc3MgZnJvbSB0aGUgc3RhcnQgb2YgdGhlIGxpc3QuIE11c3QgYmUgcG9zaXRpdmUuXG4gICAqL1xuICB0cnVuY2F0ZUZyb250VG9TaXplPzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJhY2tUcnVuY2F0YWJsZUNhbGxPcHRpb25zIGV4dGVuZHMgQ29sbGVjdGlvbkNhbGxPcHRpb25zIHtcbiAgLyoqXG4gICAqIElmIHRoZSBjb2xsZWN0aW9uIGV4Y2VlZHMgdGhpcyBsZW5ndGgsIHJlbW92ZSBleGNlc3MgZnJvbSB0aGUgZW5kIG9mIHRoZSBsaXN0LiBNdXN0IGJlIHBvc2l0aXZlLlxuICAgKi9cbiAgdHJ1bmNhdGVCYWNrVG9TaXplPzogbnVtYmVyO1xufVxuXG5leHBvcnQgZW51bSBTb3J0ZWRTZXRPcmRlciB7XG4gIEFzY2VuZGluZyA9ICdBU0MnLFxuICBEZXNjZW5kaW5nID0gJ0RFU0MnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNvcnRlZFNldEZldGNoQnlSYW5rQ2FsbE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIHJhbmsgb2YgdGhlIGZpcnN0IGVsZW1lbnQgdG8gcmV0dXJuLCBpbmNsdXNpdmUuXG4gICAqIElmIG5lZ2F0aXZlLCB0aGUgcmFuayBpcyByZWxhdGl2ZSB0byB0aGUgZW5kIG9mIHRoZSBsaXN0LlxuICAgKiBJZiB0aGUgcmFuayBpcyBub3Qgc3BlY2lmaWVkLCB0aGUgZmlyc3QgZWxlbWVudCBpcyB1c2VkLlxuICAgKi9cbiAgc3RhcnRSYW5rPzogbnVtYmVyO1xuICAvKipcbiAgICogVGhlIHJhbmsgb2YgdGhlIGxhc3QgZWxlbWVudCB0byByZXR1cm4sIGV4Y2x1c2l2ZS5cbiAgICogSWYgbmVnYXRpdmUsIHRoZSByYW5rIGlzIHJlbGF0aXZlIHRvIHRoZSBlbmQgb2YgdGhlIGxpc3QuXG4gICAqIElmIHRoZSByYW5rIGlzIG5vdCBzcGVjaWZpZWQsIHRoZSByYW5nZSBleHRlbmRzIHRvIHRoZSBlbmQgb2YgdGhlIGxpc3QuXG4gICAqL1xuICBlbmRSYW5rPzogbnVtYmVyO1xuICAvKipcbiAgICogVGhlIG9yZGVyIGluIHdoaWNoIHRvIHJldHVybiB0aGUgZWxlbWVudHMuXG4gICAqIElmIHRoZSBvcmRlciBpcyBub3Qgc3BlY2lmaWVkLCB0aGUgZWxlbWVudHMgYXJlIHJldHVybmVkIGluIGFzY2VuZGluZyBvcmRlci5cbiAgICogSWYgZGVzY2VuZGluZyBvcmRlciBpcyB1c2VkLCB0aGUgc3RhcnQgYW5kIGVuZCByYW5rcyBhcmUgaW50ZXJwcmV0ZWQgYXMgaWZcbiAgICogdGhlIGxpc3Qgd2VyZSByZXZlcnNlZC5cbiAgICovXG4gIG9yZGVyPzogU29ydGVkU2V0T3JkZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydGVkU2V0RmV0Y2hCeVNjb3JlQ2FsbE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIG1pbmltdW0gc2NvcmUgb2YgdGhlIGVsZW1lbnRzIHRvIHJldHVybiwgaW5jbHVzaXZlLlxuICAgKiBJZiB0aGUgbWluaW11bSBzY29yZSBpcyBub3Qgc3BlY2lmaWVkLCB0aGUgcmFuZ2UgZXh0ZW5kcyB0byB0aGUgbG93ZXN0IHNjb3JlLlxuICAgKi9cbiAgbWluU2NvcmU/OiBudW1iZXI7XG4gIC8qKlxuICAgKiBUaGUgbWF4aW11bSBzY29yZSBvZiB0aGUgZWxlbWVudHMgdG8gcmV0dXJuLCBpbmNsdXNpdmUuXG4gICAqIElmIHRoZSBtYXhpbXVtIHNjb3JlIGlzIG5vdCBzcGVjaWZpZWQsIHRoZSByYW5nZSBleHRlbmRzIHRvIHRoZSBoaWdoZXN0IHNjb3JlLlxuICAgKi9cbiAgbWF4U2NvcmU/OiBudW1iZXI7XG4gIC8qKlxuICAgKiBUaGUgb3JkZXIgaW4gd2hpY2ggdG8gcmV0dXJuIHRoZSBlbGVtZW50cy5cbiAgICogSWYgdGhlIG9yZGVyIGlzIG5vdCBzcGVjaWZpZWQsIHRoZSBlbGVtZW50cyBhcmUgcmV0dXJuZWQgaW4gYXNjZW5kaW5nIG9yZGVyLlxuICAgKi9cbiAgb3JkZXI/OiBTb3J0ZWRTZXRPcmRlcjtcbiAgLyoqXG4gICAqIFRoZSBpbmRleCBvZmZzZXQgb2YgdGhlIGZpcnN0IGVsZW1lbnQgdG8gcmV0dXJuLCByZWxhdGl2ZSB0byB0aGUgZmlyc3QgZWxlbWVudCBpbiB0aGUgcmVzdWx0IHNldC5cbiAgICogSWYgc3BlY2lmaWVkIG11c3QgYmUgbm9uLW5lZ2F0aXZlICg+PSAwKS5cbiAgICogRGVmYXVsdHMgdG8gemVybywgaWUuIHRoZSBzdGFydCBhdCBmaXJzdCBlbGVtZW50IGluIHRoZSByZXN1bHQgc2V0LlxuICAgKi9cbiAgb2Zmc2V0PzogbnVtYmVyO1xuICAvKipcbiAgICogVGhlIG1heGltdW0gbnVtYmVyIG9mIGVsZW1lbnRzIHRvIHJldHVybi5cbiAgICogSWYgc3BlY2lmaWVkIG11c3QgYmUgc3RyaWN0bHkgcG9zaXRpdmUgKD4gMCkuXG4gICAqIERlZmF1bHRzIHRvIGFsbCBlbGVtZW50cyBpbiB0aGUgcmVzdWx0IHNldC5cbiAgICovXG4gIGNvdW50PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNvcnRlZFNldExlbmd0aEJ5U2NvcmVDYWxsT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBzY29yZSBvZiB0aGUgZWxlbWVudHMgdG8gaW5jbHVkZSB3aGVuIGNvdW50aW5nIG51bWJlciBvZiBpdGVtcyBpbiB0aGUgc2V0LCBpbmNsdXNpdmUuXG4gICAqIElmIHRoZSBtaW5pbXVtIHNjb3JlIGlzIG5vdCBzcGVjaWZpZWQsIHRoZSByYW5nZSBleHRlbmRzIHRvIHRoZSBsb3dlc3Qgc2NvcmUuXG4gICAqL1xuICBtaW5TY29yZT86IG51bWJlcjtcbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIHNjb3JlIG9mIHRoZSBlbGVtZW50cyB0byBpbmNsdWRlIHdoZW4gY291bnRpbmcgbnVtYmVyIG9mIGl0ZW1zIGluIHRoZSBzZXQsIGluY2x1c2l2ZS5cbiAgICogSWYgdGhlIG1heGltdW0gc2NvcmUgaXMgbm90IHNwZWNpZmllZCwgdGhlIHJhbmdlIGV4dGVuZHMgdG8gdGhlIGhpZ2hlc3Qgc2NvcmUuXG4gICAqL1xuICBtYXhTY29yZT86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMaXN0UmV0YWluQ2FsbE9wdGlvbnMgZXh0ZW5kcyBDb2xsZWN0aW9uQ2FsbE9wdGlvbnMge1xuICAvKipcbiAgICogU3RhcnRpbmcgaW5jbHVzaXZlIGluZGV4IG9mIG9wZXJhdGlvbi5cbiAgICovXG4gIHN0YXJ0SW5kZXg/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIEVuZGluZyBleGNsdXNpdmUgaW5kZXggb2Ygb3BlcmF0aW9uLlxuICAgKi9cbiAgZW5kSW5kZXg/
|
14
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-call-options.js","sourceRoot":"","sources":["../../../src/utils/cache-call-options.ts"],"names":[],"mappings":";;;AA8BA,IAAY,cAGX;AAHD,WAAY,cAAc;IACxB,mCAAiB,CAAA;IACjB,qCAAmB,CAAA;AACrB,CAAC,EAHW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAGzB;AA0FD,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,uCAAmB,CAAA;AACrB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B","sourcesContent":["import {CollectionTtl} from './collection-ttl';\n\nexport interface ScalarCallOptions {\n  /**\n   * The time to live in seconds of the object being modified.\n   */\n  ttl?: number;\n}\n\nexport interface CollectionCallOptions {\n  /**\n   * The length of the TTL and whether it should be refreshed when the collection is modified.\n   */\n  ttl?: CollectionTtl;\n}\n\nexport interface FrontTruncatableCallOptions extends CollectionCallOptions {\n  /**\n   * If the collection exceeds this length, remove excess from the start of the list. Must be positive.\n   */\n  truncateFrontToSize?: number;\n}\n\nexport interface BackTruncatableCallOptions extends CollectionCallOptions {\n  /**\n   * If the collection exceeds this length, remove excess from the end of the list. Must be positive.\n   */\n  truncateBackToSize?: number;\n}\n\nexport enum SortedSetOrder {\n  Ascending = 'ASC',\n  Descending = 'DESC',\n}\n\nexport interface SortedSetFetchByRankCallOptions {\n  /**\n   * The rank of the first element to return, inclusive.\n   * If negative, the rank is relative to the end of the list.\n   * If the rank is not specified, the first element is used.\n   */\n  startRank?: number;\n  /**\n   * The rank of the last element to return, exclusive.\n   * If negative, the rank is relative to the end of the list.\n   * If the rank is not specified, the range extends to the end of the list.\n   */\n  endRank?: number;\n  /**\n   * The order in which to return the elements.\n   * If the order is not specified, the elements are returned in ascending order.\n   * If descending order is used, the start and end ranks are interpreted as if\n   * the list were reversed.\n   */\n  order?: SortedSetOrder;\n}\n\nexport interface SortedSetFetchByScoreCallOptions {\n  /**\n   * The minimum score of the elements to return, inclusive.\n   * If the minimum score is not specified, the range extends to the lowest score.\n   */\n  minScore?: number;\n  /**\n   * The maximum score of the elements to return, inclusive.\n   * If the maximum score is not specified, the range extends to the highest score.\n   */\n  maxScore?: number;\n  /**\n   * The order in which to return the elements.\n   * If the order is not specified, the elements are returned in ascending order.\n   */\n  order?: SortedSetOrder;\n  /**\n   * The index offset of the first element to return, relative to the first element in the result set.\n   * If specified must be non-negative (>= 0).\n   * Defaults to zero, ie. the start at first element in the result set.\n   */\n  offset?: number;\n  /**\n   * The maximum number of elements to return.\n   * If specified must be strictly positive (> 0).\n   * Defaults to all elements in the result set.\n   */\n  count?: number;\n}\n\nexport interface SortedSetLengthByScoreCallOptions {\n  /**\n   * The minimum score of the elements to include when counting number of items in the set, inclusive.\n   * If the minimum score is not specified, the range extends to the lowest score.\n   */\n  minScore?: number;\n  /**\n   * The maximum score of the elements to include when counting number of items in the set, inclusive.\n   * If the maximum score is not specified, the range extends to the highest score.\n   */\n  maxScore?: number;\n}\n\nexport interface ListRetainCallOptions extends CollectionCallOptions {\n  /**\n   * Starting inclusive index of operation.\n   */\n  startIndex?: number;\n\n  /**\n   * Ending exclusive index of operation.\n   */\n  endIndex?: number;\n}\nexport interface ListFetchCallOptions {\n  /**\n   * Starting inclusive index of operation.\n   */\n  startIndex?: number;\n\n  /**\n   * Ending exclusive index of operation.\n   */\n  endIndex?: number;\n}\n\nexport enum LeaderboardOrder {\n  Ascending = 'ASC', // 0 is the lowest-scoring rank\n  Descending = 'DESC', // 0 is the highest-scoring rank.\n}\n\nexport interface LeaderboardGetRankCallOptions {\n  /**\n   * The order in which to return the elements.\n   * If the order is not specified, the elements are returned in ascending order.\n   * If descending order is used, the start and end ranks are interpreted as if\n   * the leaderboard were reversed.\n   */\n  order?: LeaderboardOrder;\n}\n\nexport interface LeaderboardFetchByRankCallOptions {\n  /**\n   * The order in which to return the elements.\n   * If the order is not specified, the elements are returned in ascending order.\n   * If descending order is used, the start and end ranks are interpreted as if\n   * the leaderboard were reversed.\n   */\n  order?: LeaderboardOrder;\n}\n\nexport interface LeaderboardFetchByScoreCallOptions {\n  /**\n   * The minimum score of the elements to return, inclusive.\n   * If the minimum score is not specified, the range extends to the lowest score.\n   */\n  minScore?: number;\n  /**\n   * The maximum score of the elements to return, exclusive.\n   * If the maximum score is not specified, the range extends to the highest score.\n   */\n  maxScore?: number;\n  /**\n   * The order in which to return the elements.\n   * If the order is not specified, the elements are returned in ascending order.\n   */\n  order?: LeaderboardOrder;\n  /**\n   * The index offset of the first element to return, relative to the first element in the result set.\n   * If specified must be non-negative (>= 0).\n   * Defaults to zero, ie. the start at first element in the result set.\n   */\n  offset?: number;\n  /**\n   * The maximum number of elements to return.\n   * If specified must be strictly positive (> 0).\n   * Defaults to 8192, the maximum number of elements that can be returned at a time.\n   */\n  count?: number;\n}\n"]}
|