This repository was archived by the owner on Oct 13, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAzureSyncInsert.js
More file actions
80 lines (79 loc) · 2.71 KB
/
AzureSyncInsert.js
File metadata and controls
80 lines (79 loc) · 2.71 KB
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
function insert(item, user, request) {
// console.log(item);
if (!item.entries || !item.lastSyncDate)
request.respond(400);
var entriesTable = tables.getTable('AzureEntry');
var entries = item.entries;
var serverChanges = [];
var count = 0;
if (entries.length > 0) {
entries.forEach(function (entry, index) {
entriesTable.where({ EntryGuid: entry.EntryGuid })
.read({
success: function (results) {
if (results.length > 0 && results[0].UserId == user.userId) {
if (results[0].EditDateTime < entry.EditDateTime) {
//Update the server entry
entriesTable.update(entry, {
success: function () {
count++;
if (count === entries.length) {
processServerChanges(item, user, request, serverChanges);
}
}
});
} else {
//Add the server entry to the server changes array
serverChanges.push(results[0]);
count++;
if (count === entries.length) {
processServerChanges(item, user, request, serverChanges);
}
}
} else {
//New Entry
entry.UserId = user.userId;
entry.EditDateTime = new Date();
delete entry.id;
entriesTable.insert(entry, {
success: function () {
serverChanges.push(entry);
count++;
if (count === entries.length) {
processServerChanges(item, user, request, serverChanges);
}
}
});
}
}
});
});
} else {
processServerChanges(item, user, request, serverChanges);
}
}
function processServerChanges(item, user, request, serverChanges) {
var sql = "select * from AzureEntry where EditDateTime > ? and UserId = ?";
var params = [];
params.push(item.lastSyncDate);
params.push(user.userId);
if (item.entries.length > 0) {
sql += " and EntryGuid NOT IN (";
for (var i = 0; i < item.entries.length; i++) {
sql += "?,";
params.push(item.entries[i].EntryGuid);
}
sql = sql.substr(0, sql.length - 1) + ")";
}
// console.log(sql);
// console.log(params);
mssql.query(sql, params, {
success: function (results) {
serverChanges = serverChanges.concat(results);
var requestResult = {
ServerChanges: serverChanges
};
request.respond(statusCodes.OK, requestResult);
}
});
}