mirror of
https://github.com/HeyPuter/puter.git
synced 2025-01-23 14:20:22 +08:00
dev: add module lib installation to useapi
This commit is contained in:
parent
3d85edf537
commit
3649dff9aa
@ -24,11 +24,13 @@ const { Context } = require('./util/context');
|
||||
|
||||
|
||||
class CoreModule extends AdvancedBase {
|
||||
dirname () { return __dirname; }
|
||||
async install (context) {
|
||||
const services = context.get('services');
|
||||
const app = context.get('app');
|
||||
const useapi = context.get('useapi');
|
||||
await install({ services, app, useapi });
|
||||
const modapi = context.get('modapi');
|
||||
await install({ services, app, useapi, modapi });
|
||||
}
|
||||
|
||||
// Some services were created before the BaseService
|
||||
@ -44,7 +46,10 @@ class CoreModule extends AdvancedBase {
|
||||
|
||||
module.exports = CoreModule;
|
||||
|
||||
const install = async ({ services, app, useapi }) => {
|
||||
/**
|
||||
* @footgun - real install method is defined above
|
||||
*/
|
||||
const install = async ({ services, app, useapi, modapi }) => {
|
||||
const config = require('./config');
|
||||
|
||||
useapi.withuse(() => {
|
||||
@ -64,6 +69,8 @@ const install = async ({ services, app, useapi }) => {
|
||||
services.registerService('lib-type-tagged', LibTypeTagged);
|
||||
});
|
||||
|
||||
modapi.libdir('lib.core', './util');
|
||||
|
||||
// === SERVICES ===
|
||||
|
||||
// /!\ IMPORTANT /!\
|
||||
|
@ -135,9 +135,14 @@ class Kernel extends AdvancedBase {
|
||||
const { services } = this;
|
||||
|
||||
// Internal modules
|
||||
for ( const module of this.modules ) {
|
||||
services.registerModule(module.constructor.name, module);
|
||||
await module.install(Context.get());
|
||||
for ( const module_ of this.modules ) {
|
||||
services.registerModule(module_.constructor.name, module_);
|
||||
const mod_context = this._create_mod_context(Context.get(), {
|
||||
name: module_.constructor.name,
|
||||
['module']: module_,
|
||||
external: false,
|
||||
});
|
||||
await module_.install(mod_context);
|
||||
}
|
||||
|
||||
// External modules
|
||||
@ -209,6 +214,8 @@ class Kernel extends AdvancedBase {
|
||||
const path_ = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
const mod_install_root_context = Context.get();
|
||||
|
||||
const mod_paths = this.environment.mod_paths;
|
||||
for ( const mods_dirpath of mod_paths ) {
|
||||
const mod_dirnames = fs.readdirSync(mods_dirpath);
|
||||
@ -226,14 +233,60 @@ class Kernel extends AdvancedBase {
|
||||
continue;
|
||||
}
|
||||
|
||||
const mod_context = this._create_mod_context(mod_install_root_context, {
|
||||
name: mod_class.name ?? mod_dirname,
|
||||
['module']: mod,
|
||||
external: true,
|
||||
mod_path,
|
||||
});
|
||||
|
||||
if ( mod.install ) {
|
||||
this.useapi.awithuse(async () => {
|
||||
await mod.install(Context.get());
|
||||
await mod.install(mod_context);
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
_create_mod_context (parent, options) {
|
||||
const path_ = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
const modapi = {};
|
||||
|
||||
let mod_path = options.mod_path;
|
||||
if ( ! mod_path && options.module.dirname ) {
|
||||
mod_path = options.module.dirname();
|
||||
}
|
||||
|
||||
if ( mod_path ) {
|
||||
modapi.libdir = (prefix, directory) => {
|
||||
const fullpath = path_.join(mod_path, directory);
|
||||
const fsitems = fs.readdirSync(fullpath);
|
||||
for ( const item of fsitems ) {
|
||||
if ( ! item.endsWith('.js') ) {
|
||||
continue;
|
||||
}
|
||||
const stat = fs.statSync(path_.join(fullpath, item));
|
||||
if ( ! stat.isFile() ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
const name = item.slice(0, -3);
|
||||
const path = path_.join(fullpath, item);
|
||||
let lib = require(path);
|
||||
|
||||
// TODO: This context can be made dynamic by adding a
|
||||
// getter-like behavior to useapi.
|
||||
this.useapi.def(`${prefix}.${name}`, lib);
|
||||
}
|
||||
}
|
||||
}
|
||||
const mod_context = parent.sub({ modapi }, `mod:${options.name}`);
|
||||
return mod_context;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = { Kernel };
|
||||
|
Loading…
Reference in New Issue
Block a user