spee.ch/routes/api-routes.js

93 lines
3.5 KiB
JavaScript
Raw Normal View History

const logger = require('winston');
const multipart = require('connect-multiparty');
const multipartMiddleware = multipart();
2017-06-26 19:43:35 +02:00
const publishController = require('../controllers/publishController.js');
2017-08-03 02:13:02 +02:00
const lbryApi = require('../helpers/lbryApi.js');
const { createPublishParams, validateFile } = require('../helpers/publishHelpers.js');
const errorHandlers = require('../helpers/errorHandlers.js');
2017-06-30 07:26:29 +02:00
const { postToStats, sendGoogleAnalytics } = require('../controllers/statsController.js');
module.exports = (app, hostedContentPath) => {
// route to run a claim_list request on the daemon
2017-07-06 03:26:33 +02:00
app.get('/api/claim_list/:name', ({ headers, ip, originalUrl, params }, res) => {
2017-06-30 02:10:14 +02:00
// google analytics
2017-07-06 03:26:33 +02:00
sendGoogleAnalytics('serve', headers, ip, originalUrl);
2017-06-30 02:10:14 +02:00
// serve the content
lbryApi
2017-07-03 23:48:35 +02:00
.getClaimsList(params.name)
.then(claimsList => {
2017-07-13 00:30:31 +02:00
postToStats('serve', originalUrl, ip, null, null, 'success');
res.status(200).json(claimsList);
})
.catch(error => {
2017-06-28 07:41:48 +02:00
errorHandlers.handleRequestError('publish', originalUrl, ip, error, res);
});
});
2017-07-03 23:48:35 +02:00
// route to check whether spee.ch has published to a claim
app.get('/api/isClaimAvailable/:name', ({ ip, originalUrl, params }, res) => {
// send response
publishController
.checkNameAvailability(params.name)
.then(result => {
if (result === true) {
2017-07-03 23:48:35 +02:00
res.status(200).json(true);
} else {
logger.debug(`Rejecting publish request because ${params.name} has already been published via spee.ch`);
res.status(200).json(false);
2017-07-03 23:48:35 +02:00
}
})
.catch(error => {
res.status(500).json(error);
});
});
// route to run a resolve request on the daemon
2017-07-06 03:26:33 +02:00
app.get('/api/resolve/:uri', ({ headers, ip, originalUrl, params }, res) => {
2017-06-30 02:10:14 +02:00
// google analytics
2017-07-06 03:26:33 +02:00
sendGoogleAnalytics('serve', headers, ip, originalUrl);
2017-06-30 02:10:14 +02:00
// serve content
lbryApi
.resolveUri(params.uri)
.then(resolvedUri => {
2017-07-13 00:30:31 +02:00
postToStats('serve', originalUrl, ip, null, null, 'success');
res.status(200).json(resolvedUri);
})
.catch(error => {
2017-06-28 07:41:48 +02:00
errorHandlers.handleRequestError('publish', originalUrl, ip, error, res);
});
});
2017-07-08 01:08:35 +02:00
// route to run a publish request on the daemon
2017-07-06 03:26:33 +02:00
app.post('/api/publish', multipartMiddleware, ({ body, files, headers, ip, originalUrl }, res) => {
2017-06-30 02:10:14 +02:00
// google analytics
2017-07-06 03:26:33 +02:00
sendGoogleAnalytics('publish', headers, ip, originalUrl);
2017-06-27 04:39:12 +02:00
// validate that a file was provided
const file = files.speech || files.null;
const name = body.name || file.name.substring(0, file.name.indexOf('.'));
2017-06-26 19:43:35 +02:00
const license = body.license || 'No License Provided';
const nsfw = body.nsfw || true;
2017-07-08 01:08:35 +02:00
try {
validateFile(file, name, license, nsfw);
} catch (error) {
2017-07-13 00:30:31 +02:00
postToStats('publish', originalUrl, ip, null, null, error.message);
2017-07-08 01:08:35 +02:00
logger.debug('rejected >>', error.message);
res.status(400).send(error.message);
return;
}
2017-07-08 01:08:35 +02:00
// prepare the publish parameters
2017-06-26 19:43:35 +02:00
const fileName = file.name;
const filePath = file.path;
const fileType = file.type;
2017-07-08 01:08:35 +02:00
const publishParams = createPublishParams(name, filePath, license, nsfw);
// publish the file
publishController
.publish(publishParams, fileName, fileType)
.then(result => {
2017-07-13 00:30:31 +02:00
postToStats('publish', originalUrl, ip, null, null, 'success');
res.status(200).json(result);
})
.catch(error => {
2017-06-28 07:41:48 +02:00
errorHandlers.handleRequestError('publish', originalUrl, ip, error, res);
});
});
};