Api post route #41
5 changed files with 21 additions and 30 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +1,2 @@
|
||||||
node_modules
|
node_modules
|
||||||
|
ApiPublishTest.html
|
|
@ -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;
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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'});
|
|
||||||
// }
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
|
@ -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ω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>
|
|
Loading…
Add table
Reference in a new issue