2022-11-23 07:20:28 -08:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
|
|
const path = require('path');
|
|
|
|
const glob = require('fast-glob');
|
|
|
|
const { LoggerProxy } = require('n8n-workflow');
|
|
|
|
const { packageDir, writeJSON } = require('./common');
|
2022-11-24 08:36:57 -08:00
|
|
|
const { loadClassInIsolation } = require('../dist/ClassLoader');
|
2022-11-23 07:20:28 -08:00
|
|
|
|
|
|
|
LoggerProxy.init({
|
|
|
|
log: console.log.bind(console),
|
|
|
|
warn: console.warn.bind(console),
|
|
|
|
});
|
|
|
|
|
|
|
|
const loadClass = (sourcePath) => {
|
|
|
|
try {
|
|
|
|
const [className] = path.parse(sourcePath).name.split('.');
|
2022-11-24 08:36:57 -08:00
|
|
|
const filePath = path.resolve(packageDir, sourcePath);
|
|
|
|
const instance = loadClassInIsolation(filePath, className);
|
2022-11-23 07:20:28 -08:00
|
|
|
return { instance, sourcePath, className };
|
|
|
|
} catch (e) {
|
2022-11-24 08:36:57 -08:00
|
|
|
LoggerProxy.warn(`Failed to load ${sourcePath}: ${e.message}`);
|
2022-11-23 07:20:28 -08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const generate = (kind) => {
|
|
|
|
const data = glob
|
|
|
|
.sync(`dist/${kind}/**/*.${kind === 'nodes' ? 'node' : kind}.js`, {
|
|
|
|
cwd: packageDir,
|
|
|
|
})
|
|
|
|
.filter((filePath) => !/[vV]\d.node\.js$/.test(filePath))
|
|
|
|
.map(loadClass)
|
|
|
|
.filter((data) => !!data)
|
|
|
|
.reduce((obj, { className, sourcePath, instance }) => {
|
|
|
|
const name = kind === 'nodes' ? instance.description.name : instance.name;
|
|
|
|
if (name in obj) console.error('already loaded', kind, name, sourcePath);
|
|
|
|
else obj[name] = { className, sourcePath };
|
|
|
|
return obj;
|
|
|
|
}, {});
|
|
|
|
LoggerProxy.info(`Detected ${Object.keys(data).length} ${kind}`);
|
|
|
|
return writeJSON(`known/${kind}.json`, data);
|
|
|
|
};
|
|
|
|
|
|
|
|
(async () => {
|
|
|
|
await Promise.all([generate('credentials'), generate('nodes')]);
|
|
|
|
})();
|