@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.
- package/lib/athena/alb-athena-log-ratchet.d.ts +1 -1
- package/lib/build/ratchet-aws-node-only-info.d.ts +1 -1
- package/lib/cli/dynamo-exporter.d.ts +1 -1
- package/lib/cli/ratchet-cli-handler.d.ts +2 -2
- package/lib/index.d.ts +11 -1
- package/lib/index.mjs +29 -0
- package/lib/index.mjs.map +1 -0
- package/lib/mail/inbound/inbound-email-ratchet.d.ts +1 -1
- package/package.json +14 -28
- package/lib/athena/alb-athena-log-ratchet.js +0 -158
- package/lib/athena/alb-athena-log-ratchet.js.map +0 -1
- package/lib/athena/alb-athena-log-ratchet.spec.js +0 -29
- package/lib/athena/alb-athena-log-ratchet.spec.js.map +0 -1
- package/lib/athena/athena-ratchet.js +0 -158
- package/lib/athena/athena-ratchet.js.map +0 -1
- package/lib/athena/athena-ratchet.spec.js +0 -28
- package/lib/athena/athena-ratchet.spec.js.map +0 -1
- package/lib/build/ratchet-aws-node-only-info.js +0 -15
- package/lib/build/ratchet-aws-node-only-info.js.map +0 -1
- package/lib/cli/dynamo-exporter.js +0 -77
- package/lib/cli/dynamo-exporter.js.map +0 -1
- package/lib/cli/ratchet-cli-handler.js +0 -16
- package/lib/cli/ratchet-cli-handler.js.map +0 -1
- package/lib/cli/site-uploader/site-uploader.js +0 -116
- package/lib/cli/site-uploader/site-uploader.js.map +0 -1
- package/lib/cli/start-instance-and-ssh.js +0 -69
- package/lib/cli/start-instance-and-ssh.js.map +0 -1
- package/lib/index.js +0 -2
- package/lib/index.js.map +0 -1
- package/lib/mail/inbound/email-to-db-insert-processor.js +0 -90
- package/lib/mail/inbound/email-to-db-insert-processor.js.map +0 -1
- package/lib/mail/inbound/inbound-email-ratchet.js +0 -42
- package/lib/mail/inbound/inbound-email-ratchet.js.map +0 -1
- package/lib/mail/inbound/inbound-email-ratchet.spec.js +0 -19
- package/lib/mail/inbound/inbound-email-ratchet.spec.js.map +0 -1
- package/lib/mail/inbound/parsed-email-processor.js +0 -2
- package/lib/mail/inbound/parsed-email-processor.js.map +0 -1
- package/lib/mail/inbound/sample-email-processor.js +0 -9
- 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":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,8CAA8C,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AAIxB,MAAM,OAAO,mBAAmB;IACtB,UAAU,CAAS;IACnB,aAAa,CAAS;IACtB,cAAc,CAAS;IACvB,MAAM,CAAS;IACf,gBAAgB,CAAS;IACzB,UAAU,CAAa;IAE/B,YACE,UAAkB,EAClB,gBAAwB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,YAAY,CAAC,EACrE,iBAAyB,UAAU,EACnC,SAAiB,WAAW,EAC5B,mBAA2B,YAAY;QAEvC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAEzC,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACvE,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,IAAc;QACzC,IAAI,IAAI,EAAE,MAAM,KAAK,CAAC,IAAI,IAAI,EAAE,MAAM,KAAK,CAAC,EAAE;YAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YAG3B,OAAO,IAAI,mBAAmB,CAAC,UAAU,CAAC,CAAC;SAC5C;aAAM;YACL,MAAM,CAAC,IAAI,CAAC,uGAAuG,EAAE,IAAI,CAAC,CAAC;YAC3H,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,IAAc;QAC/C,MAAM,IAAI,GAAwB,mBAAmB,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC3E,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC;IACpB,CAAC;IAEM,KAAK,CAAC,GAAG;QAEd,IAAI,QAAQ,GAAa,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjF,IAAI,CAAC,CAAC,QAAQ,EAAE;YACd,IAAI,QAAQ,GAAY,KAAK,CAAC;YAC9B,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,EAAE;gBAC7B,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;gBAC9C,QAAQ,GAAG,IAAI,CAAC;aACjB;iBAAM;gBACL,MAAM,CAAC,IAAI,CAAC,6CAA6C,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC5E,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;aAC7E;YAED,IAAI,QAAQ,EAAE;gBACZ,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;gBACvC,MAAM,aAAa,GAAW,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,QAAQ,EAAE,CAAC;gBAC7E,MAAM,iBAAiB,GAA6B,MAAM,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAClG,IAAI,CAAC,UAAU,EACf,aAAa,EACb,IAAI,CAAC,cAAc,CACpB,CAAC;gBACF,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,iBAAiB,CAAC,CAAC;gBAEpD,QAAQ,GAAG,QAAQ,IAAI,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACrH,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;gBACnE,MAAM,GAAG,GAA6B,SAAS,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,GAAG,GAAG,QAAQ,CAAC,eAAe,CAAC,EAAE;oBAC7G,KAAK,EAAE,SAAS;iBACjB,CAAC,CAAC;gBAEH,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;aACxB;iBAAM;gBACL,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;aACtD;SACF;aAAM;YACL,MAAM,CAAC,IAAI,CAAC,oDAAoD,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;SACpF;IAEH,CAAC;CACF"}
|
package/lib/index.js
DELETED
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":"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"}
|
|
@@ -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 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"parsed-email-processor.js","sourceRoot":"","sources":["../../../src/mail/inbound/parsed-email-processor.ts"],"names":[],"mappings":""}
|
|
@@ -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"}
|