@social-mail/social-mail-web-server 1.8.433 → 1.8.439
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/server/model/SocialMailContext.d.ts +4 -0
- package/dist/server/model/SocialMailContext.d.ts.map +1 -1
- package/dist/server/model/SocialMailContext.js +4 -0
- package/dist/server/model/SocialMailContext.js.map +1 -1
- package/dist/server/model/SocialMailContextEvents.d.ts.map +1 -1
- package/dist/server/model/SocialMailContextEvents.js +6 -0
- package/dist/server/model/SocialMailContextEvents.js.map +1 -1
- package/dist/server/model/entities/Domain.d.ts.map +1 -1
- package/dist/server/model/entities/Domain.js +3 -2
- package/dist/server/model/entities/Domain.js.map +1 -1
- package/dist/server/model/entities/Email.d.ts +3 -0
- package/dist/server/model/entities/Email.d.ts.map +1 -1
- package/dist/server/model/entities/Email.js +9 -0
- package/dist/server/model/entities/Email.js.map +1 -1
- package/dist/server/model/entities/EmailAddress.d.ts +1 -0
- package/dist/server/model/entities/EmailAddress.d.ts.map +1 -1
- package/dist/server/model/entities/EmailAddress.js +12 -2
- package/dist/server/model/entities/EmailAddress.js.map +1 -1
- package/dist/server/model/entities/NameToken.d.ts +1 -1
- package/dist/server/model/entities/NameToken.d.ts.map +1 -1
- package/dist/server/model/entities/NameToken.js +5 -4
- package/dist/server/model/entities/NameToken.js.map +1 -1
- package/dist/server/model/entities/SearchToken.d.ts +8 -0
- package/dist/server/model/entities/SearchToken.d.ts.map +1 -0
- package/dist/server/model/entities/SearchToken.js +37 -0
- package/dist/server/model/entities/SearchToken.js.map +1 -0
- package/dist/server/model/entities/SearchTokenEmail.d.ts +12 -0
- package/dist/server/model/entities/SearchTokenEmail.d.ts.map +1 -0
- package/dist/server/model/entities/SearchTokenEmail.js +42 -0
- package/dist/server/model/entities/SearchTokenEmail.js.map +1 -0
- package/dist/server/model/entities/SearchWord.d.ts +1 -1
- package/dist/server/model/events/NameTokenEvents.d.ts +2 -4
- package/dist/server/model/events/NameTokenEvents.d.ts.map +1 -1
- package/dist/server/model/events/NameTokenEvents.js +2 -8
- package/dist/server/model/events/NameTokenEvents.js.map +1 -1
- package/dist/server/model/events/ReadOnlyEvents.d.ts +7 -0
- package/dist/server/model/events/ReadOnlyEvents.d.ts.map +1 -0
- package/dist/server/model/events/ReadOnlyEvents.js +16 -0
- package/dist/server/model/events/ReadOnlyEvents.js.map +1 -0
- package/dist/server/model/events/SearchTokenEmailEvents.d.ts +5 -0
- package/dist/server/model/events/SearchTokenEmailEvents.d.ts.map +1 -0
- package/dist/server/model/events/SearchTokenEmailEvents.js +4 -0
- package/dist/server/model/events/SearchTokenEmailEvents.js.map +1 -0
- package/dist/server/model/events/SearchTokenEvents.d.ts +5 -0
- package/dist/server/model/events/SearchTokenEvents.d.ts.map +1 -0
- package/dist/server/model/events/SearchTokenEvents.js +4 -0
- package/dist/server/model/events/SearchTokenEvents.js.map +1 -0
- package/dist/server/seed/ui/seed-ui.js +2 -2
- package/dist/server/services/EmailAddressService.d.ts.map +1 -1
- package/dist/server/services/EmailAddressService.js +2 -12
- package/dist/server/services/EmailAddressService.js.map +1 -1
- package/dist/server/services/emails/IndexEmailService.d.ts +14 -0
- package/dist/server/services/emails/IndexEmailService.d.ts.map +1 -0
- package/dist/server/services/emails/IndexEmailService.js +72 -0
- package/dist/server/services/emails/IndexEmailService.js.map +1 -0
- package/dist/server/services/extract/TextExtractorService.d.ts +9 -0
- package/dist/server/services/extract/TextExtractorService.d.ts.map +1 -0
- package/dist/server/services/extract/TextExtractorService.js +59 -0
- package/dist/server/services/extract/TextExtractorService.js.map +1 -0
- package/dist/server/services/search/SearchTokenService.d.ts +7 -0
- package/dist/server/services/search/SearchTokenService.d.ts.map +1 -0
- package/dist/server/services/search/SearchTokenService.js +107 -0
- package/dist/server/services/search/SearchTokenService.js.map +1 -0
- package/dist/server/workflows/SocialWorkflowContext.d.ts.map +1 -1
- package/dist/server/workflows/SocialWorkflowContext.js +4 -0
- package/dist/server/workflows/SocialWorkflowContext.js.map +1 -1
- package/dist/server/workflows/daily/DailyWorkflow.d.ts.map +1 -1
- package/dist/server/workflows/daily/DailyWorkflow.js +4 -0
- package/dist/server/workflows/daily/DailyWorkflow.js.map +1 -1
- package/dist/server/workflows/email/index/IndexEmailAddressWorkflow.d.ts +11 -0
- package/dist/server/workflows/email/index/IndexEmailAddressWorkflow.d.ts.map +1 -0
- package/dist/server/workflows/email/index/IndexEmailAddressWorkflow.js +69 -0
- package/dist/server/workflows/email/index/IndexEmailAddressWorkflow.js.map +1 -0
- package/dist/server/workflows/email/index/IndexEmailContentWorkflow.d.ts +11 -0
- package/dist/server/workflows/email/index/IndexEmailContentWorkflow.d.ts.map +1 -0
- package/dist/server/workflows/email/index/IndexEmailContentWorkflow.js +64 -0
- package/dist/server/workflows/email/index/IndexEmailContentWorkflow.js.map +1 -0
- package/dist/server/workflows/search/IndexFileContentsWorkflow.d.ts +2 -2
- package/dist/server/workflows/search/IndexFileContentsWorkflow.d.ts.map +1 -1
- package/dist/server/workflows/search/IndexFileContentsWorkflow.js +9 -39
- package/dist/server/workflows/search/IndexFileContentsWorkflow.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/server/model/SocialMailContext.ts +6 -0
- package/src/server/model/SocialMailContextEvents.ts +8 -0
- package/src/server/model/entities/Domain.ts +3 -2
- package/src/server/model/entities/Email.ts +10 -0
- package/src/server/model/entities/EmailAddress.ts +11 -2
- package/src/server/model/entities/NameToken.ts +5 -4
- package/src/server/model/entities/SearchToken.ts +26 -0
- package/src/server/model/entities/SearchTokenEmail.ts +34 -0
- package/src/server/model/entities/SearchWord.ts +1 -1
- package/src/server/model/events/NameTokenEvents.ts +2 -9
- package/src/server/model/events/ReadOnlyEvents.ts +20 -0
- package/src/server/model/events/SearchTokenEmailEvents.ts +6 -0
- package/src/server/model/events/SearchTokenEvents.ts +6 -0
- package/src/server/seed/ui/seed-ui.ts +2 -2
- package/src/server/services/EmailAddressService.ts +2 -13
- package/src/server/services/emails/IndexEmailService.ts +65 -0
- package/src/server/services/extract/TextExtractorService.ts +52 -0
- package/src/server/services/search/SearchTokenService.ts +33 -0
- package/src/server/workflows/SocialWorkflowContext.ts +5 -0
- package/src/server/workflows/daily/DailyWorkflow.ts +4 -0
- package/src/server/workflows/email/index/IndexEmailAddressWorkflow.ts +65 -0
- package/src/server/workflows/email/index/IndexEmailContentWorkflow.ts +54 -0
- package/src/server/workflows/search/IndexFileContentsWorkflow.ts +7 -43
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/* eslint-disable no-console */
|
|
2
|
+
import Inject from "@entity-access/entity-access/dist/di/di.js";
|
|
3
|
+
import DateTime from "@entity-access/entity-access/dist/types/DateTime.js";
|
|
4
|
+
import Workflow, { UniqueActivity } from "@entity-access/entity-access/dist/workflows/Workflow.js";
|
|
5
|
+
import WorkflowContext from "@entity-access/entity-access/dist/workflows/WorkflowContext.js";
|
|
6
|
+
import SocialMailContext from "../../../model/SocialMailContext.js";
|
|
7
|
+
import IndexEmailService from "../../../services/emails/IndexEmailService.js";
|
|
8
|
+
|
|
9
|
+
export default class IndexEmailContentWorkflow extends Workflow {
|
|
10
|
+
|
|
11
|
+
static taskGroup = "batch";
|
|
12
|
+
|
|
13
|
+
static queue(context: WorkflowContext) {
|
|
14
|
+
const now = DateTime.now;
|
|
15
|
+
return context.queue(IndexEmailContentWorkflow, "", {
|
|
16
|
+
id: `index-email-${now.msSinceEpoch.toString(36)}`
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
async run() {
|
|
21
|
+
await this.index();
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
@UniqueActivity
|
|
25
|
+
async index(
|
|
26
|
+
@Inject db?: SocialMailContext,
|
|
27
|
+
@Inject indexService?: IndexEmailService
|
|
28
|
+
) {
|
|
29
|
+
|
|
30
|
+
for(let i = 0;i<1000;i++) {
|
|
31
|
+
const pending = await db.emails.where(void 0, (p) => (x) => x.searchIndexed === false
|
|
32
|
+
&& x.statePostReceiveInvoked === true)
|
|
33
|
+
.limit(100)
|
|
34
|
+
.map(void 0, (p) => (x) => ({ emailID: x.emailID, textBody: x.textBody}))
|
|
35
|
+
.toArray();
|
|
36
|
+
|
|
37
|
+
if (!pending.length) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
for (const email of pending) {
|
|
42
|
+
try {
|
|
43
|
+
await indexService.indexEmail(email);
|
|
44
|
+
} catch (error) {
|
|
45
|
+
console.error(error);
|
|
46
|
+
}
|
|
47
|
+
const { emailID } = email;
|
|
48
|
+
await db.emails.statements.update({ searchIndexed: true }, { emailID });
|
|
49
|
+
}
|
|
50
|
+
db.changeSet.clear();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
}
|
|
@@ -1,18 +1,15 @@
|
|
|
1
1
|
/* eslint-disable no-console */
|
|
2
2
|
import Workflow, { UniqueActivity } from "@entity-access/entity-access/dist/workflows/Workflow.js";
|
|
3
|
-
import Inject
|
|
3
|
+
import Inject from "@entity-access/entity-access/dist/di/di.js";
|
|
4
4
|
import SocialMailContext from "../../model/SocialMailContext.js";
|
|
5
5
|
import TempFileService from "../../storage/TempFileService.js";
|
|
6
6
|
import { LocalFile } from "@entity-access/server-pages/dist/core/LocalFile.js";
|
|
7
|
-
import { FileType } from "../../../common/FileType.js";
|
|
8
7
|
import FileContent from "../../model/entities/FileContent.js";
|
|
9
|
-
import EmailParserService from "../../smtp/services/EmailParserService.js";
|
|
10
|
-
import { parse } from "path";
|
|
11
|
-
import { Extract } from "../../services/extract/Extract.js";
|
|
12
8
|
import { AppWorkflowContext } from "../AppWorkflowContext.js";
|
|
13
9
|
import { appendFile } from "fs/promises";
|
|
14
10
|
import BufferHelper from "../../../common/BufferHelper.js";
|
|
15
11
|
import sleep from "../../../common/sleep.js";
|
|
12
|
+
import TextExtractorService from "../../services/extract/TextExtractorService.js";
|
|
16
13
|
|
|
17
14
|
export default class IndexFileContentsWorkflow extends Workflow {
|
|
18
15
|
|
|
@@ -38,7 +35,8 @@ export default class IndexFileContentsWorkflow extends Workflow {
|
|
|
38
35
|
async index(
|
|
39
36
|
start,
|
|
40
37
|
@Inject db?: SocialMailContext,
|
|
41
|
-
@Inject tempFileService?: TempFileService
|
|
38
|
+
@Inject tempFileService?: TempFileService,
|
|
39
|
+
@Inject te?: TextExtractorService
|
|
42
40
|
) {
|
|
43
41
|
|
|
44
42
|
db.verifyFilters = false;
|
|
@@ -63,7 +61,7 @@ export default class IndexFileContentsWorkflow extends Workflow {
|
|
|
63
61
|
for (const iterator of files) {
|
|
64
62
|
start = iterator.fileContentID;
|
|
65
63
|
try {
|
|
66
|
-
await this.saveTextContent(iterator, tempFileService, db);
|
|
64
|
+
await this.saveTextContent(iterator, tempFileService, db, te);
|
|
67
65
|
} catch (error) {
|
|
68
66
|
console.error(error);
|
|
69
67
|
}
|
|
@@ -72,42 +70,8 @@ export default class IndexFileContentsWorkflow extends Workflow {
|
|
|
72
70
|
return start;
|
|
73
71
|
}
|
|
74
72
|
|
|
75
|
-
private async extractText(file: LocalFile, tempFileService: TempFileService, db: SocialMailContext) {
|
|
76
73
|
|
|
77
|
-
|
|
78
|
-
const outputFile = await tempFileService.createTempFile(".txt");
|
|
79
|
-
|
|
80
|
-
const isEmail = file.contentType === "message/rfc822";
|
|
81
|
-
if(isEmail) {
|
|
82
|
-
const parser = ServiceProvider.resolve(this, EmailParserService);
|
|
83
|
-
const parsedEmail = await parser.parse(file, true);
|
|
84
|
-
await outputFile.appendLine(parsedEmail.text);
|
|
85
|
-
for (const iterator of parsedEmail.attachments) {
|
|
86
|
-
const { ext } = parse(iterator.filename || "file.dat");
|
|
87
|
-
const tf = await tempFileService.createTempFile(ext, iterator.filename, iterator.contentType);
|
|
88
|
-
await tf.writeAll(iterator.content);
|
|
89
|
-
const t = await this.extractText(tf, tempFileService, db);
|
|
90
|
-
if (t) {
|
|
91
|
-
await outputFile.appendLine(await t.readAsText());
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
return outputFile;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
if (/image\//i.test(file.contentType)) {
|
|
99
|
-
await Extract.text(file, outputFile, true);
|
|
100
|
-
return outputFile;
|
|
101
|
-
} if (FileType.canBeCompressed(file)) {
|
|
102
|
-
await Extract.text(file, outputFile);
|
|
103
|
-
return outputFile;
|
|
104
|
-
}
|
|
105
|
-
await outputFile.writeAllText("");
|
|
106
|
-
return outputFile;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
private async saveTextContent(fileContent: FileContent, tempFileService: TempFileService, db: SocialMailContext) {
|
|
74
|
+
private async saveTextContent(fileContent: FileContent, tempFileService: TempFileService, db: SocialMailContext, te: TextExtractorService) {
|
|
111
75
|
|
|
112
76
|
let searchable = "";
|
|
113
77
|
|
|
@@ -143,7 +107,7 @@ export default class IndexFileContentsWorkflow extends Workflow {
|
|
|
143
107
|
}
|
|
144
108
|
|
|
145
109
|
if (file) {
|
|
146
|
-
const fx = await
|
|
110
|
+
const fx = await te.extract(file);
|
|
147
111
|
|
|
148
112
|
if (fx.contentSize < 10*1024*1024) {
|
|
149
113
|
|