sorting npm stuff out

This commit is contained in:
NEOLPAR 2022-09-05 15:04:26 +01:00
parent 5ad21ad333
commit 4c47c3a418
3 changed files with 34 additions and 25 deletions

View File

@ -1,11 +1,11 @@
import { ObjectStoreBuckets } from "../../constants" import { ObjectStoreBuckets } from "../../constants"
import { import {
extractPluginTarball, extractPluginTarball,
createNpmPlugin,
createUrlPlugin, createUrlPlugin,
createGithubPlugin, createGithubPlugin,
loadJSFile, loadJSFile,
} from "../../utilities/fileSystem" } from "../../utilities/fileSystem"
import { createNpmPlugin } from "./plugin/utils"
import { getGlobalDB } from "@budibase/backend-core/tenancy" import { getGlobalDB } from "@budibase/backend-core/tenancy"
import { generatePluginID, getPluginParams } from "../../db/utils" import { generatePluginID, getPluginParams } from "../../db/utils"
import { import {
@ -148,7 +148,7 @@ export async function storePlugin(
// TODO: this isn't safe - but we need full node environment // TODO: this isn't safe - but we need full node environment
// in future we should do this in a thread for safety // in future we should do this in a thread for safety
try { try {
//eval(js) eval(js)
} catch (err: any) { } catch (err: any) {
const message = err?.message ? err.message : JSON.stringify(err) const message = err?.message ? err.message : JSON.stringify(err)
throw new Error(`JS invalid: ${message}`) throw new Error(`JS invalid: ${message}`)

View File

@ -0,0 +1,32 @@
const fetch = require("node-fetch")
import { downloadUnzipPlugin } from "../../../utilities/fileSystem"
export const createNpmPlugin = async (url, name = "") => {
let npmTarball = url
let pluginName = name
if (
!npmTarball.includes("https://www.npmjs.com") &&
!npmTarball.includes("https://registry.npmjs.org")
) {
throw "The plugin origin must be from NPM"
}
if (!npmTarball.includes(".tgz")) {
const npmPackageURl = url.replace(
"https://www.npmjs.com/package/",
"https://registry.npmjs.org/"
)
const response = await fetch(npmPackageURl)
if (response.status === 200) {
let npmDetails = await response.json()
pluginName = npmDetails.name
const npmVersion = npmDetails["dist-tags"].latest
npmTarball = npmDetails.versions[npmVersion].dist.tarball
} else {
throw "Cannot get package details"
}
}
return await downloadUnzipPlugin(pluginName, npmTarball)
}

View File

@ -360,29 +360,6 @@ const extractPluginTarball = async (file, ext = ".tar.gz") => {
} }
exports.extractPluginTarball = extractPluginTarball exports.extractPluginTarball = extractPluginTarball
exports.createNpmPlugin = async (url, name = "") => {
let npmTarball = url
let pluginName = name
if (!npmTarball.includes(".tgz")) {
const npmPackageURl = url.replace(
"https://www.npmjs.com/package/",
"https://registry.npmjs.org/"
)
const response = await fetch(npmPackageURl)
if (response.status === 200) {
let npmDetails = await response.json()
pluginName = npmDetails.name
const npmVersion = npmDetails["dist-tags"].latest
npmTarball = npmDetails.versions[npmVersion].dist.tarball
} else {
throw "Cannot get package details"
}
}
return await downloadUnzipPlugin(pluginName, npmTarball)
}
exports.createUrlPlugin = async (url, name = "", headers = {}) => { exports.createUrlPlugin = async (url, name = "", headers = {}) => {
if (!url.includes(".tgz") && !url.includes(".tar.gz")) { if (!url.includes(".tgz") && !url.includes(".tar.gz")) {
throw new Error("Plugin must be compressed into a gzipped tarball.") throw new Error("Plugin must be compressed into a gzipped tarball.")