@ido_kawaz/amqp-client 3.0.0 → 4.0.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/README.md +8 -1
- package/dist/__tests__/config.test.d.ts +2 -0
- package/dist/__tests__/config.test.d.ts.map +1 -0
- package/dist/__tests__/config.test.js +34 -0
- package/dist/__tests__/config.test.js.map +1 -0
- package/dist/amqpClient.d.ts +2 -1
- package/dist/amqpClient.d.ts.map +1 -1
- package/dist/amqpClient.js +3 -2
- package/dist/amqpClient.js.map +1 -1
- package/dist/config.d.ts +1 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +19 -0
- package/dist/config.js.map +1 -1
- package/dist/consumer.d.ts +6 -1
- package/dist/consumer.d.ts.map +1 -1
- package/dist/consumer.js.map +1 -1
- package/dist/errors.d.ts +4 -3
- package/dist/errors.d.ts.map +1 -1
- package/dist/errors.js +1 -1
- package/dist/errors.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/types.d.ts +1 -13
- package/dist/types.d.ts.map +1 -1
- package/package.json +4 -2
package/README.md
CHANGED
|
@@ -17,7 +17,8 @@ import {
|
|
|
17
17
|
AmqpClient,
|
|
18
18
|
Consumer,
|
|
19
19
|
createConsumerBinding,
|
|
20
|
-
type AmqpConfig
|
|
20
|
+
type AmqpConfig
|
|
21
|
+
createAmqpConfig,
|
|
21
22
|
AmqpRetriableError,
|
|
22
23
|
} from '@ido_kawaz/amqp-client';
|
|
23
24
|
|
|
@@ -76,6 +77,12 @@ bootstrap().catch(console.error);
|
|
|
76
77
|
|
|
77
78
|
- `amqpConnectionString`: Full RabbitMQ connection URL (for example `amqp://guest:guest@localhost:5672`)
|
|
78
79
|
|
|
80
|
+
`createAmqpConfig(env: NodeJS.ProcessEnv): AmqpConfig`
|
|
81
|
+
|
|
82
|
+
- Validates `AMQP_CONNECTION_STRING` from env using Joi
|
|
83
|
+
- Requires URI scheme `amqp` or `amqps`
|
|
84
|
+
- Throws Joi validation error for invalid or missing env value
|
|
85
|
+
|
|
79
86
|
## API
|
|
80
87
|
|
|
81
88
|
### `AmqpClient`
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/config.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const joi_1 = __importDefault(require("joi"));
|
|
7
|
+
const config_1 = require("../config");
|
|
8
|
+
describe('createAmqpConfig', () => {
|
|
9
|
+
it('returns config when AMQP_CONNECTION_STRING is valid', () => {
|
|
10
|
+
const config = (0, config_1.createAmqpConfig)({
|
|
11
|
+
AMQP_CONNECTION_STRING: 'amqp://guest:guest@localhost:5672',
|
|
12
|
+
});
|
|
13
|
+
expect(config).toEqual({
|
|
14
|
+
amqpConnectionString: 'amqp://guest:guest@localhost:5672',
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
it('accepts amqps scheme', () => {
|
|
18
|
+
const config = (0, config_1.createAmqpConfig)({
|
|
19
|
+
AMQP_CONNECTION_STRING: 'amqps://rabbitmq.example.com:5671',
|
|
20
|
+
});
|
|
21
|
+
expect(config).toEqual({
|
|
22
|
+
amqpConnectionString: 'amqps://rabbitmq.example.com:5671',
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
it('throws validation error when AMQP_CONNECTION_STRING is missing', () => {
|
|
26
|
+
expect(() => (0, config_1.createAmqpConfig)({})).toThrow(joi_1.default.ValidationError);
|
|
27
|
+
});
|
|
28
|
+
it('throws validation error when scheme is invalid', () => {
|
|
29
|
+
expect(() => (0, config_1.createAmqpConfig)({
|
|
30
|
+
AMQP_CONNECTION_STRING: 'http://localhost:5672',
|
|
31
|
+
})).toThrow(joi_1.default.ValidationError);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=config.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.test.js","sourceRoot":"","sources":["../../src/__tests__/config.test.ts"],"names":[],"mappings":";;;;;AAAA,8CAAsB;AACtB,sCAA6C;AAE7C,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC3D,MAAM,MAAM,GAAG,IAAA,yBAAgB,EAAC;YAC5B,sBAAsB,EAAE,mCAAmC;SAC9D,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACnB,oBAAoB,EAAE,mCAAmC;SAC5D,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC5B,MAAM,MAAM,GAAG,IAAA,yBAAgB,EAAC;YAC5B,sBAAsB,EAAE,mCAAmC;SAC9D,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACnB,oBAAoB,EAAE,mCAAmC;SAC5D,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE,GAAG,EAAE;QACtE,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,yBAAgB,EAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,aAAG,CAAC,eAAe,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACtD,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,yBAAgB,EAAC;YAC1B,sBAAsB,EAAE,uBAAuB;SAClD,CAAC,CAAC,CAAC,OAAO,CAAC,aAAG,CAAC,eAAe,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
package/dist/amqpClient.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Channel, ChannelModel } from 'amqplib';
|
|
2
2
|
import { AmqpConfig } from './config';
|
|
3
3
|
import { Consumer } from './consumer';
|
|
4
|
+
import { AmqpPublishArgs } from './types';
|
|
4
5
|
export declare class AmqpClient {
|
|
5
6
|
private readonly config;
|
|
6
7
|
private readonly consumers;
|
|
@@ -8,7 +9,7 @@ export declare class AmqpClient {
|
|
|
8
9
|
channel: Channel | undefined;
|
|
9
10
|
constructor(config: AmqpConfig, consumers: Consumer<any, any>[]);
|
|
10
11
|
start(): Promise<void>;
|
|
11
|
-
publish<T>(
|
|
12
|
+
publish<T>(...args: AmqpPublishArgs<T>): void;
|
|
12
13
|
stop(): Promise<void>;
|
|
13
14
|
}
|
|
14
15
|
//# sourceMappingURL=amqpClient.d.ts.map
|
package/dist/amqpClient.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"amqpClient.d.ts","sourceRoot":"","sources":["../src/amqpClient.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"amqpClient.d.ts","sourceRoot":"","sources":["../src/amqpClient.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE1C,qBAAa,UAAU;IAGP,OAAO,CAAC,QAAQ,CAAC,MAAM;IAAc,OAAO,CAAC,QAAQ,CAAC,SAAS;IAF3E,UAAU,EAAE,YAAY,GAAG,SAAS,CAAC;IACrC,OAAO,EAAE,OAAO,GAAG,SAAS,CAAC;gBACA,MAAM,EAAE,UAAU,EAAmB,SAAS,EAAE,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE;IAG3F,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAa5B,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI;IAYvC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAQ9B"}
|
package/dist/amqpClient.js
CHANGED
|
@@ -25,14 +25,15 @@ class AmqpClient {
|
|
|
25
25
|
throw new errors_1.AmqpConnectionError(error.message, { amqpConnectionString: this.config.amqpConnectionString });
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
-
publish(
|
|
28
|
+
publish(...args) {
|
|
29
29
|
if ((0, ramda_1.isNil)(this.channel)) {
|
|
30
30
|
throw new errors_1.AmqpUninitializedError();
|
|
31
31
|
}
|
|
32
|
+
const [exchange, topic, message] = args;
|
|
32
33
|
const messageData = Buffer.from(JSON.stringify(message));
|
|
33
34
|
const isPublished = this.channel.publish(exchange, topic, messageData);
|
|
34
35
|
if (!isPublished) {
|
|
35
|
-
throw new errors_1.AmqpPublisherError(
|
|
36
|
+
throw new errors_1.AmqpPublisherError(exchange, topic, message);
|
|
36
37
|
}
|
|
37
38
|
}
|
|
38
39
|
async stop() {
|
package/dist/amqpClient.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"amqpClient.js","sourceRoot":"","sources":["../src/amqpClient.ts"],"names":[],"mappings":";;;;;;AAAA,sDAAsD;AAEtD,qCAA2F;AAC3F,iCAAwC;
|
|
1
|
+
{"version":3,"file":"amqpClient.js","sourceRoot":"","sources":["../src/amqpClient.ts"],"names":[],"mappings":";;;;;;AAAA,sDAAsD;AAEtD,qCAA2F;AAC3F,iCAAwC;AAIxC,MAAa,UAAU;IAGnB,YAA6B,MAAkB,EAAmB,SAA+B;QAApE,WAAM,GAAN,MAAM,CAAY;QAAmB,cAAS,GAAT,SAAS,CAAsB;IACjG,CAAC;IAED,KAAK,CAAC,KAAK;QACP,IAAI,CAAC;YACD,MAAM,UAAU,GAAG,MAAM,iBAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;YACxE,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,OAAO,GAAG,MAAM,UAAU,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;gBACnE,MAAM,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC7E,OAAO,OAAO,CAAC;YACnB,CAAC,CAAC,CAAC;QACP,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,MAAM,IAAI,4BAAmB,CAAE,KAAe,CAAC,OAAO,EAAE,EAAE,oBAAoB,EAAE,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC,CAAC;QACxH,CAAC;IACL,CAAC;IAED,OAAO,CAAI,GAAG,IAAwB;QAClC,IAAI,IAAA,aAAK,EAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACtB,MAAM,IAAI,+BAAsB,EAAE,CAAC;QACvC,CAAC;QACD,MAAM,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;QACxC,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC;QACvE,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,MAAM,IAAI,2BAAkB,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;QAC3D,CAAC;IACL,CAAC;IAED,KAAK,CAAC,IAAI;QACN,IAAI,IAAA,gBAAQ,EAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACzB,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAC/B,CAAC;QACD,IAAI,IAAA,gBAAQ,EAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QAClC,CAAC;IACL,CAAC;CACJ;AAvCD,gCAuCC"}
|
package/dist/config.d.ts
CHANGED
package/dist/config.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,UAAU;IACvB,oBAAoB,EAAE,MAAM,CAAC;CAChC;AAUD,eAAO,MAAM,gBAAgB,GAAI,KAAK,MAAM,CAAC,UAAU,KAAG,UASzD,CAAA"}
|
package/dist/config.js
CHANGED
|
@@ -1,3 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createAmqpConfig = void 0;
|
|
7
|
+
const joi_1 = __importDefault(require("joi"));
|
|
8
|
+
const amqpEnvSchema = joi_1.default.object({
|
|
9
|
+
AMQP_CONNECTION_STRING: joi_1.default.string().uri({ scheme: ['amqp', 'amqps'] }).required(),
|
|
10
|
+
}).unknown();
|
|
11
|
+
const createAmqpConfig = (env) => {
|
|
12
|
+
const { error, value } = amqpEnvSchema.validate(env, { abortEarly: false });
|
|
13
|
+
if (error) {
|
|
14
|
+
throw error;
|
|
15
|
+
}
|
|
16
|
+
const amqpEnv = value;
|
|
17
|
+
return {
|
|
18
|
+
amqpConnectionString: amqpEnv.AMQP_CONNECTION_STRING
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
exports.createAmqpConfig = createAmqpConfig;
|
|
3
22
|
//# sourceMappingURL=config.js.map
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";;;;;;AAAA,8CAAsB;AAUtB,MAAM,aAAa,GAAG,aAAG,CAAC,MAAM,CAAU;IACtC,sBAAsB,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAAC,QAAQ,EAAE;CACrF,CAAC,CAAC,OAAO,EAAE,CAAC;AAEN,MAAM,gBAAgB,GAAG,CAAC,GAAsB,EAAc,EAAE;IACnE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,aAAa,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;IAC5E,IAAI,KAAK,EAAE,CAAC;QACR,MAAM,KAAK,CAAC;IAChB,CAAC;IACD,MAAM,OAAO,GAAG,KAAgB,CAAC;IACjC,OAAO;QACH,oBAAoB,EAAE,OAAO,CAAC,sBAAsB;KACvD,CAAC;AACN,CAAC,CAAA;AATY,QAAA,gBAAgB,oBAS5B"}
|
package/dist/consumer.d.ts
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import { Channel } from 'amqplib';
|
|
2
|
-
|
|
2
|
+
interface ConsumerBinding {
|
|
3
|
+
queue: string;
|
|
4
|
+
exchange: string;
|
|
5
|
+
topic: string;
|
|
6
|
+
}
|
|
3
7
|
export declare class Consumer<Payload extends object, Binding extends ConsumerBinding> {
|
|
4
8
|
private readonly binding;
|
|
5
9
|
private readonly validatePayload;
|
|
@@ -13,4 +17,5 @@ export declare class Consumer<Payload extends object, Binding extends ConsumerBi
|
|
|
13
17
|
private assertExchange;
|
|
14
18
|
private bindQueue;
|
|
15
19
|
}
|
|
20
|
+
export {};
|
|
16
21
|
//# sourceMappingURL=consumer.d.ts.map
|
package/dist/consumer.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consumer.d.ts","sourceRoot":"","sources":["../src/consumer.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"consumer.d.ts","sourceRoot":"","sources":["../src/consumer.ts"],"names":[],"mappings":"AAAA,OAAa,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGxC,UAAU,eAAe;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,QAAQ,CAAC,OAAO,SAAS,MAAM,EAAE,OAAO,SAAS,eAAe;IAErE,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAFb,OAAO,EAAE,OAAO,EAChB,eAAe,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,IAAI,OAAO,EACxD,aAAa,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC;IAGjE,KAAK,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAwB5C,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,gBAAgB;YAYV,wBAAwB;YAMxB,WAAW;YAIX,cAAc;YAId,SAAS;CAG1B"}
|
package/dist/consumer.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consumer.js","sourceRoot":"","sources":["../src/consumer.ts"],"names":[],"mappings":";;;AACA,qCAA8C;
|
|
1
|
+
{"version":3,"file":"consumer.js","sourceRoot":"","sources":["../src/consumer.ts"],"names":[],"mappings":"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"}
|
package/dist/errors.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { AmqpConfig } from "./config";
|
|
2
|
+
import { AmqpPublishArgs } from "./types";
|
|
2
3
|
export declare class AmqpError extends Error {
|
|
3
4
|
constructor(message: string, args?: Object);
|
|
4
5
|
}
|
|
@@ -6,10 +7,10 @@ export declare class AmqpUninitializedError extends AmqpError {
|
|
|
6
7
|
constructor();
|
|
7
8
|
}
|
|
8
9
|
export declare class AmqpConnectionError extends AmqpError {
|
|
9
|
-
constructor(errorMessage: string, args:
|
|
10
|
+
constructor(errorMessage: string, args: AmqpConfig);
|
|
10
11
|
}
|
|
11
12
|
export declare class AmqpPublisherError<T> extends AmqpError {
|
|
12
|
-
constructor(args: AmqpPublishArgs<T>);
|
|
13
|
+
constructor(...args: AmqpPublishArgs<T>);
|
|
13
14
|
}
|
|
14
15
|
export declare class AmqpConsumerError extends AmqpError {
|
|
15
16
|
constructor(error: Error);
|
package/dist/errors.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE1C,qBAAa,SAAU,SAAQ,KAAK;gBACpB,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM;CAG7C;AAED,qBAAa,sBAAuB,SAAQ,SAAS;;CAIpD;AAED,qBAAa,mBAAoB,SAAQ,SAAS;gBAClC,YAAY,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU;CAGrD;AAGD,qBAAa,kBAAkB,CAAC,CAAC,CAAE,SAAQ,SAAS;gBACpC,GAAG,IAAI,EAAE,eAAe,CAAC,CAAC,CAAC;CAG1C;AAED,qBAAa,iBAAkB,SAAQ,SAAS;gBAChC,KAAK,EAAE,KAAK;CAG3B;AAED,qBAAa,kBAAmB,SAAQ,iBAAiB;aACX,UAAU,EAAE,MAAM;gBAAhD,KAAK,EAAE,KAAK,EAAkB,UAAU,GAAE,MAAU;CAGnE;AAED,qBAAa,cAAe,SAAQ,iBAAiB;gBACrC,KAAK,EAAE,KAAK;CAG3B"}
|
package/dist/errors.js
CHANGED
package/dist/errors.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":";;;AAGA,MAAa,SAAU,SAAQ,KAAK;IAChC,YAAY,OAAe,EAAE,IAAa;QACtC,KAAK,CAAC,eAAe,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzE,CAAC;CACJ;AAJD,8BAIC;AAED,MAAa,sBAAuB,SAAQ,SAAS;IACjD;QACI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IAC5C,CAAC;CACJ;AAJD,wDAIC;AAED,MAAa,mBAAoB,SAAQ,SAAS;IAC9C,YAAY,YAAoB,EAAE,IAAgB;QAC9C,KAAK,CAAC,qCAAqC,YAAY,EAAE,EAAE,IAAI,CAAC,CAAC;IACrE,CAAC;CACJ;AAJD,kDAIC;AAGD,MAAa,kBAAsB,SAAQ,SAAS;IAChD,YAAY,GAAG,IAAwB;QACnC,KAAK,CAAC,2BAA2B,EAAE,IAAI,CAAC,CAAC;IAC7C,CAAC;CACJ;AAJD,gDAIC;AAED,MAAa,iBAAkB,SAAQ,SAAS;IAC5C,YAAY,KAAY;QACpB,KAAK,CAAC,2BAA2B,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAClD,CAAC;CACJ;AAJD,8CAIC;AAED,MAAa,kBAAmB,SAAQ,iBAAiB;IACrD,YAAY,KAAY,EAAkB,aAAqB,CAAC;QAC5D,KAAK,CAAC,KAAK,CAAC,CAAC;QADyB,eAAU,GAAV,UAAU,CAAY;IAEhE,CAAC;CACJ;AAJD,gDAIC;AAED,MAAa,cAAe,SAAQ,iBAAiB;IACjD,YAAY,KAAY;QACpB,KAAK,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;CACJ;AAJD,wCAIC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { AmqpClient } from './amqpClient';
|
|
2
|
-
export { AmqpConfig } from './config';
|
|
2
|
+
export { AmqpConfig, createAmqpConfig } from './config';
|
|
3
3
|
export { Consumer } from './consumer';
|
|
4
4
|
export { createConsumerBinding } from './binding';
|
|
5
5
|
export { AmqpError, AmqpConnectionError, AmqpPublisherError, AmqpConsumerError, AmqpRetriableError, AmqpFatalError, } from './errors';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAClD,OAAO,EACH,SAAS,EACT,mBAAmB,EACnB,kBAAkB,EAClB,iBAAiB,EACjB,kBAAkB,EAClB,cAAc,GACjB,MAAM,UAAU,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AmqpFatalError = exports.AmqpRetriableError = exports.AmqpConsumerError = exports.AmqpPublisherError = exports.AmqpConnectionError = exports.AmqpError = exports.createConsumerBinding = exports.Consumer = exports.AmqpClient = void 0;
|
|
3
|
+
exports.AmqpFatalError = exports.AmqpRetriableError = exports.AmqpConsumerError = exports.AmqpPublisherError = exports.AmqpConnectionError = exports.AmqpError = exports.createConsumerBinding = exports.Consumer = exports.createAmqpConfig = exports.AmqpClient = void 0;
|
|
4
4
|
var amqpClient_1 = require("./amqpClient");
|
|
5
5
|
Object.defineProperty(exports, "AmqpClient", { enumerable: true, get: function () { return amqpClient_1.AmqpClient; } });
|
|
6
|
+
var config_1 = require("./config");
|
|
7
|
+
Object.defineProperty(exports, "createAmqpConfig", { enumerable: true, get: function () { return config_1.createAmqpConfig; } });
|
|
6
8
|
var consumer_1 = require("./consumer");
|
|
7
9
|
Object.defineProperty(exports, "Consumer", { enumerable: true, get: function () { return consumer_1.Consumer; } });
|
|
8
10
|
var binding_1 = require("./binding");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;AACnB,mCAAwD;AAAnC,0GAAA,gBAAgB,OAAA;AACrC,uCAAsC;AAA7B,oGAAA,QAAQ,OAAA;AACjB,qCAAkD;AAAzC,gHAAA,qBAAqB,OAAA;AAC9B,mCAOkB;AANd,mGAAA,SAAS,OAAA;AACT,6GAAA,mBAAmB,OAAA;AACnB,4GAAA,kBAAkB,OAAA;AAClB,2GAAA,iBAAiB,OAAA;AACjB,4GAAA,kBAAkB,OAAA;AAClB,wGAAA,cAAc,OAAA"}
|
package/dist/types.d.ts
CHANGED
|
@@ -1,14 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
amqpConnectionString: string;
|
|
3
|
-
}
|
|
4
|
-
export interface AmqpPublishArgs<T> {
|
|
5
|
-
exchange: string;
|
|
6
|
-
topic: string;
|
|
7
|
-
message: T;
|
|
8
|
-
}
|
|
9
|
-
export interface ConsumerBinding {
|
|
10
|
-
queue: string;
|
|
11
|
-
exchange: string;
|
|
12
|
-
topic: string;
|
|
13
|
-
}
|
|
1
|
+
export type AmqpPublishArgs<T> = [exchange: string, topic: string, message: T];
|
|
14
2
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ido_kawaz/amqp-client",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "4.0.0",
|
|
4
4
|
"description": "AMQP client library for Kawaz Plus services",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -24,8 +24,10 @@
|
|
|
24
24
|
"author": "",
|
|
25
25
|
"license": "MIT",
|
|
26
26
|
"dependencies": {
|
|
27
|
-
"amqplib": "^0.10.9",
|
|
28
27
|
"@types/amqplib": "^0.10.8",
|
|
28
|
+
"@types/joi": "^17.2.2",
|
|
29
|
+
"amqplib": "^0.10.9",
|
|
30
|
+
"joi": "^18.0.2",
|
|
29
31
|
"ramda": "^0.32.0"
|
|
30
32
|
},
|
|
31
33
|
"devDependencies": {
|