forked from johnagan/gmail-labeler
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathlabeler.gs
107 lines (85 loc) · 3.17 KB
/
labeler.gs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
var filters = [
// RegEx match against the raw contents of the email
// { name: 'user emails', match: /deliveredto:[email protected]/, star: true }, // star emails deliveredto [email protected]
// use a RegEx selector (.+?) to set the label name
// Ex:
// List-Id: Hibernate Dev List <hibernate-dev.lists.jboss.org>
{ id: "First Filter", match: /(?:List-ID:\s(.+?)\s<)/i, archive: true }, // organize by list name
// use a RegEx selector (.+?) to set the label name
// Ex:
// List-Id: <users.activemq.apache.org>
{ id: "Second Filter", match: /List-ID:\s[^<]*<(.+?)>/i, archive: true }, // organize by list name
// use the subject shortcut to check the subject for text
// { name: 'finance', subject: 'bank', markRead: true }, // label all emails with "bank" in the subject as "finance" and mark as read
];
var from = [
// "from:[email protected]",
// "list:subscription.domain.com"
];
var ROOT_FOLDER = "OSS/";
var SELECTION = "-label:OSS-personal AND (label:OSS)";
function labeler() {
var batchSize = 50;
var labelCache = {};
var query = "in:inbox AND (" + from.join(' OR ') + ")";
if (SELECTION) {
query += " AND (" + SELECTION + ")";
}
var threads = GmailApp.search(query, 0, batchSize);
GmailApp.getMessagesForThreads(threads);
var findOrCreateLabel = function(name) {
if (labelCache[name] === undefined) {
var labelObject = GmailApp.getUserLabelByName(name);
if( labelObject ){
labelCache[name] = labelObject;
} else {
labelCache[name] = GmailApp.createLabel(name);
Logger.log("Created new label: [" + name + "]");
}
}
return labelCache[name];
}
var applyLabel = function(name, thread){
name = ROOT_FOLDER + name;
var label = null;
var labelName = "";
// create nested labels by parsing "/"
name.split('/').forEach(function(labelPart, i) {
labelName = labelName + (i===0 ? "" : "/") + labelPart.trim();
label = findOrCreateLabel(labelName);
});
thread.addLabel(label);
}
threads.forEach(function(thread) {
var messages = thread.getMessages();
if (messages == null)
return; // nothing to do
var message = messages[messages.length - 1]; // most recent message
var body = message.getRawContent();
var archive = true;
Logger.log("Body: " + body);
filters.forEach(function(filter){
Logger.log("Applying filter: " + filter.id);
// shortcuts
if (filter.subject)
filter.match = new RegExp('Subject:.*?' + filter.subject, 'i');
var matches = filter.match.exec(body);
if (matches !== null) {
// label will be regex match or name provided
var label = filter.name || matches[1];
if (label !== undefined)
applyLabel(label, thread);
// toggle flags
if (filter.star)
message.star();
if (filter.markRead)
message.markRead();
// prevent archive if filter explicitly sets "archive" to false (if "archive" is not defined, continue)
if (filter.archive !== undefined && !filter.archive)
archive = false;
}
});
if (archive)
thread.moveToArchive();
});
}