Api post route #41

Merged
bones7242 merged 6 commits from api-post-route into master 2017-06-27 02:24:42 +02:00
5 changed files with 21 additions and 30 deletions
Showing only changes of commit 6170be4978 - Show all commits

3
.gitignore vendored
View file

@ -1 +1,2 @@
node_modules node_modules
ApiPublishTest.html

View file

@ -46,14 +46,22 @@ module.exports = {
nsfw : publishParams.metadata.nsfw, nsfw : publishParams.metadata.nsfw,
}, },
{ name: publishParams.name, claimId: result.claim_id } { name: publishParams.name, claimId: result.claim_id }
).catch(error => { ).then(() => {
// resolve the promise with the result from lbryApi.publishClaim;
resolve(result);
})
.catch(error => {
logger.error('Sequelize findOne error', error); logger.error('Sequelize findOne error', error);
// reject the promise
reject(error);
}); });
}) })
.catch(error => { .catch(error => {
logger.error(`Error publishing ${fileName}`, error); logger.error(`Error publishing ${fileName}`, error);
// delete the local file // delete the local file
deleteTemporaryFile(publishParams.file_path); deleteTemporaryFile(publishParams.file_path);
// reject the promise
reject(error);
}); });
}); });
return deferred; return deferred;

View file

@ -6,6 +6,14 @@ const walletAddress = config.get('WalletConfig.LbryAddress');
module.exports = { module.exports = {
createPublishParams (name, filePath, license, nsfw) { createPublishParams (name, filePath, license, nsfw) {
logger.debug(`Creating Publish Parameters for "${name}"`); logger.debug(`Creating Publish Parameters for "${name}"`);
// ensure nsfw is a boolean
if (nsfw.toLowerCase === 'true') {
nsfw = true;
} else if (nsfw.toLowerCase === 'on') {
nsfw = true;
} else {
nsfw = false;
}
const publishParams = { const publishParams = {
name, name,
file_path: filePath, file_path: filePath,

View file

@ -34,11 +34,9 @@ module.exports = app => {
// route to run a publish request on the daemon // route to run a publish request on the daemon
app.post('/api/publish', multipartMiddleware, ({ originalUrl, body, files }, res) => { app.post('/api/publish', multipartMiddleware, ({ originalUrl, body, files }, res) => {
logger.debug(`POST request on ${originalUrl}`); logger.debug(`POST request on ${originalUrl}`);
console.log('>> req.files:', files); const file = files.file1 || files.null;
console.log('>> req.body:', body);
const file = files.file1;
if (!file) { if (!file) {
res.status(500).json({ 'error': 'No file was submitted. Form submission must have key "speechFile"' }); res.status(500).json({ 'success': false, 'error': 'No file was submitted. Form submission must have key "speechFile"', 'data': null });
return; return;
} }
const name = body.claim || file.name.substring(0, file.name.indexOf('.')); const name = body.claim || file.name.substring(0, file.name.indexOf('.'));
@ -52,7 +50,6 @@ module.exports = app => {
*/ */
// prepare the publish parameters // prepare the publish parameters
const publishParams = publishHelpers.createPublishParams(name, filePath, license, nsfw); const publishParams = publishHelpers.createPublishParams(name, filePath, license, nsfw);
console.log('publish params', publishParams);
// publish the file // publish the file
publishController publishController
.publish(publishParams, fileName, fileType) .publish(publishParams, fileName, fileType)
@ -62,11 +59,5 @@ module.exports = app => {
.catch(error => { .catch(error => {
errorHandlers.handleRequestError(error, res); errorHandlers.handleRequestError(error, res);
}); });
// if (files) {
// res.status(200).json({'status': 'file(s) received'});
// } else {
// res.status(400).josn({'status': 'no files(s) received'});
// }
}); });
}; };

View file

@ -1,17 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8"/>
<title>upload</title>
</head>
<body>
<form action="http://localhost:3000/api/publish" method="post" enctype="multipart/form-data">
<p><input type="text" name="text1" value="text default">
<p><input type="text" name="text2" value="a&#x03C9;b">
<p><input type="file" name="file1">
<p><input type="file" name="file2">
<p><input type="file" name="file3">
<p><button type="submit">Submit</button>
</form>
</body>
</html>