port resolve call to lbrytv

This commit is contained in:
Niko Storni 2019-09-23 19:27:04 +02:00
parent 777d9f0f83
commit d5932ce67c
4 changed files with 139 additions and 75 deletions

62
app/helpers/lbrytv-sdk.js Normal file
View file

@ -0,0 +1,62 @@
"use strict";
const request = require("request");
import messageSlack from "./slack";
let addSupport = function() {
return;
};
let publish = function() {
return;
};
let resolve = function(urls) {
return new Promise(function(resolve, reject) {
let options = {
method: "POST",
url: "https://api.lbry.tv/api/proxy",
headers:
{
"Content-Type": "application/json"
},
body: {
method: "resolve",
params: { urls: urls }
},
json: true
};
request(options, function(error, response, daemonResponse) {
if (error) {
messageSlack({
message: "```" + error + "```",
title: "DAEMON ERROR: resolve"
});
return reject("DAEMON ERROR: resolve");
}
if (Object.prototype.hasOwnProperty.call(daemonResponse,"error")) {
messageSlack({
message: "```" + daemonResponse.error + "```",
title: "DAEMON ERROR: resolve"
});
return reject("DAEMON ERROR: resolve");
} else
return resolve(daemonResponse.result);
});
});
};
let getTrending = function() {
return;
};
export default {
addSupport,
publish,
resolve,
getTrending
};

View file

@ -4,7 +4,7 @@
// P A C K A G E S
import color from "colorette";
import * as color from "colorette";
import compress from "fastify-compress";
import cors from "cors";
import fastify from "fastify";

View file

@ -11,6 +11,7 @@ import html from "choo/html";
import apiPage from "~view/api";
import fetchMetadata from "~helper/fetch-metadata";
import lbrytvAPI from "~helper/lbrytv-sdk";
import { generateGitHubFeed } from "~helper/github";
import messageSlack from "~helper/slack";
import { URL } from "url";
@ -117,7 +118,8 @@ export default async(socket, action) => {
function generateContent(exampleNumber, displayTrendingContent) {
if (exampleNumber === 1) {
return getTrendingContent().then(response => {
return getTrendingContent()
.then(response => {
if (!response || !response.success || response.success !== true || !response.data)
return "";
@ -193,20 +195,17 @@ function generateContent(exampleNumber, displayTrendingContent) {
"minecraft-in-real-life-iron-man#758dd6497cdfc401ae1f25984738d024d47b50af",
"ethan-shows-kyle-warframe-skyvault#8a7401b88d5ed0376d98f16808194d4dcb05b284"
];
const rawContentCollection = [];
const renderedContentCollection = [];
for (const url of approvedUrls)
rawContentCollection.push(fetchMetadata({ claim: url, method: "resolve", example: 1 }));
lbrytvAPI.resolve(approvedUrls)
.then(resolveResponse => {
if (resolveResponse != null) {
let responses = Object.values(resolveResponse);
return Promise.all(rawContentCollection).then(collection => {
for (const part of collection) {
if (
part &&
part.value &&
part.value.thumbnail.url
) {
for (let r in responses) {
let part = responses[r];
if (part.value && part.value.thumbnail.url) {
renderedContentCollection.push(`
<section class="playground-content__trend">
<figure
@ -228,14 +227,16 @@ function generateContent(exampleNumber, displayTrendingContent) {
`);
}
}
}
renderedContentCollection.push(`
<script>
document.getElementById("playground-example-description").innerHTML = document.querySelector("[data-action='playground, example 3']").dataset.description
</script>
`);
displayTrendingContent(renderedContentCollection.join(""));
})
.catch(error => {
console.error(error);
});
}
}

View file

@ -44,7 +44,8 @@
"redis": "^2.8.0",
"slack-node": "^0.1.8",
"socket.io": "^2.2.0",
"stringify-object": "^3.3.0"
"stringify-object": "^3.3.0",
"request": "latest"
},
"description": "Documentation for the LBRY protocol and associated projects",
"devDependencies": {