sorting npm stuff out
This commit is contained in:
parent
5ad21ad333
commit
4c47c3a418
|
@ -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}`)
|
||||||
|
|
|
@ -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)
|
||||||
|
}
|
|
@ -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.")
|
||||||
|
|
Loading…
Reference in New Issue