const axios = require('axios'); const logger = require('winston'); module.exports = { publishClaim (publishParams) { logger.debug(`Publishing claim to "${publishParams.name}"`); const deferred = new Promise((resolve, reject) => { axios .post('http://localhost:5279/lbryapi', { method: 'publish', params: publishParams, }) .then(response => { const result = response.data.result; resolve(result); }) .catch(error => { reject(error); }); }); return deferred; }, getClaim (uri) { logger.debug(`Getting Claim for "${uri}"`); const deferred = new Promise((resolve, reject) => { axios .post('http://localhost:5279/lbryapi', { method: 'get', params: { uri, timeout: 30 }, }) .then(({ data }) => { // check to make sure the daemon didn't just time out if (!data.result) { reject(JSON.stringify(data)); } if (data.result.error) { reject(data.result.error); } /* note: put in a check to make sure we do not resolve until the download is actually complete (response.data.completed === true) */ resolve(data.result); }) .catch(error => { reject(error); }); }); return deferred; }, getClaimsList (claimName) { logger.debug(`Getting Claim List for "${claimName}"`); const deferred = new Promise((resolve, reject) => { axios .post('http://localhost:5279/lbryapi', { method: 'claim_list', params: { name: claimName }, }) .then(({ data }) => { resolve(data.result); }) .catch(error => { reject(error); }); }); return deferred; }, resolveUri (uri) { logger.debug(`Resolving URI for "${uri}"`); const deferred = new Promise((resolve, reject) => { axios .post('http://localhost:5279/lbryapi', { method: 'resolve', params: { uri }, }) .then(({ data }) => { // check for errors if (data.result[uri].error) { reject(data.result[uri].error); return; } resolve(data.result); }) .catch(error => { reject(error); }); }); return deferred; }, };