refactor(app/web): new features (#1124) [skip ci]

This commit is contained in:
Simon Lecoq
2022-07-06 04:37:39 +02:00
committed by GitHub
parent 7379fb21a8
commit 130c74b266
80 changed files with 1304 additions and 1103 deletions

View File

@@ -239,7 +239,8 @@ export default async function(
},
//Settings and tokens
{
enabled = false
enabled = false,
extras = false,
} = {}) {
//Plugin execution
try {

View File

@@ -1,9 +1,9 @@
//Setup
export default async function({q, data, imports, account}, {enabled = false} = {}) {
export default async function({q, data, imports, account}, {enabled = false, extras = false} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!enabled) || (!q.fortune))
if ((!enabled) || (!q.fortune) || (!imports.metadata.plugins.fortune.extras("enabled", {extras})))
return null
//Load inputs
@@ -40,6 +40,6 @@ export default async function({q, data, imports, account}, {enabled = false} = {
}
//Handle errors
catch (error) {
throw {error: {message: "An error occured", instance: error}}
throw imports.format.error(error)
}
}

View File

@@ -1,16 +1,16 @@
//Setup
export default async function({q, imports, data, account}, {enabled = false} = {}) {
export default async function({q, imports, data, account}, {enabled = false, extras = false} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!enabled) || (!q.nightscout))
if ((!enabled) || (!q.nightscout) || (!imports.metadata.plugins.nightscout.extras("enabled", {extras})))
return null
//Load inputs
let {url, datapoints, lowalert, highalert, urgentlowalert, urgenthighalert} = imports.metadata.plugins.nightscout.inputs({data, account, q})
if (!url || url === "https://example.herokuapp.com")
throw {error: {message: "Nightscout site URL isn't set!"}}
throw {error: {message: "Nightscout URL is not set"}}
if (url.substring(url.length - 1) !== "/")
url += "/"
if (url.substring(0, 7) === "http://")
@@ -48,9 +48,7 @@ export default async function({q, imports, data, account}, {enabled = false} = {
}
//Handle errors
catch (error) {
if (error.error?.message)
throw error
throw {error: {message: "An error occured", instance: error}}
throw imports.format.error(error)
}
}

View File

@@ -1,9 +1,9 @@
//Setup
export default async function({q, imports, data, account}, {enabled = false, token = ""} = {}) {
export default async function({q, imports, data, account}, {enabled = false, token = "", extras = false} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!enabled) || (!q.poopmap))
if ((!enabled) || (!q.poopmap) || (!imports.metadata.plugins.poopmap.extras("enabled", {extras})))
return null
if (!token)
@@ -32,6 +32,6 @@ export default async function({q, imports, data, account}, {enabled = false, tok
}
//Handle errors
catch (error) {
throw {error: {message: "An error occured", instance: error}}
throw imports.format.error(error)
}
}

View File

@@ -1,15 +1,15 @@
//Setup
export default async function({login, q, imports, data, account}, {enabled = false} = {}) {
export default async function({login, q, imports, data, account}, {enabled = false, extras = false} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!enabled) || (!q.screenshot))
if ((!enabled) || (!q.screenshot) || (!imports.metadata.plugins.screenshot.extras("enabled", {extras})))
return null
//Load inputs
let {url, selector, title, background} = imports.metadata.plugins.screenshot.inputs({data, account, q})
if (!url)
throw {error: {message: "An url is required"}}
throw {error: {message: "URL is not set"}}
//Start puppeteer and navigate to page
console.debug(`metrics/compute/${login}/plugins > screenshot > starting browser`)
@@ -37,8 +37,6 @@ export default async function({login, q, imports, data, account}, {enabled = fal
}
//Handle errors
catch (error) {
if (error.error?.message)
throw error
throw {title: "Screenshot error", error: {message: "An error occured", instance: error}}
throw imports.format.error(error, {title:"Screenshot error"})
}
}

View File

@@ -20,6 +20,8 @@ inputs:
Enable screenshot plugin
type: boolean
default: no
extras:
- metrics.run.puppeteer.scrapping
plugin_screenshot_title:
description: |

View File

@@ -1,17 +1,17 @@
//Setup
export default async function({login, q, imports, data, account}, {enabled = false, token} = {}) {
export default async function({login, q, imports, data, account}, {enabled = false, extras = false, token} = {}) {
//Plugin execution
try {
//Check if plugin is enabled and requirements are met
if ((!enabled) || (!q.stock))
if ((!enabled) || (!q.stock) || (!imports.metadata.plugins.stock.extras("enabled", {extras})))
return null
//Load inputs
let {symbol, interval, duration} = imports.metadata.plugins.stock.inputs({data, account, q})
if (!token)
throw {error: {message: "A token is required"}}
throw {error: {message: "API token is not set"}}
if (!symbol)
throw {error: {message: "A company stock symbol is required"}}
throw {error: {message: "Company stock symbol is not set"}}
symbol = symbol.toLocaleUpperCase()
//Query API for company informations
@@ -48,13 +48,6 @@ export default async function({login, q, imports, data, account}, {enabled = fal
}
//Handle errors
catch (error) {
let message = "An error occured"
if (error.isAxiosError) {
const status = error.response?.status
const description = error.response?.data?.message ?? null
message = `API returned ${status}${description ? ` (${description})` : ""}`
error = error.response?.data ?? null
}
throw {error: {message, instance: error}}
throw imports.format.error(error)
}
}