2023-12-07 14:43:38 +02:00
|
|
|
import validatePluginId from '@joplin/lib/services/plugins/utils/validatePluginId';
|
|
|
|
import validatePluginVersion from '@joplin/lib/services/plugins/utils/validatePluginVersion';
|
|
|
|
import checkIfPluginCanBeAdded from './checkIfPluginCanBeAdded';
|
|
|
|
|
|
|
|
// Assumes that
|
|
|
|
// 1. manifest._npm_package_name is correct,
|
|
|
|
// 2. other fields were set by the plugin author and are thus untrusted.
|
|
|
|
const validateUntrustedManifest = (manifest: any, existingManifests: any) => {
|
|
|
|
// At this point, we need to check the manifest ID as it's used in various
|
|
|
|
// places including as directory name and object key in manifests.json, so
|
|
|
|
// it needs to be correct. It's mostly for security reasons. The other
|
|
|
|
// manifest properties are checked when the plugin is loaded into the app.
|
|
|
|
validatePluginId(manifest.id);
|
|
|
|
validatePluginVersion(manifest.version);
|
|
|
|
|
2023-12-22 13:31:57 +02:00
|
|
|
// This prevents a plugin author from marking their own plugin as _recommended.
|
2023-12-07 14:43:38 +02:00
|
|
|
if (typeof manifest._recommended !== 'undefined') {
|
|
|
|
throw new Error(`Plugin ${manifest.id} cannot mark itself as recommended.`);
|
|
|
|
}
|
|
|
|
|
|
|
|
checkIfPluginCanBeAdded(existingManifests, manifest);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default validateUntrustedManifest;
|