2024-06-25 05:59:59 -07:00
|
|
|
import Setting from '../../models/Setting';
|
|
|
|
import BasePluginRunner from '../plugins/BasePluginRunner';
|
|
|
|
import PluginService, { PluginSettings } from '../../services/plugins/PluginService';
|
2024-03-11 08:02:15 -07:00
|
|
|
import { Store } from 'redux';
|
|
|
|
import Logger from '@joplin/utils/Logger';
|
2024-06-25 05:59:59 -07:00
|
|
|
import shim from '../../shim';
|
|
|
|
import { State as AppState } from '../../reducer';
|
|
|
|
import BasePlatformImplementation from './BasePlatformImplementation';
|
2024-03-11 08:02:15 -07:00
|
|
|
|
|
|
|
const logger = Logger.create('loadPlugins');
|
|
|
|
|
|
|
|
type CancelEvent = { cancelled: boolean };
|
|
|
|
|
2024-06-10 23:40:36 -07:00
|
|
|
export interface Props {
|
|
|
|
pluginRunner: BasePluginRunner;
|
|
|
|
pluginSettings: PluginSettings;
|
2024-06-25 05:59:59 -07:00
|
|
|
platformImplementation: BasePlatformImplementation;
|
2024-06-10 23:40:36 -07:00
|
|
|
store: Store<AppState>;
|
|
|
|
reloadAll: boolean;
|
|
|
|
cancelEvent: CancelEvent;
|
|
|
|
}
|
|
|
|
|
2024-06-25 05:59:59 -07:00
|
|
|
const loadPlugins = async ({
|
|
|
|
pluginRunner,
|
|
|
|
platformImplementation,
|
|
|
|
pluginSettings,
|
|
|
|
store,
|
|
|
|
reloadAll,
|
|
|
|
cancelEvent,
|
|
|
|
}: Props) => {
|
2024-03-11 08:02:15 -07:00
|
|
|
try {
|
|
|
|
const pluginService = PluginService.instance();
|
|
|
|
pluginService.initialize(
|
|
|
|
platformImplementation.versionInfo.version, platformImplementation, pluginRunner, store,
|
|
|
|
);
|
|
|
|
pluginService.isSafeMode = Setting.value('isSafeMode');
|
|
|
|
|
2024-06-10 23:40:36 -07:00
|
|
|
if (reloadAll) {
|
|
|
|
logger.info('Reloading all plugins.');
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const pluginId of pluginService.pluginIds) {
|
|
|
|
if (reloadAll || (pluginSettings[pluginId] && !pluginSettings[pluginId].enabled)) {
|
|
|
|
logger.info('Unloading plugin', pluginId);
|
2024-04-27 03:45:39 -07:00
|
|
|
await pluginService.unloadPlugin(pluginId);
|
|
|
|
}
|
2024-03-11 08:02:15 -07:00
|
|
|
|
2024-06-10 23:40:36 -07:00
|
|
|
if (cancelEvent.cancelled) {
|
|
|
|
logger.info('Cancelled.');
|
2024-03-11 08:02:15 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Setting.value('env') === 'dev') {
|
|
|
|
logger.info('Running dev plugins (if any)...');
|
|
|
|
await pluginService.loadAndRunDevPlugins(pluginSettings);
|
|
|
|
}
|
|
|
|
|
2024-06-10 23:40:36 -07:00
|
|
|
if (cancelEvent.cancelled) {
|
|
|
|
logger.info('Cancelled.');
|
2024-03-11 08:02:15 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (await shim.fsDriver().exists(Setting.value('pluginDir'))) {
|
|
|
|
logger.info('Running user-installed plugins...');
|
|
|
|
await pluginService.loadAndRunPlugins(Setting.value('pluginDir'), pluginSettings);
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error);
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export default loadPlugins;
|