2018-02-08 12:01:06 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Upload.js service
|
|
|
|
*
|
|
|
|
* @description: A set of functions similar to controller's actions to avoid code duplication.
|
|
|
|
*/
|
|
|
|
|
2018-02-19 14:26:20 +01:00
|
|
|
const _ = require('lodash');
|
|
|
|
const path = require('path');
|
|
|
|
const fs = require('fs');
|
|
|
|
const toArray = require('stream-to-array');
|
|
|
|
const uuid = require('uuid/v4');
|
|
|
|
|
2018-02-08 12:01:06 +01:00
|
|
|
module.exports = {
|
2018-02-27 11:52:18 +01:00
|
|
|
bufferize: async files => {
|
|
|
|
if (_.isEmpty(files) === 0) {
|
2018-02-19 14:26:20 +01:00
|
|
|
throw 'Missing files.';
|
|
|
|
}
|
|
|
|
|
2018-02-21 17:18:33 +01:00
|
|
|
// files is always an array to map on
|
2018-02-27 11:52:18 +01:00
|
|
|
files = _.isArray(files) ? files : [files];
|
2018-02-19 14:26:20 +01:00
|
|
|
|
2018-02-21 17:18:33 +01:00
|
|
|
// transform all files in buffer
|
2018-02-19 14:26:20 +01:00
|
|
|
return Promise.all(
|
|
|
|
files.map(async stream => {
|
|
|
|
const parts = await toArray(fs.createReadStream(stream.path));
|
|
|
|
const buffers = parts.map(
|
|
|
|
part => _.isBuffer(part) ? part : Buffer.from(part)
|
|
|
|
);
|
|
|
|
|
|
|
|
return {
|
2018-02-19 15:41:26 +01:00
|
|
|
name: stream.name,
|
|
|
|
hash: uuid().replace(/-/g, ''),
|
2018-02-23 14:57:58 +01:00
|
|
|
ext: stream.name.split('.').length > 1 ? `.${_.last(stream.name.split('.'))}` : '',
|
2018-02-19 14:26:20 +01:00
|
|
|
buffer: Buffer.concat(buffers),
|
2018-02-19 15:41:26 +01:00
|
|
|
mime: stream.type,
|
2018-02-21 14:46:10 +01:00
|
|
|
size: (stream.size / 1000).toFixed(2)
|
2018-02-19 14:26:20 +01:00
|
|
|
};
|
|
|
|
})
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
2018-02-20 17:10:25 +01:00
|
|
|
upload: async (files, config) => {
|
2018-02-27 16:53:06 +01:00
|
|
|
// Get upload provider settings to configure the provider to use.
|
|
|
|
const provider = _.find(strapi.plugins.upload.config.providers, { provider: config.provider });
|
|
|
|
const actions = provider.init(config);
|
2018-02-20 17:10:25 +01:00
|
|
|
|
2018-02-27 16:53:06 +01:00
|
|
|
// Execute upload function of the provider for all files.
|
2018-02-19 14:26:20 +01:00
|
|
|
return Promise.all(
|
|
|
|
files.map(async file => {
|
2018-02-20 17:10:25 +01:00
|
|
|
await actions.upload(file);
|
2018-02-19 15:41:26 +01:00
|
|
|
|
2018-02-27 16:53:06 +01:00
|
|
|
// Remove buffer to don't save it.
|
2018-02-19 15:41:26 +01:00
|
|
|
delete file.buffer;
|
|
|
|
|
2018-02-27 16:53:06 +01:00
|
|
|
return await strapi.plugins['upload'].services.upload.add(file);
|
2018-02-19 14:26:20 +01:00
|
|
|
})
|
|
|
|
);
|
2018-02-19 15:41:26 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
add: async (values) => {
|
|
|
|
// Use Content Manager business logic to handle relation.
|
|
|
|
if (strapi.plugins['content-manager']) {
|
|
|
|
return await strapi.plugins['content-manager'].services['contentmanager'].add({
|
|
|
|
model: 'file'
|
|
|
|
}, values, 'upload');
|
|
|
|
}
|
|
|
|
|
|
|
|
return strapi.query('file', 'upload').create(values);
|
|
|
|
},
|
|
|
|
|
|
|
|
edit: async (params, values) => {
|
|
|
|
// Use Content Manager business logic to handle relation.
|
|
|
|
if (strapi.plugins['content-manager']) {
|
|
|
|
params.model = 'file';
|
|
|
|
params.id = (params._id || params.id);
|
|
|
|
|
|
|
|
return await strapi.plugins['content-manager'].services['contentmanager'].edit(params, values, 'upload');
|
|
|
|
}
|
|
|
|
|
|
|
|
return strapi.query('file', 'upload').update(_.assign(params, values));
|
|
|
|
},
|
|
|
|
|
|
|
|
fetch: (params) => {
|
|
|
|
return strapi.query('file', 'upload').findOne(_.pick(params, ['_id', 'id']));
|
|
|
|
},
|
|
|
|
|
|
|
|
fetchAll: (params) => {
|
|
|
|
return strapi.query('file', 'upload').find(strapi.utils.models.convertParams('file', params));
|
|
|
|
},
|
|
|
|
|
2018-02-19 19:54:45 +01:00
|
|
|
count: async (params, source) => {
|
|
|
|
return await strapi.query('file', 'upload').count();
|
|
|
|
},
|
|
|
|
|
2018-02-20 17:10:25 +01:00
|
|
|
remove: async (params, config) => {
|
2018-02-20 15:57:34 +01:00
|
|
|
const file = await strapi.plugins['upload'].services.upload.fetch(params);
|
2018-02-19 16:00:37 +01:00
|
|
|
|
2018-02-21 17:18:33 +01:00
|
|
|
// get upload provider settings to configure the provider to use
|
2018-02-20 17:10:25 +01:00
|
|
|
const provider = _.cloneDeep(_.find(strapi.plugins.upload.config.providers, {provider: config.provider}));
|
|
|
|
_.assign(provider, config);
|
|
|
|
const actions = provider.init(strapi, config);
|
|
|
|
|
2018-02-21 17:18:33 +01:00
|
|
|
// execute delete function of the provider
|
2018-02-20 17:10:25 +01:00
|
|
|
await actions.delete(file);
|
2018-02-19 16:00:37 +01:00
|
|
|
|
2018-02-19 15:41:26 +01:00
|
|
|
// Use Content Manager business logic to handle relation.
|
|
|
|
if (strapi.plugins['content-manager']) {
|
2018-02-19 16:00:37 +01:00
|
|
|
params.model = 'file';
|
|
|
|
params.id = (params._id || params.id);
|
|
|
|
|
|
|
|
await strapi.plugins['content-manager'].services['contentmanager'].delete(params, {source: 'upload'});
|
2018-02-19 15:41:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return strapi.query('file', 'upload').delete(params);
|
2018-02-28 12:33:32 +01:00
|
|
|
},
|
|
|
|
|
2018-02-28 15:49:28 +01:00
|
|
|
uploadToEntity: async function (params, files, source) {
|
|
|
|
// Retrieve provider settings from database.
|
2018-02-28 12:33:32 +01:00
|
|
|
const config = await strapi.store({
|
|
|
|
environment: strapi.config.environment,
|
|
|
|
type: 'plugin',
|
|
|
|
name: 'upload'
|
|
|
|
}).get({ key: 'provider' });
|
|
|
|
|
2018-02-28 15:49:28 +01:00
|
|
|
const model = source && source !== 'content-manager' ?
|
|
|
|
strapi.plugins[source].models[params.model]:
|
|
|
|
strapi.models[params.model];
|
2018-02-28 12:33:32 +01:00
|
|
|
|
2018-02-28 15:49:28 +01:00
|
|
|
// Asynchronous upload.
|
2018-02-28 12:33:32 +01:00
|
|
|
await Promise.all(
|
|
|
|
Object.keys(files)
|
|
|
|
.map(async attribute => {
|
|
|
|
// Bufferize files per attribute.
|
|
|
|
const buffers = await this.bufferize(files[attribute]);
|
|
|
|
const enhancedFiles = buffers.map(file => {
|
2018-02-28 15:49:28 +01:00
|
|
|
const details = model.attributes[attribute];
|
|
|
|
|
2018-02-28 12:33:32 +01:00
|
|
|
// Add related information to be able to make
|
|
|
|
// the relationships later.
|
2018-02-28 15:49:28 +01:00
|
|
|
file[details.via] = [{
|
2018-02-28 12:33:32 +01:00
|
|
|
refId: params.id,
|
|
|
|
ref: params.model,
|
|
|
|
source,
|
|
|
|
field: attribute,
|
|
|
|
}];
|
|
|
|
|
|
|
|
return file;
|
|
|
|
});
|
|
|
|
|
|
|
|
// Make upload async.
|
|
|
|
return this.upload(enhancedFiles, config);
|
|
|
|
})
|
|
|
|
);
|
2018-02-19 14:26:20 +01:00
|
|
|
}
|
2018-02-08 12:01:06 +01:00
|
|
|
};
|