From 28907071705913298be3b8d5c947dc2579636926 Mon Sep 17 00:00:00 2001 From: Aral Balkan Date: Wed, 13 Jun 2018 19:51:15 +0100 Subject: [PATCH] Mirror-folder example now downloads the files correctly. Fixes #116 --- docs/cookbook/diy-dat.md | 55 +++++++++++++++++++++++++++------------- 1 file changed, 38 insertions(+), 17 deletions(-) diff --git a/docs/cookbook/diy-dat.md b/docs/cookbook/diy-dat.md index cc8aa767..a67abdde 100644 --- a/docs/cookbook/diy-dat.md +++ b/docs/cookbook/diy-dat.md @@ -95,35 +95,56 @@ To download the files to the file system, we are going to use [mirror-folder](ht In practice, you should use [dat-storage](https://github.com/datproject/dat-storage) to do this as it'll be more efficient and keep the metadata on disk. -Setup will be the same as before (make sure you install `mirror-folder`). The first part of the module will look the same. +In addition to the modules you installed earlier, you will also need to install the following ones: + +```bash +npm install --save mirror-folder mkdirp +``` + +Update your _index.js_ file to match the following: ```js -var path = require('path') -var ram = require('random-access-memory') -var hyperdrive = require('hyperdrive') -var discovery = require('hyperdiscovery') -var mirror = require('mirror-folder') -var mkdirp = require('mkdirp') +const path = require('path') +const ram = require('random-access-memory') +const hyperdrive = require('hyperdrive') +const discovery = require('hyperdiscovery') +const mirror = require('mirror-folder') +const mkdirp = require('mkdirp') -var link = process.argv[2] // user inputs the dat link -var key = link.replace('dat://', '') // extract the key -var dir = path.join(process.cwd(), 'dat-download') // make a download folder +const link = process.argv[2] + +const key = link.replace('dat://', '') + +const dir = path.join(process.cwd(), 'dat-download') mkdirp.sync(dir) -var archive = hyperdrive(ram, key) -archive.ready(function () { - discovery(archive) +const archive = hyperdrive(ram, key) - var progress = mirror({name: '/', fs: archive}, dir, function (err) { - console.log('done downloading!') +archive.ready(function (err) { + if (err) throw err + const swarm = discovery(archive) + swarm.on('connection', function (peer, type) { + console.log(`Connected to peer (${type.type})`) + }) +}) + +archive.on('content', function () { + console.log('Archive’s content is ready.') + console.log('Starting to mirror…') + const progress = mirror({name: '/', fs: archive}, dir, function (err) { + if (err) throw err + console.log('Done mirroring the archive’s content to disk.') }) progress.on('put', function (src) { - console.log(src.name, 'downloaded') + console.log(` Mirrored: ${src.name}`) + }) + progress.on('skip', function (src) { + console.log(` Skipped: ${src.name}`) }) }) ``` -You should be able to run the module and see all our docs files in the `download` folder: +You should be able to run the module and see all our docs files in the `dat-download` folder: ```bash node index.js dat://