spee.ch/routes/api-routes.js

264 lines
11 KiB
JavaScript
Raw Normal View History

const logger = require('winston');
const multipart = require('connect-multiparty');
const { files, site } = require('../config/speechConfig.js');
const multipartMiddleware = multipart({uploadDir: files.uploadDirectory});
2017-09-28 11:42:29 -07:00
const db = require('../models');
const { checkClaimNameAvailability, checkChannelAvailability, publish } = require('../controllers/publishController.js');
2017-11-20 15:51:05 -08:00
const { getClaimList, resolveUri, getClaim } = require('../helpers/lbryApi.js');
2018-01-23 12:08:53 -08:00
const { createPublishParams, parsePublishApiRequestBody, parsePublishApiRequestFiles, parsePublishApiChannel, addGetResultsToFileData, createFileData, returnPublishTimingActionType } = require('../helpers/publishHelpers.js');
2017-08-02 17:13:02 -07:00
const errorHandlers = require('../helpers/errorHandlers.js');
2018-01-22 16:14:05 -08:00
const { sendGoogleAnalyticsTiming } = require('../helpers/statsHelpers.js');
2017-12-15 10:26:51 -08:00
const { authenticateIfNoUserToken } = require('../auth/authentication.js');
const { getChannelData, getChannelClaims, getClaimId } = require('../controllers/serveController.js');
const NO_CHANNEL = 'NO_CHANNEL';
const NO_CLAIM = 'NO_CLAIM';
2017-09-20 14:39:20 -07:00
module.exports = (app) => {
2018-02-06 21:55:04 -08:00
// route to check whether site has published to a channel
app.get('/api/channel/availability/:name', ({ params }, res) => {
checkChannelAvailability(params.name)
.then(result => {
2018-02-06 21:55:04 -08:00
if (result === true) {
res.status(200).json(true);
} else {
res.status(200).json(false);
}
2018-02-06 21:55:04 -08:00
})
.catch(error => {
res.status(500).json(error);
});
});
// route to get a short channel id from long channel Id
app.get('/api/channel/short-id/:longId/:name', ({ ip, originalUrl, params }, res) => {
db.Certificate.getShortChannelIdFromLongChannelId(params.longId, params.name)
.then(shortId => {
logger.debug('sending back short channel id', shortId);
res.status(200).json(shortId);
})
.catch(error => {
logger.error('api error getting short channel id', error);
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
app.get('/api/channel/data/:channelName/:channelClaimId', ({ ip, originalUrl, body, params }, res) => {
const channelName = params.channelName;
let channelClaimId = params.channelClaimId;
if (channelClaimId === 'none') channelClaimId = null;
getChannelData(channelName, channelClaimId, 0) // getChannelViewData(channelName, channelId, 0)
.then(data => {
if (data === NO_CHANNEL) {
return res.status(200).json({success: false, message: 'No matching channel was found'});
}
res.status(200).json({success: true, data});
})
.catch(error => {
logger.error('api error getting channel contents', error);
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
app.get('/api/channel/claims/:channelName/:channelClaimId/:page', ({ ip, originalUrl, body, params }, res) => {
const channelName = params.channelName;
let channelClaimId = params.channelClaimId;
if (channelClaimId === 'none') channelClaimId = null;
const page = params.page;
getChannelClaims(channelName, channelClaimId, page)// getChannelViewData(channelName, channelClaimId, page)
.then(data => {
if (data === NO_CHANNEL) {
return res.status(200).json({success: false, message: 'No matching channel was found'});
}
res.status(200).json({success: true, data});
})
.catch(error => {
logger.error('api error getting channel contents', error);
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
// route to run a claim_list request on the daemon
app.get('/api/claim/list/:name', ({ ip, originalUrl, params }, res) => {
getClaimList(params.name)
.then(claimsList => {
res.status(200).json(claimsList);
})
.catch(error => {
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
2017-11-20 15:51:05 -08:00
// route to get an asset
2018-02-06 21:55:04 -08:00
app.get('/api/claim/get/:name/:claimId', ({ ip, originalUrl, params }, res) => {
2017-11-29 15:36:23 -08:00
const name = params.name;
const claimId = params.claimId;
// resolve the claim
2017-11-29 15:36:23 -08:00
db.Claim.resolveClaim(name, claimId)
2017-11-21 12:53:43 -08:00
.then(resolveResult => {
// make sure a claim actually exists at that uri
2017-11-21 12:53:43 -08:00
if (!resolveResult) {
throw new Error('No matching uri found in Claim table');
}
let fileData = createFileData(resolveResult);
// get the claim
2017-11-29 15:36:23 -08:00
return Promise.all([fileData, getClaim(`${name}#${claimId}`)]);
2017-11-21 12:53:43 -08:00
})
.then(([ fileData, getResult ]) => {
fileData = addGetResultsToFileData(fileData, getResult);
2017-11-29 15:36:23 -08:00
return Promise.all([db.upsert(db.File, fileData, {name, claimId}, 'File'), getResult]);
2017-11-21 12:53:43 -08:00
})
.then(([ fileRecord, {message, completed} ]) => {
res.status(200).json({ success: true, message, completed });
2017-11-20 15:51:05 -08:00
})
.catch(error => {
errorHandlers.handleApiError(originalUrl, ip, error, res);
2017-11-20 15:51:05 -08:00
});
});
// route to check whether this site published to a claim
2018-02-06 21:55:04 -08:00
app.get('/api/claim/availability/:name', ({ params }, res) => {
2017-09-19 12:54:23 -07:00
checkClaimNameAvailability(params.name)
2017-09-19 08:47:24 -07:00
.then(result => {
if (result === true) {
res.status(200).json(true);
} else {
res.status(200).json(false);
}
})
.catch(error => {
res.status(500).json(error);
});
});
// route to run a resolve request on the daemon
2018-02-06 21:55:04 -08:00
app.get('/api/claim/resolve/:name/:claimId', ({ headers, ip, originalUrl, params }, res) => {
2018-01-30 15:32:42 -08:00
resolveUri(`${params.name}#${params.claimId}`)
2018-02-06 21:55:04 -08:00
.then(resolvedUri => {
res.status(200).json(resolvedUri);
})
.catch(error => {
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
// route to run a publish request on the daemon
2018-02-06 21:55:04 -08:00
app.post('/api/claim/publish', multipartMiddleware, ({ body, files, headers, ip, originalUrl, user }, res) => {
2017-12-15 11:02:04 -08:00
logger.debug('api/claim-publish body:', body);
2017-12-15 14:10:34 -08:00
logger.debug('api/claim-publish files:', files);
2018-01-23 12:08:53 -08:00
// record the start time of the request and create variable for storing the action type
2018-01-22 20:09:28 -08:00
const publishStartTime = Date.now();
logger.debug('publish request started @', publishStartTime);
2018-01-23 12:08:53 -08:00
let timingActionType;
// define variables
2017-12-15 10:26:51 -08:00
let name, fileName, filePath, fileType, nsfw, license, title, description, thumbnail, channelName, channelPassword;
// validate the body and files of the request
2017-07-07 16:08:35 -07:00
try {
// validateApiPublishRequest(body, files);
({name, nsfw, license, title, description, thumbnail} = parsePublishApiRequestBody(body));
({fileName, filePath, fileType} = parsePublishApiRequestFiles(files));
2017-12-15 10:26:51 -08:00
({channelName, channelPassword} = parsePublishApiChannel(body, user));
2017-07-07 16:08:35 -07:00
} catch (error) {
2017-12-15 14:10:34 -08:00
logger.debug('publish request rejected, insufficient request parameters', error);
return res.status(400).json({success: false, message: error.message});
}
// check channel authorization
2017-12-15 10:26:51 -08:00
authenticateIfNoUserToken(channelName, channelPassword, user)
2018-02-06 21:55:04 -08:00
.then(authenticated => {
if (!authenticated) {
throw new Error('Authentication failed, you do not have access to that channel');
}
// make sure the claim name is available
return checkClaimNameAvailability(name);
})
.then(result => {
if (!result) {
throw new Error('That name is already claimed by another user.');
}
// create publish parameters object
return createPublishParams(filePath, name, title, description, license, nsfw, thumbnail, channelName);
})
.then(publishParams => {
// set the timing event type for reporting
timingActionType = returnPublishTimingActionType(publishParams.channel_name);
// publish the asset
return publish(publishParams, fileName, fileType);
})
.then(result => {
res.status(200).json({
success: true,
message: 'publish completed successfully',
data : {
name,
claimId: result.claim_id,
url : `${site.host}/${result.claim_id}/${name}`,
lbryTx : result,
},
});
// log the publish end time
const publishEndTime = Date.now();
logger.debug('publish request completed @', publishEndTime);
sendGoogleAnalyticsTiming(timingActionType, headers, ip, originalUrl, publishStartTime, publishEndTime);
})
.catch(error => {
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
2017-09-28 11:42:29 -07:00
// route to get a short claim id from long claim Id
2018-02-06 21:55:04 -08:00
app.get('/api/claim/short-id/:longId/:name', ({ params }, res) => {
2017-11-03 17:10:08 -07:00
db.Claim.getShortClaimIdFromLongClaimId(params.longId, params.name)
2017-09-28 11:42:29 -07:00
.then(shortId => {
2018-02-04 17:43:02 -08:00
res.status(200).json({success: true, data: shortId});
2017-09-28 11:42:29 -07:00
})
.catch(error => {
logger.error('api error getting short channel id', error);
2018-02-04 17:43:02 -08:00
res.status(200).json({success: false, message: error.message});
2017-09-28 11:42:29 -07:00
});
});
app.post('/api/claim/long-id', ({ ip, originalUrl, body, params }, res) => {
logger.debug('body:', body);
const channelName = body.channelName;
const channelClaimId = body.channelClaimId;
const claimName = body.claimName;
const claimId = body.claimId;
getClaimId(channelName, channelClaimId, claimName, claimId)
.then(result => {
if (result === NO_CHANNEL) {
return res.status(200).json({success: false, message: 'No matching channel could be found'});
}
if (result === NO_CLAIM) {
2018-01-30 15:32:42 -08:00
return res.status(200).json({success: false, message: 'No matching claim id could be found'});
}
2018-02-04 17:43:02 -08:00
res.status(200).json({success: true, data: result});
2018-01-30 15:32:42 -08:00
})
.catch(error => {
logger.error('api error getting long claim id', error);
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
2018-02-06 21:55:04 -08:00
app.get('/api/claim/data/:claimName/:claimId', ({ ip, originalUrl, body, params }, res) => {
2018-01-30 15:32:42 -08:00
const claimName = params.claimName;
let claimId = params.claimId;
if (claimId === 'none') claimId = null;
db.Claim.resolveClaim(claimName, claimId)
.then(claimInfo => {
if (!claimInfo) {
return res.status(200).json({success: false, message: 'No claim could be found'});
}
res.status(200).json({success: true, data: claimInfo});
2018-01-30 15:32:42 -08:00
})
.catch(error => {
logger.error('api error getting long claim id', error);
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
2018-02-06 21:55:04 -08:00
// route to see if asset is available locally
app.get('/api/file/availability/:name/:claimId', ({ ip, originalUrl, params }, res) => {
const name = params.name;
const claimId = params.claimId;
let isAvailable = false;
db.File.findOne({where: {name, claimId}})
.then(result => {
if (result) {
isAvailable = true;
}
res.status(200).json({success: true, data: isAvailable});
})
.catch(error => {
errorHandlers.handleApiError(originalUrl, ip, error, res);
});
});
};