blob: 2fd6d2730de35a9ec1e915c271cb0d89634c6d7c [file] [log] [blame]
/**
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
*/
const fs = require('node:fs');
const path = require('node:path');
const execa = require('execa');
const PluginInfoProvider = require('cordova-common').PluginInfoProvider;
const events = require('cordova-common').events;
const CordovaError = require('cordova-common').CordovaError;
const fetch = require('cordova-fetch');
module.exports.getInstalledPlugins = getInstalledPlugins;
module.exports.mergeVariables = mergeVariables;
module.exports.info = info;
function getInstalledPlugins (projectRoot) {
const pluginsDir = path.join(projectRoot, 'plugins');
// TODO: This should list based off of platform.json, not directories within plugins/
const pluginInfoProvider = new PluginInfoProvider();
return pluginInfoProvider.getAllWithinSearchPath(pluginsDir);
}
/*
* Merges cli and config.xml variables.
*
* @param {object} pluginInfo
* @param {object} config.xml
* @param {object} options
*
* @return {object} object containing the new merged variables
*/
function mergeVariables (pluginInfo, cfg, opts) {
// Validate top-level required variables
const pluginVariables = pluginInfo.getPreferences();
opts.cli_variables = opts.cli_variables || {};
const pluginEntry = cfg.getPlugin(pluginInfo.id);
// Get variables from config.xml
const configVariables = pluginEntry ? pluginEntry.variables : {};
// Add config variable if it's missing in cli_variables
Object.keys(configVariables).forEach(function (variable) {
opts.cli_variables[variable] = opts.cli_variables[variable] || configVariables[variable];
});
const missingVariables = Object.keys(pluginVariables)
.filter(function (variableName) {
// discard variables with default value
return !(pluginVariables[variableName] || opts.cli_variables[variableName]);
});
if (missingVariables.length) {
events.emit('verbose', 'Removing ' + pluginInfo.dir + ' because mandatory plugin variables were missing.');
fs.rmSync(pluginInfo.dir, { recursive: true, force: true });
const msg = 'Variable(s) missing (use: --variable ' + missingVariables.join('=value --variable ') + '=value).';
throw new CordovaError(msg);
}
return opts.cli_variables;
}
function info (plugin) {
const viewArgs = ['view'];
plugin = plugin.shift();
viewArgs.push(plugin);
viewArgs.push('--json');
// check if npm is installed
return fetch.isNpmInstalled()
.then(function () {
return execa('npm', viewArgs)
.then(({ stdout: info }) => {
const pluginInfo = JSON.parse(info);
return pluginInfo;
});
});
}