-
Notifications
You must be signed in to change notification settings - Fork 15
/
async-downloads.js
66 lines (56 loc) · 1.58 KB
/
async-downloads.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
// Cet exemple utilise la bibliothèque async
// (https://github.com/caolan/async#asyncjs) qui offre un grand nombre
// de fonctionnalités de haut niveau pour construire des processus
// asynchrones.
//
// Ici, 2 fichiers (`example-net.html` et `example-org.html`) vont
// être téléchargés en parallèle et enregistrés sur le disque.
// Cette exemple requiert l'installation de dépendances :
//
// ```
// > npm install
// ```
'use strict'
const async = require('async')
// Utiliser le paquet `got` pour le téléchargement.
const got = require('got') // starting with 12.x an ESM-only package
// Utiliser `fs.writeFile()` pour enregistrer les fichiers.
const writeFile = require('fs').writeFile
const files = [
{
name: 'example-net.html',
url: 'http://example.net/'
},
{
name: 'example-org.html',
url: 'http://example.org/'
}
]
async.waterfall([
// Télécharge en parallèle tous les fichiers de `files`.
function (callback) {
async.parallel(files.map(function (file) {
return function (callback) {
// console.log('get URL ' + file.url)
got(file.url)
callback()
}
}), callback)
},
// Puis les enregistre sur le disque (toujours en parallèle).
function (results, callback) {
async.parallel(results.map(function (content, i) {
return function (callback) {
// console.log('write file ' + files[i].name)
writeFile(files[i].name, content, callback)
}
}), callback)
}
], function (error) {
if (error) {
console.error(error)
}
else {
console.log('Tout s\'est bien passé')
}
})