@gomomento/sdk-core 1.19.0 → 1.21.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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gomomento/sdk-core",
3
- "version": "1.19.0",
3
+ "version": "1.21.0",
4
4
  "description": "Common code for Momento JS SDKs",
5
5
  "main": "dist/src/index.js",
6
6
  "files": [
@@ -1,41 +0,0 @@
1
- export interface GrpcConfigurationProps {
2
- /**
3
- * number of milliseconds the client is willing to wait for an RPC to complete before it is terminated
4
- * with a DeadlineExceeded error.
5
- */
6
- deadlineMillis: number;
7
- /**
8
- * the maximum amount of memory, in megabytes, that a session is allowed to consume. Sessions that consume
9
- * more than this amount will return a ResourceExhausted error.
10
- */
11
- maxSessionMemoryMb: number;
12
- }
13
- /**
14
- * Encapsulates gRPC configuration tunables.
15
- * @export
16
- * @interface GrpcConfiguration
17
- */
18
- export interface GrpcConfiguration {
19
- /**
20
- * @returns {number} number of milliseconds the client is willing to wait for an RPC to complete before it is terminated
21
- * with a DeadlineExceeded error.
22
- */
23
- getDeadlineMillis(): number;
24
- /**
25
- * Copy constructor for overriding the client-side deadline
26
- * @param {number} deadlineMillis
27
- * @returns {GrpcConfiguration} a new GrpcConfiguration with the specified client-side deadline
28
- */
29
- withDeadlineMillis(deadlineMillis: number): GrpcConfiguration;
30
- /**
31
- * @returns {number} the maximum amount of memory, in megabytes, that a session is allowed to consume. Sessions that consume
32
- * more than this amount will return a ResourceExhausted error.
33
- */
34
- getMaxSessionMemoryMb(): number;
35
- /**
36
- * Copy constructor for overriding the max session memory
37
- * @param {number} maxSessionMemoryMb the desired maximum amount of memory, in megabytes, to allow a client session to consume
38
- * @returns {GrpcConfiguration} a new GrpcConfiguration with the specified maximum memory
39
- */
40
- withMaxSessionMemoryMb(maxSessionMemoryMb: number): GrpcConfiguration;
41
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JwYy1jb25maWd1cmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbmZpZy90cmFuc3BvcnQvZ3JwYy1jb25maWd1cmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEdycGNDb25maWd1cmF0aW9uUHJvcHMge1xuICAvKipcbiAgICogbnVtYmVyIG9mIG1pbGxpc2Vjb25kcyB0aGUgY2xpZW50IGlzIHdpbGxpbmcgdG8gd2FpdCBmb3IgYW4gUlBDIHRvIGNvbXBsZXRlIGJlZm9yZSBpdCBpcyB0ZXJtaW5hdGVkXG4gICAqIHdpdGggYSBEZWFkbGluZUV4Y2VlZGVkIGVycm9yLlxuICAgKi9cbiAgZGVhZGxpbmVNaWxsaXM6IG51bWJlcjtcbiAgLyoqXG4gICAqIHRoZSBtYXhpbXVtIGFtb3VudCBvZiBtZW1vcnksIGluIG1lZ2FieXRlcywgdGhhdCBhIHNlc3Npb24gaXMgYWxsb3dlZCB0byBjb25zdW1lLiAgU2Vzc2lvbnMgdGhhdCBjb25zdW1lXG4gICAqIG1vcmUgdGhhbiB0aGlzIGFtb3VudCB3aWxsIHJldHVybiBhIFJlc291cmNlRXhoYXVzdGVkIGVycm9yLlxuICAgKi9cbiAgbWF4U2Vzc2lvbk1lbW9yeU1iOiBudW1iZXI7XG59XG5cbi8qKlxuICogRW5jYXBzdWxhdGVzIGdSUEMgY29uZmlndXJhdGlvbiB0dW5hYmxlcy5cbiAqIEBleHBvcnRcbiAqIEBpbnRlcmZhY2UgR3JwY0NvbmZpZ3VyYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHcnBjQ29uZmlndXJhdGlvbiB7XG4gIC8qKlxuICAgKiBAcmV0dXJucyB7bnVtYmVyfSBudW1iZXIgb2YgbWlsbGlzZWNvbmRzIHRoZSBjbGllbnQgaXMgd2lsbGluZyB0byB3YWl0IGZvciBhbiBSUEMgdG8gY29tcGxldGUgYmVmb3JlIGl0IGlzIHRlcm1pbmF0ZWRcbiAgICogICAgd2l0aCBhIERlYWRsaW5lRXhjZWVkZWQgZXJyb3IuXG4gICAqL1xuICBnZXREZWFkbGluZU1pbGxpcygpOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIENvcHkgY29uc3RydWN0b3IgZm9yIG92ZXJyaWRpbmcgdGhlIGNsaWVudC1zaWRlIGRlYWRsaW5lXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBkZWFkbGluZU1pbGxpc1xuICAgKiBAcmV0dXJucyB7R3JwY0NvbmZpZ3VyYXRpb259IGEgbmV3IEdycGNDb25maWd1cmF0aW9uIHdpdGggdGhlIHNwZWNpZmllZCBjbGllbnQtc2lkZSBkZWFkbGluZVxuICAgKi9cbiAgd2l0aERlYWRsaW5lTWlsbGlzKGRlYWRsaW5lTWlsbGlzOiBudW1iZXIpOiBHcnBjQ29uZmlndXJhdGlvbjtcblxuICAvKipcbiAgICogQHJldHVybnMge251bWJlcn0gdGhlIG1heGltdW0gYW1vdW50IG9mIG1lbW9yeSwgaW4gbWVnYWJ5dGVzLCB0aGF0IGEgc2Vzc2lvbiBpcyBhbGxvd2VkIHRvIGNvbnN1bWUuICBTZXNzaW9ucyB0aGF0IGNvbnN1bWVcbiAgICogICAgbW9yZSB0aGFuIHRoaXMgYW1vdW50IHdpbGwgcmV0dXJuIGEgUmVzb3VyY2VFeGhhdXN0ZWQgZXJyb3IuXG4gICAqL1xuICBnZXRNYXhTZXNzaW9uTWVtb3J5TWIoKTogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBDb3B5IGNvbnN0cnVjdG9yIGZvciBvdmVycmlkaW5nIHRoZSBtYXggc2Vzc2lvbiBtZW1vcnlcbiAgICogQHBhcmFtIHtudW1iZXJ9IG1heFNlc3Npb25NZW1vcnlNYiB0aGUgZGVzaXJlZCBtYXhpbXVtIGFtb3VudCBvZiBtZW1vcnksIGluIG1lZ2FieXRlcywgdG8gYWxsb3cgYSBjbGllbnQgc2Vzc2lvbiB0byBjb25zdW1lXG4gICAqIEByZXR1cm5zIHtHcnBjQ29uZmlndXJhdGlvbn0gYSBuZXcgR3JwY0NvbmZpZ3VyYXRpb24gd2l0aCB0aGUgc3BlY2lmaWVkIG1heGltdW0gbWVtb3J5XG4gICAqL1xuICB3aXRoTWF4U2Vzc2lvbk1lbW9yeU1iKG1heFNlc3Npb25NZW1vcnlNYjogbnVtYmVyKTogR3JwY0NvbmZpZ3VyYXRpb247XG59XG4iXX0=
@@ -1,2 +0,0 @@
1
- export * from './grpc-configuration';
2
- export * from './transport-strategy';
@@ -1,19 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./grpc-configuration"), exports);
18
- __exportStar(require("./transport-strategy"), exports);
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29uZmlnL3RyYW5zcG9ydC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdURBQXFDO0FBQ3JDLHVEQUFxQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZ3JwYy1jb25maWd1cmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNwb3J0LXN0cmF0ZWd5JztcbiJdfQ==
@@ -1,77 +0,0 @@
1
- import { GrpcConfiguration, GrpcConfigurationProps } from './grpc-configuration';
2
- export interface TransportStrategyProps {
3
- /**
4
- * low-level gRPC settings for communication with the Momento server
5
- */
6
- grpcConfiguration: GrpcConfiguration;
7
- /**
8
- * The maximum duration for which a connection may remain idle before being replaced. This
9
- * setting can be used to force re-connection of a client if it has been idle for too long.
10
- * In environments such as AWS lambda, if the lambda is suspended for too long the connection
11
- * may be closed by the load balancer, resulting in an error on the subsequent request. If
12
- * this setting is set to a duration less than the load balancer timeout, we can ensure that
13
- * the connection will be refreshed to avoid errors.
14
- * @returns {number}
15
- */
16
- maxIdleMillis: number;
17
- }
18
- /**
19
- * Configures the network options for communicating with the Momento service.
20
- * @export
21
- * @interface TransportStrategy
22
- */
23
- export interface TransportStrategy {
24
- /**
25
- * Configures the low-level gRPC settings for the Momento client's communication
26
- * with the Momento server.
27
- * @returns {GrpcConfiguration}
28
- */
29
- getGrpcConfig(): GrpcConfiguration;
30
- /**
31
- * Copy constructor for overriding the gRPC configuration
32
- * @param {GrpcConfiguration} grpcConfig
33
- * @returns {TransportStrategy} a new TransportStrategy with the specified gRPC config.
34
- */
35
- withGrpcConfig(grpcConfig: GrpcConfiguration): TransportStrategy;
36
- /**
37
- * Copy constructor to update the client-side timeout
38
- * @param {number} clientTimeoutMillis
39
- * @returns {TransportStrategy} a new TransportStrategy with the specified client timeout
40
- */
41
- withClientTimeoutMillis(clientTimeoutMillis: number): TransportStrategy;
42
- /**
43
- * The maximum duration for which a connection may remain idle before being replaced. This
44
- * setting can be used to force re-connection of a client if it has been idle for too long.
45
- * In environments such as AWS lambda, if the lambda is suspended for too long the connection
46
- * may be closed by the load balancer, resulting in an error on the subsequent request. If
47
- * this setting is set to a duration less than the load balancer timeout, we can ensure that
48
- * the connection will be refreshed to avoid errors.
49
- * @returns {number}
50
- */
51
- getMaxIdleMillis(): number;
52
- /**
53
- * Copy constructor to update the max idle connection timeout. (See {getMaxIdleMillis}.)
54
- * @param {number} maxIdleMillis
55
- * @returns {TransportStrategy} a new TransportStrategy with the specified max idle connection timeout.
56
- */
57
- withMaxIdleMillis(maxIdleMillis: number): TransportStrategy;
58
- }
59
- export declare class StaticGrpcConfiguration implements GrpcConfiguration {
60
- private readonly deadlineMillis;
61
- private readonly maxSessionMemoryMb;
62
- constructor(props: GrpcConfigurationProps);
63
- getDeadlineMillis(): number;
64
- getMaxSessionMemoryMb(): number;
65
- withDeadlineMillis(deadlineMillis: number): StaticGrpcConfiguration;
66
- withMaxSessionMemoryMb(maxSessionMemoryMb: number): StaticGrpcConfiguration;
67
- }
68
- export declare class StaticTransportStrategy implements TransportStrategy {
69
- private readonly grpcConfig;
70
- private readonly maxIdleMillis;
71
- constructor(props: TransportStrategyProps);
72
- getGrpcConfig(): GrpcConfiguration;
73
- withGrpcConfig(grpcConfig: GrpcConfiguration): StaticTransportStrategy;
74
- getMaxIdleMillis(): number;
75
- withMaxIdleMillis(maxIdleMillis: number): TransportStrategy;
76
- withClientTimeoutMillis(clientTimeout: number): StaticTransportStrategy;
77
- }
@@ -1,60 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StaticTransportStrategy = exports.StaticGrpcConfiguration = void 0;
4
- class StaticGrpcConfiguration {
5
- constructor(props) {
6
- this.deadlineMillis = props.deadlineMillis;
7
- this.maxSessionMemoryMb = props.maxSessionMemoryMb;
8
- }
9
- getDeadlineMillis() {
10
- return this.deadlineMillis;
11
- }
12
- getMaxSessionMemoryMb() {
13
- return this.maxSessionMemoryMb;
14
- }
15
- withDeadlineMillis(deadlineMillis) {
16
- return new StaticGrpcConfiguration({
17
- deadlineMillis: deadlineMillis,
18
- maxSessionMemoryMb: this.maxSessionMemoryMb,
19
- });
20
- }
21
- withMaxSessionMemoryMb(maxSessionMemoryMb) {
22
- return new StaticGrpcConfiguration({
23
- deadlineMillis: this.deadlineMillis,
24
- maxSessionMemoryMb: maxSessionMemoryMb,
25
- });
26
- }
27
- }
28
- exports.StaticGrpcConfiguration = StaticGrpcConfiguration;
29
- class StaticTransportStrategy {
30
- constructor(props) {
31
- this.grpcConfig = props.grpcConfiguration;
32
- this.maxIdleMillis = props.maxIdleMillis;
33
- }
34
- getGrpcConfig() {
35
- return this.grpcConfig;
36
- }
37
- withGrpcConfig(grpcConfig) {
38
- return new StaticTransportStrategy({
39
- grpcConfiguration: grpcConfig,
40
- maxIdleMillis: this.maxIdleMillis,
41
- });
42
- }
43
- getMaxIdleMillis() {
44
- return this.maxIdleMillis;
45
- }
46
- withMaxIdleMillis(maxIdleMillis) {
47
- return new StaticTransportStrategy({
48
- grpcConfiguration: this.grpcConfig,
49
- maxIdleMillis: maxIdleMillis,
50
- });
51
- }
52
- withClientTimeoutMillis(clientTimeout) {
53
- return new StaticTransportStrategy({
54
- grpcConfiguration: this.grpcConfig.withDeadlineMillis(clientTimeout),
55
- maxIdleMillis: this.maxIdleMillis,
56
- });
57
- }
58
- }
59
- exports.StaticTransportStrategy = StaticTransportStrategy;
60
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transport-strategy.js","sourceRoot":"","sources":["../../../../src/config/transport/transport-strategy.ts"],"names":[],"mappings":";;;AAiEA,MAAa,uBAAuB;IAGlC,YAAY,KAA6B;QACvC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,kBAAkB,CAAC;IACrD,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,qBAAqB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAED,kBAAkB,CAAC,cAAsB;QACvC,OAAO,IAAI,uBAAuB,CAAC;YACjC,cAAc,EAAE,cAAc;YAC9B,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;SAC5C,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,kBAA0B;QAC/C,OAAO,IAAI,uBAAuB,CAAC;YACjC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,kBAAkB,EAAE,kBAAkB;SACvC,CAAC,CAAC;IACL,CAAC;CACF;AA7BD,0DA6BC;AAED,MAAa,uBAAuB;IAIlC,YAAY,KAA6B;QACvC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,iBAAiB,CAAC;QAC1C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;IAC3C,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,cAAc,CAAC,UAA6B;QAC1C,OAAO,IAAI,uBAAuB,CAAC;YACjC,iBAAiB,EAAE,UAAU;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,aAAqB;QACrC,OAAO,IAAI,uBAAuB,CAAC;YACjC,iBAAiB,EAAE,IAAI,CAAC,UAAU;YAClC,aAAa,EAAE,aAAa;SAC7B,CAAC,CAAC;IACL,CAAC;IAED,uBAAuB,CAAC,aAAqB;QAC3C,OAAO,IAAI,uBAAuB,CAAC;YACjC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,aAAa,CAAC;YACpE,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;IACL,CAAC;CACF;AArCD,0DAqCC","sourcesContent":["import {GrpcConfiguration, GrpcConfigurationProps} from './grpc-configuration';\n\nexport interface TransportStrategyProps {\n  /**\n   * low-level gRPC settings for communication with the Momento server\n   */\n  grpcConfiguration: GrpcConfiguration;\n  /**\n   * The maximum duration for which a connection may remain idle before being replaced.  This\n   * setting can be used to force re-connection of a client if it has been idle for too long.\n   * In environments such as AWS lambda, if the lambda is suspended for too long the connection\n   * may be closed by the load balancer, resulting in an error on the subsequent request.  If\n   * this setting is set to a duration less than the load balancer timeout, we can ensure that\n   * the connection will be refreshed to avoid errors.\n   * @returns {number}\n   */\n  maxIdleMillis: number;\n}\n\n/**\n * Configures the network options for communicating with the Momento service.\n * @export\n * @interface TransportStrategy\n */\nexport interface TransportStrategy {\n  /**\n   * Configures the low-level gRPC settings for the Momento client's communication\n   * with the Momento server.\n   * @returns {GrpcConfiguration}\n   */\n  getGrpcConfig(): GrpcConfiguration;\n\n  /**\n   * Copy constructor for overriding the gRPC configuration\n   * @param {GrpcConfiguration} grpcConfig\n   * @returns {TransportStrategy} a new TransportStrategy with the specified gRPC config.\n   */\n  withGrpcConfig(grpcConfig: GrpcConfiguration): TransportStrategy;\n\n  /**\n   * Copy constructor to update the client-side timeout\n   * @param {number} clientTimeoutMillis\n   * @returns {TransportStrategy} a new TransportStrategy with the specified client timeout\n   */\n  withClientTimeoutMillis(clientTimeoutMillis: number): TransportStrategy;\n\n  /**\n   * The maximum duration for which a connection may remain idle before being replaced.  This\n   * setting can be used to force re-connection of a client if it has been idle for too long.\n   * In environments such as AWS lambda, if the lambda is suspended for too long the connection\n   * may be closed by the load balancer, resulting in an error on the subsequent request.  If\n   * this setting is set to a duration less than the load balancer timeout, we can ensure that\n   * the connection will be refreshed to avoid errors.\n   * @returns {number}\n   */\n  getMaxIdleMillis(): number;\n\n  /**\n   * Copy constructor to update the max idle connection timeout.  (See {getMaxIdleMillis}.)\n   * @param {number} maxIdleMillis\n   * @returns {TransportStrategy} a new TransportStrategy with the specified max idle connection timeout.\n   */\n  withMaxIdleMillis(maxIdleMillis: number): TransportStrategy;\n}\n\nexport class StaticGrpcConfiguration implements GrpcConfiguration {\n  private readonly deadlineMillis: number;\n  private readonly maxSessionMemoryMb: number;\n  constructor(props: GrpcConfigurationProps) {\n    this.deadlineMillis = props.deadlineMillis;\n    this.maxSessionMemoryMb = props.maxSessionMemoryMb;\n  }\n\n  getDeadlineMillis(): number {\n    return this.deadlineMillis;\n  }\n\n  getMaxSessionMemoryMb(): number {\n    return this.maxSessionMemoryMb;\n  }\n\n  withDeadlineMillis(deadlineMillis: number): StaticGrpcConfiguration {\n    return new StaticGrpcConfiguration({\n      deadlineMillis: deadlineMillis,\n      maxSessionMemoryMb: this.maxSessionMemoryMb,\n    });\n  }\n\n  withMaxSessionMemoryMb(maxSessionMemoryMb: number): StaticGrpcConfiguration {\n    return new StaticGrpcConfiguration({\n      deadlineMillis: this.deadlineMillis,\n      maxSessionMemoryMb: maxSessionMemoryMb,\n    });\n  }\n}\n\nexport class StaticTransportStrategy implements TransportStrategy {\n  private readonly grpcConfig: GrpcConfiguration;\n  private readonly maxIdleMillis: number;\n\n  constructor(props: TransportStrategyProps) {\n    this.grpcConfig = props.grpcConfiguration;\n    this.maxIdleMillis = props.maxIdleMillis;\n  }\n\n  getGrpcConfig(): GrpcConfiguration {\n    return this.grpcConfig;\n  }\n\n  withGrpcConfig(grpcConfig: GrpcConfiguration): StaticTransportStrategy {\n    return new StaticTransportStrategy({\n      grpcConfiguration: grpcConfig,\n      maxIdleMillis: this.maxIdleMillis,\n    });\n  }\n\n  getMaxIdleMillis(): number {\n    return this.maxIdleMillis;\n  }\n\n  withMaxIdleMillis(maxIdleMillis: number): TransportStrategy {\n    return new StaticTransportStrategy({\n      grpcConfiguration: this.grpcConfig,\n      maxIdleMillis: maxIdleMillis,\n    });\n  }\n\n  withClientTimeoutMillis(clientTimeout: number): StaticTransportStrategy {\n    return new StaticTransportStrategy({\n      grpcConfiguration: this.grpcConfig.withDeadlineMillis(clientTimeout),\n      maxIdleMillis: this.maxIdleMillis,\n    });\n  }\n}\n"]}