spee.ch/helpers/publishHelpers.js

149 lines
4.6 KiB
JavaScript
Raw Normal View History

const logger = require('winston');
const config = require('config');
const fs = require('fs');
2017-08-16 11:00:17 -07:00
const db = require('../models');
module.exports = {
2017-07-07 16:08:35 -07:00
validateFile (file, name, license, nsfw) {
if (!file) {
throw new Error('No file was submitted or the key used was incorrect. Files posted through this route must use a key of "speech" or null');
}
// check file type and size
switch (file.type) {
case 'image/jpeg':
case 'image/png':
case 'image/gif':
2017-07-31 10:14:27 -07:00
if (file.size > 50000000) {
throw new Error('Your image exceeds the 50 megabyte limit.');
2017-07-07 16:08:35 -07:00
}
break;
case 'video/mp4':
if (file.size > 50000000) {
throw new Error('Your video exceeds the 50 megabyte limit.');
}
break;
default:
throw new Error('The ' + file.Type + ' content type is not supported. Only, .jpeg, .png, .gif, and .mp4 files are currently supported.');
}
// validate claim name
const invalidCharacters = /[^A-Za-z0-9,-]/.exec(name);
2017-07-07 16:08:35 -07:00
if (invalidCharacters) {
2017-09-25 11:55:56 -07:00
throw new Error('The url name you provided is not allowed. Only the following characters are allowed: A-Z, a-z, 0-9, and "-"');
2017-07-07 16:08:35 -07:00
}
// validate license
2017-09-21 16:03:45 -07:00
if ((license.indexOf('Public Domain') === -1) && (license.indexOf('Creative Commons') === -1)) {
throw new Error('Only posts with a "Public Domain" license, or one of the Creative Commons licenses are eligible for publishing through spee.ch');
2017-07-07 16:08:35 -07:00
}
switch (nsfw) {
case true:
case false:
case 'true':
case 'false':
case 'on':
case 'off':
case 0:
case '0':
case 1:
case '1':
break;
default:
throw new Error('NSFW value was not accepted. NSFW must be set to either true, false, "on", or "off"');
}
},
2017-09-21 09:18:19 -07:00
createPublishParams (name, filePath, title, description, license, nsfw, channel) {
logger.debug(`Creating Publish Parameters for "${name}"`);
const claimAddress = config.get('WalletConfig.LbryClaimAddress');
2017-09-21 16:03:45 -07:00
const defaultChannel = config.get('WalletConfig.DefaultChannel');
2017-06-29 12:35:36 -07:00
// filter nsfw and ensure it is a boolean
2017-06-26 19:39:12 -07:00
if (nsfw === false) {
nsfw = false;
2017-09-28 10:51:02 -07:00
} else if (typeof nsfw === 'string') {
if (nsfw.toLowerCase === 'false' || nsfw.toLowerCase === 'off' || nsfw === '0') {
nsfw = false;
}
} else if (nsfw === 0) {
nsfw = false;
} else {
nsfw = true;
2017-06-26 15:01:41 -07:00
}
2017-08-20 16:56:37 -07:00
// provide defaults for title & description
2017-09-28 10:51:02 -07:00
if (title === null || title === '') {
2017-08-20 16:56:37 -07:00
title = name;
}
2017-09-28 10:51:02 -07:00
if (description === null || description.trim() === '') {
2017-08-20 16:56:37 -07:00
description = `${name} published via spee.ch`;
}
// create the publish params
const publishParams = {
name,
file_path: filePath,
bid : 0.01,
metadata : {
2017-08-20 16:56:37 -07:00
description,
title,
author : 'spee.ch',
language: 'en',
license,
nsfw,
},
claim_address: claimAddress,
};
2017-09-21 16:03:45 -07:00
// add channel if applicable
2017-09-21 16:03:58 -07:00
if (channel !== 'none') {
2017-09-21 16:03:45 -07:00
publishParams['channel_name'] = channel;
} else {
publishParams['channel_name'] = defaultChannel;
}
logger.debug('publishParams:', publishParams);
return publishParams;
},
deleteTemporaryFile (filePath) {
fs.unlink(filePath, err => {
if (err) throw err;
logger.debug(`successfully deleted ${filePath}`);
});
},
2017-09-19 12:54:23 -07:00
checkClaimNameAvailability (name) {
2017-08-16 11:00:17 -07:00
return new Promise((resolve, reject) => {
// find any records where the name is used
db.File.findAll({ where: { name } })
.then(result => {
if (result.length >= 1) {
const claimAddress = config.get('WalletConfig.LbryClaimAddress');
// filter out any results that were not published from spee.ch's wallet address
const filteredResult = result.filter((claim) => {
return (claim.address === claimAddress);
2017-08-16 11:00:17 -07:00
});
// return based on whether any non-spee.ch claims were left
if (filteredResult.length >= 1) {
resolve(false);
} else {
resolve(true);
}
2017-08-16 11:00:17 -07:00
} else {
resolve(true);
}
})
.catch(error => {
reject(error);
});
});
},
2017-09-19 08:47:24 -07:00
checkChannelAvailability (name) {
return new Promise((resolve, reject) => {
// find any records where the name is used
2017-09-25 21:03:43 -07:00
db.Channel.findAll({ where: { channelName: name } })
2017-09-19 08:47:24 -07:00
.then(result => {
if (result.length >= 1) {
2017-09-19 12:54:23 -07:00
return resolve(false);
2017-09-19 08:47:24 -07:00
}
2017-09-19 12:54:23 -07:00
resolve(true);
2017-09-19 08:47:24 -07:00
})
.catch(error => {
reject(error);
});
});
},
};