/
index.js
320 lines (319 loc) · 44.7 KB
/
index.js
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
var Promise = require("bluebird");
var pathExists = require("path-exists");
var child_process = require("child_process");
var lsDisks = require("ls-disks");
var exec = child_process.exec;
var spawn = child_process.spawn;
function shacheck(path, bs, count) {
return new Promise(function (resolve, reject) {
if (bs && count) {
exec("dd if=" + path + " bs=" + bs + " count=" + count + " | sha1sum |awk '{print($1)}' ", function (err, stdout, stderr) {
if (err) {
reject(err);
}
else {
resolve(stdout.toString("utf-8"));
}
});
}
else {
exec("sha1sum " + path + " |awk '{print($1)}'", function (err, stdout, stderr) {
if (err) {
reject(err);
}
else if (stderr) {
reject(stderr);
}
else {
resolve(stdout.toString("utf-8"));
}
});
}
});
}
function filesize(file) {
return new Promise(function (resolve, reject) {
exec("du -b " + file, function (err, stdout, stderr) {
if (err) {
reject(err);
}
else if (stderr) {
reject(stderr);
}
else {
resolve(parseInt(stdout.toString("utf-8")));
}
});
});
}
function freespace(file) {
return new Promise(function (resolve, reject) {
var folder = file.replace("/" + file.split("/")[file.split("/").length - 1], "");
exec("df -k " + folder + "| tail -1 | awk {'print$(4)'}", function (err, stdout, stderr) {
if (err) {
reject(err);
}
else if (stderr) {
reject(stderr);
}
else {
console.log(stdout);
resolve(parseInt(stdout.toString("utf-8")) * 1024);
}
});
});
}
function checkspace(source, dest) {
var lsdisks = lsDisks.all();
var diskdest;
var disksource;
for (var i = 0; i < lsdisks.length; i++) {
if (source === lsdisks[i].disk) {
disksource = lsdisks[i];
}
else if (dest === lsdisks[i].disk) {
diskdest = lsdisks[i];
}
}
return new Promise(function (resolve, reject) {
if (source.split("dev/").length === 2) {
if (dest.split("dev/").length === 2) {
if (disksource.used_blocks < diskdest.sectors) {
console.log("size ok");
resolve(true);
}
else {
reject("insufficient space on " + dest);
}
}
else {
freespace(dest).then(function (sizedest) {
console.log("free space is " + sizedest);
if (disksource.used_blocks * disksource.block < sizedest) {
resolve(true);
}
else {
reject("insufficient space on " + dest);
}
}).catch(function (err) {
reject(err);
});
}
}
else {
filesize(source).then(function (sizesource) {
if (dest.split("dev/").length === 2) {
if (sizesource < diskdest.size) {
resolve(true);
}
else {
reject("insufficient space on " + dest);
}
}
else {
freespace(dest).then(function (sizedest) {
if (sizesource < sizedest) {
resolve(true);
}
else {
reject("insufficient space on " + dest);
}
}).catch(function (err) {
reject(err);
});
}
}).catch(function (err) {
reject(err);
});
}
});
}
function umount_drive(disk) {
return new Promise(function (resolve, reject) {
exec("cat /proc/mounts | grep " + disk + " | awk {'print$(1)'}", function (err, stdout, stderr) {
if (err) {
reject(err);
}
else if (stderr) {
reject(stderr);
}
else {
var drives = "";
var fdiskstring = stdout.toString("utf-8");
var fdisklines = fdiskstring.split("\n");
for (var i = 0; i < fdisklines.length; i++) {
drives = drives + fdisklines[i] + " ";
}
if (fdisklines[0] !== "") {
console.log("umount partitions: " + drives);
exec("umount " + drives, function (err, stdout, stderr) {
if (err) {
reject(err);
}
else if (stderr) {
reject(stderr);
}
else {
resolve(true);
}
});
}
else {
resolve(true);
}
}
});
});
}
function umountall(source, dest) {
return new Promise(function (resolve, reject) {
if (source.split("dev/").length === 2) {
umount_drive(source).then(function () {
if (dest.split("dev/").length === 2) {
umount_drive(dest).then(function () {
resolve(true);
}).catch(function (err) {
reject(err);
});
}
else {
resolve(true);
}
}).catch(function (err) {
reject(err);
});
}
else {
if (dest.split("dev/").length === 2) {
umount_drive(dest).then(function () {
resolve(true);
}).catch(function (err) {
reject(err);
});
}
else {
resolve(true);
}
}
});
}
module.exports = function (source, dest, progress) {
console.log("starting");
return new Promise(function (resolve, reject) {
if (!source || !pathExists.sync(source)) {
reject("missing source");
}
else if (!dest) {
reject("missing dest");
}
else if (dest.split("dev/").length === 2 && !pathExists.sync(dest)) {
reject("missing dest");
}
else {
var lsdisks = lsDisks.all();
var diskdest;
var disksource;
for (var i = 0; i < lsdisks.length; i++) {
if (source === lsdisks[i].disk) {
disksource = lsdisks[i];
}
else if (dest === lsdisks[i].disk) {
diskdest = lsdisks[i];
}
}
umountall(source, dest).then(function () {
console.log("checking space...");
checkspace(source, dest).then(function () {
console.log("cloning...");
if (source.split("dev/").length === 2) {
var CloneCmd = "dd if=" + source + " bs=" + disksource.block + " count=" + disksource.used_blocks + " of=" + dest;
console.log(CloneCmd);
shacheck(source, disksource.block, disksource.used_blocks).then(function (sha1) {
exec(CloneCmd, function (err, stdout, stderr) {
if (err) {
reject(err);
}
else {
shacheck(dest, disksource.block, disksource.used_blocks).then(function (sha2) {
if (sha1 === sha2) {
resolve(true);
}
else {
reject("shasum don't match");
}
}).catch(function (err) {
reject(err);
});
}
});
}).catch(function (err) {
reject(err);
});
}
else {
var CloneCmd = "dd if=" + source + " of=" + dest;
console.log(CloneCmd);
shacheck(source).then(function (sha1) {
console.log("shasum " + source + ": " + sha1);
exec(CloneCmd, function (err, stdout, stderr) {
if (err) {
reject(err);
}
else {
if (dest.split("dev/").length === 2) {
filesize(source).then(function (sizesource) {
lsdisks = lsDisks.all();
for (var i = 0; i < lsdisks.length; i++) {
if (source === lsdisks[i].disk) {
disksource = lsdisks[i];
}
else if (dest === lsdisks[i].disk) {
diskdest = lsdisks[i];
}
}
console.log("bs= " + diskdest.block);
console.log("count= " + diskdest.used_blocks);
shacheck(dest, diskdest.block, diskdest.used_blocks).then(function (sha2) {
console.log("shasum " + dest + ": " + sha2);
if (sha1 === sha2) {
resolve(true);
}
else {
reject("shasum don't match");
}
}).catch(function (err) {
reject(err);
});
}).catch(function (err) {
reject(err);
});
}
else {
shacheck(dest).then(function (sha2) {
console.log("shasum " + dest + ": " + sha2);
if (sha1 === sha2) {
resolve(true);
}
else {
reject("shasum don't match");
}
}).catch(function (err) {
reject(err);
});
}
}
});
}).catch(function (err) {
reject(err);
});
}
}).catch(function (err) {
reject(err);
});
}).catch(function (err) {
reject(err);
});
}
});
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["index.ts"],"names":["shacheck","filesize","freespace","checkspace","umount_drive","umountall"],"mappings":"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","file":"index.js","sourcesContent":["import * as Promise from \"bluebird\";\nimport * as pathExists from \"path-exists\";\nimport * as child_process from \"child_process\";\n\nimport lsDisks = require(\"ls-disks\");\n\nlet exec = child_process.exec;\nlet spawn = child_process.spawn;\n\nfunction shacheck(path: string, bs?: number, count?: number) {\n    return new Promise<string>(function(resolve, reject) {\n\n        if (bs && count) {\n            exec(\"dd if=\" + path + \" bs=\" + bs + \" count=\" + count + \" | sha1sum |awk '{print($1)}' \", function(err, stdout, stderr) {\n\n                if (err) {\n                    reject(err);\n\n                } else {\n\n                    resolve(stdout.toString(\"utf-8\"));\n                }\n            });\n        } else {\n            exec(\"sha1sum \" + path + \" |awk '{print($1)}'\", function(err, stdout, stderr) {\n                if (err) {\n                    reject(err);\n                } else if (stderr) {\n                    reject(stderr);\n\n                } else {\n\n                    resolve(stdout.toString(\"utf-8\"));\n                }\n            });\n        }\n    });\n}\n\nfunction filesize(file: string) {\n    return new Promise<number>(function(resolve, reject) {\n        exec(\"du -b \" + file, function(err, stdout, stderr) {\n            if (err) {\n                reject(err);\n            } else if (stderr) {\n                reject(stderr);\n\n            } else {\n                resolve(parseInt(stdout.toString(\"utf-8\")));\n            }\n        });\n    });\n}\n\n\n\n\n\nfunction freespace(file: string) {\n    return new Promise<number>(function(resolve, reject) {\n        let folder = file.replace(\"/\" + file.split(\"/\")[file.split(\"/\").length - 1], \"\");\n        exec(\"df -k \" + folder + \"| tail -1 | awk {'print$(4)'}\", function(err, stdout, stderr) {\n            if (err) {\n                reject(err);\n            } else if (stderr) {\n                reject(stderr);\n\n            } else {\n                console.log(stdout);\n                resolve(parseInt(stdout.toString(\"utf-8\")) * 1024);\n            }\n        });\n    });\n}\n\n\nfunction checkspace(source: string, dest: string) {\n    let lsdisks = lsDisks.all();\n    let diskdest: IDisk;\n    let disksource: IDisk;\n\n\n    for (let i = 0; i < lsdisks.length; i++) {\n        if (source === lsdisks[i].disk) {\n            disksource = lsdisks[i];\n        } else if (dest === lsdisks[i].disk) {\n            diskdest = lsdisks[i];\n        }\n    }\n\n\n    return new Promise<boolean>(function(resolve, reject) {\n        if (source.split(\"dev/\").length === 2) {\n            if (dest.split(\"dev/\").length === 2) {\n\n\n\n                if (disksource.used_blocks < diskdest.sectors) {\n                    console.log(\"size ok\");\n                    resolve(true);\n                } else {\n                    reject(\"insufficient space on \" + dest);\n                }\n\n\n\n\n            } else {\n\n                freespace(dest).then(function(sizedest) {\n\n                    console.log(\"free space is \" + sizedest);\n\n                    if (disksource.used_blocks * disksource.block < sizedest) {\n                        resolve(true);\n                    } else {\n                        reject(\"insufficient space on \" + dest);\n                    }\n                }).catch(function(err) {\n                    reject(err);\n                });\n            }\n\n        } else {\n            filesize(source).then(function(sizesource) {\n\n                if (dest.split(\"dev/\").length === 2) {\n\n\n                    if (sizesource < diskdest.size) {\n                        resolve(true);\n                    } else {\n                        reject(\"insufficient space on \" + dest);\n                    }\n\n\n                } else {\n\n                    freespace(dest).then(function(sizedest) {\n\n                        if (sizesource < sizedest) {\n                            resolve(true);\n                        } else {\n                            reject(\"insufficient space on \" + dest);\n                        }\n\n                    }).catch(function(err) {\n                        reject(err);\n                    });\n\n                }\n\n\n            }).catch(function(err) {\n                reject(err);\n            });\n\n\n        }\n    });\n}\n\nfunction umount_drive(disk) {\n    return new Promise<boolean>(function(resolve, reject) {\n        exec(\"cat /proc/mounts | grep \" + disk + \" | awk {'print$(1)'}\", function(err, stdout, stderr) {\n            if (err) {\n                reject(err);\n            } else if (stderr) {\n                reject(stderr);\n\n            } else {\n                let drives = \"\";\n                let fdiskstring = stdout.toString(\"utf-8\");\n                let fdisklines = fdiskstring.split(\"\\n\");\n                for (let i = 0; i < fdisklines.length; i++) {\n                    drives = drives + fdisklines[i] + \" \";\n                }\n\n                if (fdisklines[0] !== \"\") {\n                    console.log(\"umount partitions: \" + drives);\n                    exec(\"umount \" + drives, function(err, stdout, stderr) {\n                        if (err) {\n                            reject(err);\n                        } else if (stderr) {\n                            reject(stderr);\n\n                        } else {\n\n                            resolve(true);\n                        }\n                    });\n                } else {\n                    resolve(true);\n                }\n\n            }\n        });\n    });\n}\n\n\nfunction umountall(source: string, dest: string) {\n    return new Promise<boolean>(function(resolve, reject) {\n        if (source.split(\"dev/\").length === 2) {\n            umount_drive(source).then(function() {\n                if (dest.split(\"dev/\").length === 2) {\n                    umount_drive(dest).then(function() {\n                        resolve(true);\n                    }).catch(function(err) {\n                        reject(err);\n                    });\n                } else {\n                    resolve(true);\n                }\n            }).catch(function(err) {\n                reject(err);\n            });\n        } else {\n            if (dest.split(\"dev/\").length === 2) {\n                umount_drive(dest).then(function() {\n                    resolve(true);\n                }).catch(function(err) {\n                    reject(err);\n                });\n            } else {\n                resolve(true);\n            }\n\n        }\n\n\n\n    });\n}\n\ninterface IPartition {\n    partition: string;\n    sectors: number;\n    sectors_start: number;\n    sectors_stop: number;\n    type: string;\n    boot: boolean;\n    size: number;\n}\n\ninterface IDisk {\n    disk: string;\n    sectors: number;\n    size: number;\n    partitions: IPartition[];\n    block: number;\n    used_blocks: number;\n}\n\nexport = function(source: string, dest: string, progress?: Function) {\n    console.log(\"starting\");\n    return new Promise<boolean>(function(resolve, reject) {\n        if (!source || !pathExists.sync(source)) {\n            reject(\"missing source\");\n        } else if (!dest) {\n            reject(\"missing dest\");\n        } else if (dest.split(\"dev/\").length === 2 && !pathExists.sync(dest)) {\n            reject(\"missing dest\");\n        } else {\n\n            let lsdisks: IDisk[] = lsDisks.all();\n            let diskdest: IDisk;\n            let disksource: IDisk;\n\n\n            for (let i = 0; i < lsdisks.length; i++) {\n                if (source === lsdisks[i].disk) {\n                    disksource = lsdisks[i];\n                } else if (dest === lsdisks[i].disk) {\n                    diskdest = lsdisks[i];\n                }\n            }\n\n\n\n\n            umountall(source, dest).then(function() {\n                console.log(\"checking space...\");\n                checkspace(source, dest).then(function() {\n\n                    console.log(\"cloning...\");\n\n                    if (source.split(\"dev/\").length === 2) {\n\n\n                        let CloneCmd = \"dd if=\" + source + \" bs=\" + disksource.block + \" count=\" + disksource.used_blocks + \" of=\" + dest;\n\n                        console.log(CloneCmd);\n\n                        shacheck(source, disksource.block, disksource.used_blocks).then(function(sha1) {\n                            exec(CloneCmd, function(err, stdout, stderr) {\n                                if (err) {\n                                    reject(err);\n\n\n                                } else {\n\n\n                                    shacheck(dest, disksource.block, disksource.used_blocks).then(function(sha2) {\n                                        if (sha1 === sha2) {\n                                            resolve(true);\n                                        } else {\n                                            reject(\"shasum don't match\");\n                                        }\n\n                                    }).catch(function(err) {\n                                        reject(err);\n                                    });\n                                }\n                            });\n                        }).catch(function(err) {\n                            reject(err);\n                        });\n\n\n                    } else {\n\n\n                        let CloneCmd = \"dd if=\" + source + \" of=\" + dest;\n\n                        console.log(CloneCmd);\n\n                        shacheck(source).then(function(sha1) {\n                            console.log(\"shasum \" + source + \": \" + sha1);\n                            exec(CloneCmd, function(err, stdout, stderr) {\n\n                                if (err) {\n\n                                    reject(err);\n\n                                } else {\n\n\n                                    if (dest.split(\"dev/\").length === 2) {\n\n\n                                        filesize(source).then(function(sizesource) {\n\n\n                                            lsdisks = lsDisks.all();\n\n                                            for (let i = 0; i < lsdisks.length; i++) {\n                                                if (source === lsdisks[i].disk) {\n                                                    disksource = lsdisks[i];\n                                                } else if (dest === lsdisks[i].disk) {\n                                                    diskdest = lsdisks[i];\n                                                }\n                                            }\n\n\n\n\n\n\n                                            console.log(\"bs= \" + diskdest.block);\n                                            console.log(\"count= \" + diskdest.used_blocks);\n\n\n                                            shacheck(dest, diskdest.block, diskdest.used_blocks).then(function(sha2) {\n                                                console.log(\"shasum \" + dest + \": \" + sha2);\n                                                if (sha1 === sha2) {\n                                                    resolve(true);\n                                                } else {\n                                                    reject(\"shasum don't match\");\n                                                }\n\n                                            }).catch(function(err) {\n                                                reject(err);\n                                            });\n\n\n\n                                        }).catch(function(err) {\n                                            reject(err);\n                                        });\n\n\n\n\n\n\n\n                                    } else {\n\n                                        shacheck(dest).then(function(sha2) {\n                                            console.log(\"shasum \" + dest + \": \" + sha2);\n                                            if (sha1 === sha2) {\n                                                resolve(true);\n                                            } else {\n                                                reject(\"shasum don't match\");\n                                            }\n\n                                        }).catch(function(err) {\n                                            reject(err);\n                                        });\n\n\n\n                                    }\n\n                                }\n                            });\n                        }).catch(function(err) {\n                            reject(err);\n                        });\n                    }\n\n                }).catch(function(err) {\n                    reject(err);\n                });\n            }).catch(function(err) {\n                reject(err);\n            });\n\n\n        }\n    });\n\n\n\n}\n"],"sourceRoot":"/source/"}