blob: b2b76d28d690fe093d81b8c7d6cafa4c47ddd06f [file] [log] [blame]
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
var fs = require('fs');
var http = require('http');
var https = require('https');
var path = require('path');
var parseURL = require('url').parse;
var shell = require('child_process').execSync;
var Stream = require('stream').Transform;
function fetch(url) {
return new Promise(fetchPromise);
function fetchPromise(resolve, reject) {
var request;
var protocol = parseURL(url).protocol;
var handleResponse = getCallback.bind(null, resolve, reject);
if (protocol === 'https:') {
request = https.get(url, handleResponse);
} else if (protocol === 'http:') {
request = http.get(url, handleResponse);
} else {
reject(new Error(`Invalid protocol for url: ${url}`));
return;
}
request.on('error', err => reject(err));
}
function getCallback(resolve, reject, response) {
if (response.statusCode !== 200) {
reject(new Error(`Request error: + ${response.statusCode}`));
return;
}
var body = new Stream();
response.on('data', chunk => body.push(chunk));
response.on('end', () => resolve(body.read()));
}
}
function atob(str) {
return new Buffer(str, 'base64').toString('binary');
}
function isFile(path) {
try {
return fs.statSync(path).isFile();
} catch (error) {
return false;
}
}
function isDir(path) {
try {
return fs.statSync(path).isDirectory();
} catch (error) {
return false;
}
}
function copy(src, dest) {
try {
var targetFilePath = path.resolve(dest, path.basename(src));
fs.writeFileSync(targetFilePath, fs.readFileSync(src));
} catch (error) {
throw new Error(`Received an error: [${error}] while trying to copy: ${src} -> ${dest}`);
}
}
function copyRecursive(src, dest) {
try {
if (isFile(src)) {
copy(src, dest);
return;
}
var targetDirPath = path.resolve(dest, path.basename(src));
if (!fs.existsSync(targetDirPath))
fs.mkdirSync(targetDirPath);
if (isDir(src)) {
var files = fs.readdirSync(src);
for (var i = 0; i < files.length; i++) {
var childPath = path.resolve(src, files[i]);
if (isDir(childPath)) {
copyRecursive(childPath, targetDirPath);
} else {
var targetFilePath = path.resolve(targetDirPath, path.basename(childPath));
fs.writeFileSync(targetFilePath, fs.readFileSync(childPath));
}
}
}
} catch (error) {
throw new Error(`Received an error: [${error}] while trying to copy: ${src} -> ${dest}`);
}
}
function removeRecursive(filePath) {
try {
if (fs.existsSync(filePath)) {
if (isFile(filePath)) {
fs.unlinkSync(filePath);
return;
}
var files = fs.readdirSync(filePath);
for (var i = 0; i < files.length; i++) {
var childPath = path.resolve(filePath, files[i]);
if (isDir(childPath))
removeRecursive(childPath);
else
fs.unlinkSync(childPath);
}
fs.rmdirSync(filePath);
}
} catch (error) {
throw new Error(`Received an error: [${error}] while trying to remove: ${filePath}`);
}
}
function includes(sequence, target) {
return sequence.indexOf(target) > -1;
}
function shellOutput(command) {
return shell(command).toString().trim();
}
function parseArgs(args) {
var argObject = {};
for (var i = 0; i < args.length; i++) {
var arg = args[i];
var components = arg.split('=');
var key = components[0];
argObject[key] = components[1] || true;
}
return argObject;
}
module.exports = {
fetch, atob, isFile, isDir, copy, copyRecursive, removeRecursive, includes, shellOutput, parseArgs,
};