@bitblit/ratchet-aws-node-only 4.0.116-alpha → 4.0.119-alpha

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.
Files changed (39) hide show
  1. package/lib/athena/alb-athena-log-ratchet.d.ts +1 -1
  2. package/lib/build/ratchet-aws-node-only-info.d.ts +1 -1
  3. package/lib/cli/dynamo-exporter.d.ts +1 -1
  4. package/lib/cli/ratchet-cli-handler.d.ts +2 -2
  5. package/lib/index.d.ts +11 -1
  6. package/lib/index.mjs +29 -0
  7. package/lib/index.mjs.map +1 -0
  8. package/lib/mail/inbound/inbound-email-ratchet.d.ts +1 -1
  9. package/package.json +14 -28
  10. package/lib/athena/alb-athena-log-ratchet.js +0 -158
  11. package/lib/athena/alb-athena-log-ratchet.js.map +0 -1
  12. package/lib/athena/alb-athena-log-ratchet.spec.js +0 -29
  13. package/lib/athena/alb-athena-log-ratchet.spec.js.map +0 -1
  14. package/lib/athena/athena-ratchet.js +0 -158
  15. package/lib/athena/athena-ratchet.js.map +0 -1
  16. package/lib/athena/athena-ratchet.spec.js +0 -28
  17. package/lib/athena/athena-ratchet.spec.js.map +0 -1
  18. package/lib/build/ratchet-aws-node-only-info.js +0 -15
  19. package/lib/build/ratchet-aws-node-only-info.js.map +0 -1
  20. package/lib/cli/dynamo-exporter.js +0 -77
  21. package/lib/cli/dynamo-exporter.js.map +0 -1
  22. package/lib/cli/ratchet-cli-handler.js +0 -16
  23. package/lib/cli/ratchet-cli-handler.js.map +0 -1
  24. package/lib/cli/site-uploader/site-uploader.js +0 -116
  25. package/lib/cli/site-uploader/site-uploader.js.map +0 -1
  26. package/lib/cli/start-instance-and-ssh.js +0 -69
  27. package/lib/cli/start-instance-and-ssh.js.map +0 -1
  28. package/lib/index.js +0 -2
  29. package/lib/index.js.map +0 -1
  30. package/lib/mail/inbound/email-to-db-insert-processor.js +0 -90
  31. package/lib/mail/inbound/email-to-db-insert-processor.js.map +0 -1
  32. package/lib/mail/inbound/inbound-email-ratchet.js +0 -42
  33. package/lib/mail/inbound/inbound-email-ratchet.js.map +0 -1
  34. package/lib/mail/inbound/inbound-email-ratchet.spec.js +0 -19
  35. package/lib/mail/inbound/inbound-email-ratchet.spec.js.map +0 -1
  36. package/lib/mail/inbound/parsed-email-processor.js +0 -2
  37. package/lib/mail/inbound/parsed-email-processor.js.map +0 -1
  38. package/lib/mail/inbound/sample-email-processor.js +0 -9
  39. package/lib/mail/inbound/sample-email-processor.js.map +0 -1
@@ -1,116 +0,0 @@
1
- import fs from 'fs';
2
- import walk from 'walk';
3
- import { S3Client } from '@aws-sdk/client-s3';
4
- import path from 'path';
5
- import mime from 'mime-types';
6
- import { Logger } from '@bitblit/ratchet-common/lib/logger/logger.js';
7
- import { Upload } from '@aws-sdk/lib-storage';
8
- export class SiteUploader {
9
- srcDir;
10
- bucketName;
11
- config;
12
- s3 = new S3Client({ region: 'us-east-1' });
13
- constructor(srcDir, bucketName, configFile) {
14
- this.srcDir = srcDir;
15
- this.bucketName = bucketName;
16
- this.config = JSON.parse(fs.readFileSync(configFile).toString('ascii'));
17
- }
18
- static createFromArgs(args) {
19
- if (args && args.length === 3) {
20
- const src = args[0];
21
- const bucket = args[1];
22
- const configFile = args[2];
23
- return new SiteUploader(src, bucket, configFile);
24
- }
25
- else {
26
- console.log('Usage : node ratchet-site-uploader {srcDir} {bucket} {configFile} (Found ' + args + ' arguments, need 3)');
27
- return null;
28
- }
29
- }
30
- static async runFromCliArgs(args) {
31
- const inst = SiteUploader.createFromArgs(args);
32
- return inst.runPump();
33
- }
34
- findMatch(prefix, fileName, config) {
35
- let found = null;
36
- if (prefix != null && fileName != null && config != null && config.mapping != null) {
37
- config.mapping.forEach((entry) => {
38
- if (found == null) {
39
- if (entry.prefixMatch == null || prefix.match(entry.prefixMatch)) {
40
- if (entry.fileMatch == null || fileName.match(entry.fileMatch)) {
41
- found = entry;
42
- }
43
- }
44
- }
45
- });
46
- }
47
- return found;
48
- }
49
- findMime(fileName, config) {
50
- let found = null;
51
- if (config != null && config.customMimeTypeMapping != null) {
52
- Object.keys(config.customMimeTypeMapping).forEach((k) => {
53
- if (found == null && fileName.endsWith(k)) {
54
- found = config.customMimeTypeMapping[k];
55
- }
56
- });
57
- }
58
- if (found == null) {
59
- found = mime.lookup(fileName);
60
- }
61
- if (found == null) {
62
- found = 'binary/octet-stream';
63
- }
64
- return found;
65
- }
66
- runPump() {
67
- return new Promise((resolve, reject) => {
68
- Logger.info('Uploading contents of %s to %s using %j as config', this.srcDir, this.bucketName, this.config);
69
- const options = {};
70
- const walker = walk.walk(this.srcDir, options);
71
- walker.on('file', function (root, fileStats, next) {
72
- Logger.info('Processing %j', fileStats.name);
73
- const prefix = root == this.srcDir ? '' : root.substring(this.srcDir.length + 1) + '/';
74
- const proc = this.findMatch(prefix, fileStats.name, this.config);
75
- const key = prefix + fileStats.name;
76
- Logger.info('Uploading file : %s/%s to key %s with %j', root, fileStats.name, key, proc);
77
- const params = proc && proc.putParams ? JSON.parse(JSON.stringify(proc.putParams)) : {};
78
- params.Bucket = this.bucketName;
79
- params.Key = key;
80
- params.Body = fs.readFileSync(path.join(root, fileStats.name));
81
- if (!params.ContentType) {
82
- params.ContentType = this.findMime(fileStats.name, this.config);
83
- }
84
- const upload = new Upload({
85
- client: this.s3,
86
- params: params,
87
- tags: [],
88
- queueSize: 4,
89
- partSize: 1024 * 1024 * 5,
90
- leavePartsOnError: false,
91
- });
92
- upload.on('httpUploadProgress', (progress) => {
93
- Logger.info('Uploading : %s', progress);
94
- });
95
- upload
96
- .done()
97
- .then((result) => {
98
- Logger.info('Finished upload of %s: %j', key, result);
99
- next();
100
- })
101
- .catch((err) => {
102
- Logger.warn('%s failed to upload : %s : Continuing', key, err);
103
- next();
104
- });
105
- }.bind(this));
106
- walker.on('errors', function (root, nodeStatsArray, next) {
107
- next();
108
- });
109
- walker.on('end', function () {
110
- Logger.info('All done');
111
- resolve(true);
112
- });
113
- });
114
- }
115
- }
116
- //# sourceMappingURL=site-uploader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"site-uploader.js","sourceRoot":"","sources":["../../../src/cli/site-uploader/site-uploader.ts"],"names":[],"mappings":"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"}
@@ -1,69 +0,0 @@
1
- import { Logger } from '@bitblit/ratchet-common/lib/logger/logger.js';
2
- import { Ec2Ratchet } from '@bitblit/ratchet-aws';
3
- import { spawnSync } from 'child_process';
4
- import fs from 'fs';
5
- import os from 'os';
6
- import path from 'path';
7
- export class StartInstanceAndSsh {
8
- instanceId;
9
- publicKeyFile;
10
- instanceOsUser;
11
- region;
12
- availabilityZone;
13
- ec2Ratchet;
14
- constructor(instanceId, publicKeyFile = path.join(os.homedir(), '.ssh', 'id_rsa.pub'), instanceOsUser = 'ec2-user', region = 'us-east-1', availabilityZone = 'us-east-1a') {
15
- this.instanceId = instanceId;
16
- this.publicKeyFile = publicKeyFile;
17
- this.instanceOsUser = instanceOsUser;
18
- this.region = region;
19
- this.availabilityZone = availabilityZone;
20
- this.ec2Ratchet = new Ec2Ratchet(this.region, this.availabilityZone);
21
- }
22
- static createFromArgs(args) {
23
- if (args?.length === 1 || args?.length === 2) {
24
- const instanceId = args[0];
25
- return new StartInstanceAndSsh(instanceId);
26
- }
27
- else {
28
- Logger.info('Usage : ratchet-start-instance-and-ssh {instanceId} {publicKeyFile} (Found %s arguments, need 1 or 2)', args);
29
- return null;
30
- }
31
- }
32
- static async runFromCliArgs(args) {
33
- const inst = StartInstanceAndSsh.createFromArgs(args);
34
- return inst.run();
35
- }
36
- async run() {
37
- let instance = await this.ec2Ratchet.describeInstance(this.instanceId);
38
- if (!!instance) {
39
- let launched = false;
40
- if (instance.State.Code == 16) {
41
- Logger.info('Instance is already running...');
42
- launched = true;
43
- }
44
- else {
45
- Logger.info('Instance is not running... starting up : %s', this.instanceId);
46
- launched = await this.ec2Ratchet.launchInstance(this.instanceId, 1000 * 30);
47
- }
48
- if (launched) {
49
- Logger.info('Uploading public key...');
50
- const publicKeyText = fs.readFileSync(this.publicKeyFile).toString();
51
- const publicKeyResponse = await this.ec2Ratchet.sendPublicKeyToEc2Instance(this.instanceId, publicKeyText, this.instanceOsUser);
52
- Logger.info('Key response : %j', publicKeyResponse);
53
- instance = instance && instance.PublicIpAddress ? instance : await this.ec2Ratchet.describeInstance(this.instanceId);
54
- Logger.info('Instance IP address is %s', instance.PublicIpAddress);
55
- const ret = spawnSync('ssh', [this.instanceOsUser + '@' + instance.PublicIpAddress], {
56
- stdio: 'inherit',
57
- });
58
- Logger.info('%j', ret);
59
- }
60
- else {
61
- Logger.info('Instance could not start - check logs');
62
- }
63
- }
64
- else {
65
- Logger.info('No such instance found - check your AWS keys? : %s', this.instanceId);
66
- }
67
- }
68
- }
69
- //# sourceMappingURL=start-instance-and-ssh.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"start-instance-and-ssh.js","sourceRoot":"","sources":["../../src/cli/start-instance-and-ssh.ts"],"names":[],"mappings":"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"}
package/lib/index.js DELETED
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=index.js.map
package/lib/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
@@ -1,90 +0,0 @@
1
- import { RequireRatchet } from '@bitblit/ratchet-common/lib/lang/require-ratchet.js';
2
- import { Logger } from '@bitblit/ratchet-common/lib/logger/logger.js';
3
- import { MultiStream } from '@bitblit/ratchet-common/lib/stream/multi-stream.js';
4
- import unzipper from 'unzipper';
5
- import { CsvRatchet } from '@bitblit/ratchet-node-only/lib/csv/csv-ratchet.js';
6
- import { DateTime } from 'luxon';
7
- export class EmailToDbInsertProcessor {
8
- canProcess(mail) {
9
- return true;
10
- }
11
- async processEmail(msg) {
12
- const rval = [];
13
- try {
14
- RequireRatchet.notNullOrUndefined(msg, 'msg');
15
- Logger.info('Processing Broadsign reach inbound inventory email');
16
- const data = msg.attachments[0].content;
17
- Logger.info('Unzipping attachment');
18
- const rs = new MultiStream(data);
19
- let wBuf = null;
20
- const prom = rs
21
- .pipe(unzipper.Parse())
22
- .on('entry', async (entry) => {
23
- if (entry.path.toLowerCase().endsWith('csv')) {
24
- wBuf = await entry.buffer();
25
- }
26
- else {
27
- Logger.info('Pass: %s', entry.path);
28
- entry.autodrain();
29
- }
30
- })
31
- .promise();
32
- await prom;
33
- const csvParsed = await CsvRatchet.stringParse(wBuf.toString(), (o) => o, {
34
- columns: false,
35
- skip_empty_lines: true,
36
- });
37
- if (csvParsed.length > 1) {
38
- const dropTable = 'drop table if exists sample';
39
- let createTable = 'create table sample (pump_date varchar(255),';
40
- const colNames = csvParsed[0];
41
- let insertPrefix = 'insert into sample (pump_date,';
42
- let insertQ = '?,';
43
- for (let i = 0; i < colNames.length; i++) {
44
- if (i > 0) {
45
- createTable += ', ';
46
- insertPrefix += ', ';
47
- insertQ += ', ';
48
- }
49
- const kOut = colNames[i].toLowerCase().split(' ').join('_');
50
- insertPrefix += kOut;
51
- insertQ += '?';
52
- createTable += kOut + ' varchar(255)';
53
- if (kOut === 'id') {
54
- createTable += ' primary key';
55
- }
56
- else if (kOut === 'device_id') {
57
- createTable += ' unique';
58
- }
59
- }
60
- createTable += ')';
61
- insertPrefix += ') values ';
62
- Logger.info('Recreating table');
63
- const dropRes = rval.push({ statement: dropTable });
64
- const createRes = rval.push({ statement: createTable });
65
- const pumpDate = DateTime.utc().toISO();
66
- let insertStmt = insertPrefix;
67
- let insertParams = [];
68
- for (let i = 1; i < csvParsed.length; i++) {
69
- if (insertStmt > insertPrefix) {
70
- insertStmt += ',';
71
- }
72
- insertStmt += '(' + insertQ + ')';
73
- insertParams = insertParams.concat(pumpDate, csvParsed[i]);
74
- if (i % 25 === 0 || i === csvParsed.length - 1) {
75
- rval.push({ statement: insertStmt, params: insertParams });
76
- insertStmt = insertPrefix;
77
- insertParams = [];
78
- Logger.info('Inserted %d of %d rows', i, csvParsed.length);
79
- }
80
- }
81
- Logger.info('Finished insertion of %d rows', csvParsed.length);
82
- }
83
- }
84
- catch (err) {
85
- Logger.error('Failure: %s : %j', err, rval, err);
86
- }
87
- return rval;
88
- }
89
- }
90
- //# sourceMappingURL=email-to-db-insert-processor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"email-to-db-insert-processor.js","sourceRoot":"","sources":["../../../src/mail/inbound/email-to-db-insert-processor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,qDAAqD,CAAC;AACrF,OAAO,EAAE,MAAM,EAAE,MAAM,8CAA8C,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,oDAAoD,CAAC;AACjF,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,EAAE,UAAU,EAAE,MAAM,mDAAmD,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,MAAM,OAAO,wBAAwB;IAC5B,UAAU,CAAC,IAAgB;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,YAAY,CAAC,GAAe;QACvC,MAAM,IAAI,GAAyB,EAAE,CAAC;QACtC,IAAI;YACF,cAAc,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAC9C,MAAM,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;YAClE,MAAM,IAAI,GAAW,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;YAEhD,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;YACpC,MAAM,EAAE,GAAgB,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;YAC9C,IAAI,IAAI,GAAW,IAAI,CAAC;YACxB,MAAM,IAAI,GAAiB,EAAE;iBAC1B,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;iBACtB,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;gBAC3B,IAAI,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;oBAC5C,IAAI,GAAG,MAAM,KAAK,CAAC,MAAM,EAAE,CAAC;iBAC7B;qBAAM;oBACL,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;oBACpC,KAAK,CAAC,SAAS,EAAE,CAAC;iBACnB;YACH,CAAC,CAAC;iBACD,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,CAAC;YACX,MAAM,SAAS,GAAU,MAAM,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE;gBAC/E,OAAO,EAAE,KAAK;gBACd,gBAAgB,EAAE,IAAI;aACvB,CAAC,CAAC;YAEH,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;gBACxB,MAAM,SAAS,GAAW,6BAA6B,CAAC;gBACxD,IAAI,WAAW,GAAW,8CAA8C,CAAC;gBACzE,MAAM,QAAQ,GAAa,SAAS,CAAC,CAAC,CAAC,CAAC;gBAExC,IAAI,YAAY,GAAW,gCAAgC,CAAC;gBAC5D,IAAI,OAAO,GAAW,IAAI,CAAC;gBAE3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACxC,IAAI,CAAC,GAAG,CAAC,EAAE;wBACT,WAAW,IAAI,IAAI,CAAC;wBACpB,YAAY,IAAI,IAAI,CAAC;wBACrB,OAAO,IAAI,IAAI,CAAC;qBACjB;oBACD,MAAM,IAAI,GAAW,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACpE,YAAY,IAAI,IAAI,CAAC;oBACrB,OAAO,IAAI,GAAG,CAAC;oBACf,WAAW,IAAI,IAAI,GAAG,eAAe,CAAC;oBACtC,IAAI,IAAI,KAAK,IAAI,EAAE;wBACjB,WAAW,IAAI,cAAc,CAAC;qBAC/B;yBAAM,IAAI,IAAI,KAAK,WAAW,EAAE;wBAC/B,WAAW,IAAI,SAAS,CAAC;qBAC1B;iBACF;gBACD,WAAW,IAAI,GAAG,CAAC;gBACnB,YAAY,IAAI,WAAW,CAAC;gBAG5B,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBAChC,MAAM,OAAO,GAAQ,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;gBACzD,MAAM,SAAS,GAAQ,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC,CAAC;gBAC7D,MAAM,QAAQ,GAAW,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC;gBAChD,IAAI,UAAU,GAAW,YAAY,CAAC;gBACtC,IAAI,YAAY,GAAU,EAAE,CAAC;gBAE7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACzC,IAAI,UAAU,GAAG,YAAY,EAAE;wBAC7B,UAAU,IAAI,GAAG,CAAC;qBACnB;oBACD,UAAU,IAAI,GAAG,GAAG,OAAO,GAAG,GAAG,CAAC;oBAClC,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;oBAE3D,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;wBAC9C,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;wBAC3D,UAAU,GAAG,YAAY,CAAC;wBAC1B,YAAY,GAAG,EAAE,CAAC;wBAClB,MAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;qBAC5D;iBACF;gBAED,MAAM,CAAC,IAAI,CAAC,+BAA+B,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;aAChE;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;SAClD;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -1,42 +0,0 @@
1
- import { simpleParser } from 'mailparser';
2
- import { Logger } from '@bitblit/ratchet-common/lib/logger/logger.js';
3
- import { RequireRatchet } from '@bitblit/ratchet-common/lib/lang/require-ratchet.js';
4
- export class InboundEmailRatchet {
5
- cache;
6
- processors;
7
- constructor(cache, processors) {
8
- this.cache = cache;
9
- this.processors = processors;
10
- RequireRatchet.notNullOrUndefined(this.cache, 'cache');
11
- RequireRatchet.notNullOrUndefined(this.cache.getDefaultBucket(), 'cache.defaultBucket');
12
- }
13
- async processEmailFromS3(key) {
14
- const rval = false;
15
- if (await this.cache.fileExists(key)) {
16
- const data = await this.cache.fetchCacheFileAsString(key);
17
- return this.processEmailFromBuffer(new Buffer(data));
18
- }
19
- else {
20
- Logger.warn('Cannot process inbound email - no such key : %s', key);
21
- }
22
- return rval;
23
- }
24
- async processEmailFromBuffer(buf) {
25
- const rval = false;
26
- RequireRatchet.notNullOrUndefined(buf, 'buf');
27
- Logger.info('Processing inbound email - size %d bytes', buf.length);
28
- const message = await simpleParser(buf);
29
- Logger.info('Found mail from "%s" subject "%s" with %d attachments', message?.from?.text, message?.subject, message?.attachments?.length);
30
- let procd = false;
31
- for (let i = 0; i < this.processors.length && !procd; i++) {
32
- if (this.processors[i].canProcess(message)) {
33
- Logger.info('Processing message with processor %d', i);
34
- const result = await this.processors[i].processEmail(message);
35
- Logger.info('Result was : %j', result);
36
- procd = true;
37
- }
38
- }
39
- return procd;
40
- }
41
- }
42
- //# sourceMappingURL=inbound-email-ratchet.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"inbound-email-ratchet.js","sourceRoot":"","sources":["../../../src/mail/inbound/inbound-email-ratchet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,YAAY,EAAE,MAAM,YAAY,CAAC;AAEtD,OAAO,EAAE,MAAM,EAAE,MAAM,8CAA8C,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,qDAAqD,CAAC;AAMrF,MAAM,OAAO,mBAAmB;IACV;IAA+B;IAAnD,YAAoB,KAAqB,EAAU,UAAuC;QAAtE,UAAK,GAAL,KAAK,CAAgB;QAAU,eAAU,GAAV,UAAU,CAA6B;QACxF,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACvD,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,EAAE,qBAAqB,CAAC,CAAC;IAC1F,CAAC;IAEM,KAAK,CAAC,kBAAkB,CAAC,GAAW;QACzC,MAAM,IAAI,GAAY,KAAK,CAAC;QAC5B,IAAI,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;YACpC,MAAM,IAAI,GAAW,MAAM,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC;YAClE,OAAO,IAAI,CAAC,sBAAsB,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;SACtD;aAAM;YACL,MAAM,CAAC,IAAI,CAAC,iDAAiD,EAAE,GAAG,CAAC,CAAC;SACrE;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,sBAAsB,CAAC,GAAW;QAC7C,MAAM,IAAI,GAAY,KAAK,CAAC;QAC5B,cAAc,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,0CAA0C,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;QAEpE,MAAM,OAAO,GAAe,MAAM,YAAY,CAAC,GAAG,CAAC,CAAC;QACpD,MAAM,CAAC,IAAI,CACT,uDAAuD,EACvD,OAAO,EAAE,IAAI,EAAE,IAAI,EACnB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,WAAW,EAAE,MAAM,CAC7B,CAAC;QAEF,IAAI,KAAK,GAAY,KAAK,CAAC;QAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACzD,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;gBAC1C,MAAM,CAAC,IAAI,CAAC,sCAAsC,EAAE,CAAC,CAAC,CAAC;gBACvD,MAAM,MAAM,GAAQ,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;gBACnE,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC;gBACvC,KAAK,GAAG,IAAI,CAAC;aACd;SACF;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF"}
@@ -1,19 +0,0 @@
1
- import { InboundEmailRatchet } from './inbound-email-ratchet.js';
2
- import { JestRatchet } from '@bitblit/ratchet-jest/lib/jest/jest-ratchet.js';
3
- import { jest } from '@jest/globals';
4
- import { SampleEmailProcessor } from './sample-email-processor.js';
5
- let mockS3CR;
6
- describe('#inboundEmailService', () => {
7
- beforeEach(() => {
8
- mockS3CR = JestRatchet.mock(jest.fn);
9
- });
10
- it('should process an email from S3', async () => {
11
- mockS3CR.getDefaultBucket.mockReturnValueOnce('TEST-BUCKET');
12
- mockS3CR.fileExists.mockResolvedValueOnce(true);
13
- mockS3CR.fetchCacheFileAsString.mockResolvedValue('TEST');
14
- const svc = new InboundEmailRatchet(mockS3CR, [new SampleEmailProcessor()]);
15
- const res = await svc.processEmailFromS3('some-key');
16
- expect(res).not.toBeUndefined();
17
- });
18
- });
19
- //# sourceMappingURL=inbound-email-ratchet.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"inbound-email-ratchet.spec.js","sourceRoot":"","sources":["../../../src/mail/inbound/inbound-email-ratchet.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,EAAE,WAAW,EAAE,MAAM,gDAAgD,CAAC;AAC7E,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,IAAI,QAAqC,CAAC;AAE1C,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,UAAU,CAAC,GAAG,EAAE;QACd,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,QAAQ,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC;QAC7D,QAAQ,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAChD,QAAQ,CAAC,sBAAsB,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE1D,MAAM,GAAG,GAAwB,IAAI,mBAAmB,CAAC,QAAQ,EAAE,CAAC,IAAI,oBAAoB,EAAE,CAAC,CAAC,CAAC;QAIjG,MAAM,GAAG,GAAY,MAAM,GAAG,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;QAE9D,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAClC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=parsed-email-processor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"parsed-email-processor.js","sourceRoot":"","sources":["../../../src/mail/inbound/parsed-email-processor.ts"],"names":[],"mappings":""}
@@ -1,9 +0,0 @@
1
- export class SampleEmailProcessor {
2
- canProcess(mail) {
3
- return true;
4
- }
5
- async processEmail(msg) {
6
- return msg.body;
7
- }
8
- }
9
- //# sourceMappingURL=sample-email-processor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sample-email-processor.js","sourceRoot":"","sources":["../../../src/mail/inbound/sample-email-processor.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,oBAAoB;IACxB,UAAU,CAAC,IAAgB;QAChC,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,KAAK,CAAC,YAAY,CAAC,GAAe;QACvC,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;CACF"}