0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00

Moved zip folder utility to services/themes

refs #9178

- it's only used for themes currently
- this is definitely a util which could be useful lib
- if we have a second use case, we can move it
This commit is contained in:
kirrg001 2017-12-14 21:02:47 +01:00
parent fc5b4dd934
commit 849e97640f
3 changed files with 13 additions and 11 deletions

View file

@ -6,7 +6,7 @@ var fs = require('fs-extra'),
Promise = require('bluebird'), Promise = require('bluebird'),
config = require('../../config'), config = require('../../config'),
security = require('../../lib/security'), security = require('../../lib/security'),
zipFolder = require('../../utils/zip-folder'), localUtils = require('./utils'),
LocalFileStorage = require('../../adapters/storage/LocalFileStorage'); LocalFileStorage = require('../../adapters/storage/LocalFileStorage');
/** /**
@ -37,7 +37,7 @@ class ThemeStorage extends LocalFileStorage {
fs.ensureDir(zipBasePath) fs.ensureDir(zipBasePath)
.then(function () { .then(function () {
return Promise.promisify(zipFolder)(themePath, zipPath); return Promise.promisify(localUtils.zipFolder)(themePath, zipPath);
}) })
.then(function (length) { .then(function (length) {
res.set({ res.set({

View file

@ -1,6 +1,8 @@
var fs = require('fs-extra'); 'use strict';
module.exports = function zipFolder(folderToZip, destination, callback) { const fs = require('fs-extra');
exports.zipFolder = function zipFolder(folderToZip, destination, callback) {
var archiver = require('archiver'), var archiver = require('archiver'),
output = fs.createWriteStream(destination), output = fs.createWriteStream(destination),
archive = archiver.create('zip', {}); archive = archiver.create('zip', {});

View file

@ -2,13 +2,13 @@ var should = require('should'), // jshint ignore:line
path = require('path'), path = require('path'),
fs = require('fs-extra'), fs = require('fs-extra'),
extract = require('extract-zip'), extract = require('extract-zip'),
zipFolder = require('../../../server/utils/zip-folder'); themeUtils = require('../../../../server/services/themes/utils');
describe('Utils: zip-folder', function () { describe('services/themes: theme utils', function () {
const symlinkPath = path.join(__dirname, '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink'), const symlinkPath = path.join(__dirname, '..', '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink'),
folderToSymlink = path.join(__dirname, '..', '..', 'utils', 'fixtures', 'themes', 'casper'), folderToSymlink = path.join(__dirname, '..', '..', '..', 'utils', 'fixtures', 'themes', 'casper'),
zipDestination = path.join(__dirname, '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink.zip'), zipDestination = path.join(__dirname, '..', '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink.zip'),
unzipDestination = path.join(__dirname, '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink-unzipped'); unzipDestination = path.join(__dirname, '..', '..', '..', 'utils', 'fixtures', 'themes', 'theme-symlink-unzipped');
before(function () { before(function () {
fs.removeSync(symlinkPath); fs.removeSync(symlinkPath);
@ -25,7 +25,7 @@ describe('Utils: zip-folder', function () {
it('ensure symlinks work', function (done) { it('ensure symlinks work', function (done) {
fs.symlink(folderToSymlink, symlinkPath); fs.symlink(folderToSymlink, symlinkPath);
zipFolder(symlinkPath, zipDestination, function (err) { themeUtils.zipFolder(symlinkPath, zipDestination, function (err) {
if (err) { if (err) {
return done(err); return done(err);
} }