mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -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:
parent
fc5b4dd934
commit
849e97640f
3 changed files with 13 additions and 11 deletions
|
@ -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({
|
||||||
|
|
|
@ -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', {});
|
|
@ -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);
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue