Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

convert to ESM #217

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
convert to ESM, use global state
  • Loading branch information
milahu committed Apr 1, 2024
commit 48295073f8d20c14786bec3fd28c2dafc3136125
1 change: 1 addition & 0 deletions app/package.json
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
{
"type": "module",
"dependencies": {
"simple-node-logger": "^21.8.12",
"base64-js": "^1.5.1",
Expand Down
9 changes: 9 additions & 0 deletions app/src/config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// experimental
//import config from './config.json' with { type: "json" };

import { createRequire } from 'node:module';
const require = createRequire(import.meta.url);
import fs from 'fs';
const config = JSON.parse(fs.readFileSync(require.resolve('./config.json'), 'utf8'));

export default config;
21 changes: 13 additions & 8 deletions app/src/converter.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
import open from 'open';
import os from "os";
import path from "path";
import fs from "node:fs";

const os = require("os");
const path = require('path');
const fs = require("node:fs");

const logger = require('./logger');
const rpc = require('./weh-rpc');
export default ({logger, rpc}) => {

const exec_dir = path.dirname(process.execPath);

Expand Down Expand Up @@ -99,7 +97,7 @@ function ExecConverter(args) {
});
}

exports.star_listening = () => {
const start_listening = () => {

const convertChildren = new Map();

Expand Down Expand Up @@ -334,7 +332,7 @@ exports.star_listening = () => {
});
};

exports.info = () => {
const info = () => {
return new Promise((resolve, reject) => {
let convProcess = spawn(ffmpeg, ["-h"]);
let done = false;
Expand Down Expand Up @@ -365,3 +363,10 @@ exports.info = () => {
});
});
};

return {
start_listening,
info,
};

}
11 changes: 5 additions & 6 deletions app/src/downloads.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
const path = require('path');
const fs = require('node:fs');
const rpc = require('./weh-rpc');
const os = require("os");
const got = require('got');
import path from "path";
import fs from "node:fs";
import os from "os";
import got from "got";

let downloadFolder = path.join(os.homedir(), "dwhelper");

Expand Down Expand Up @@ -156,7 +155,7 @@ function cancel(downloadId) {
}
}

rpc.listen({
export default ({rpc}) => rpc.listen({
"downloads.download": download,
"downloads.search": search,
"downloads.cancel": cancel
Expand Down
15 changes: 7 additions & 8 deletions app/src/file.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
const fs = require('node:fs');
const path = require('path');
const tmp = require('tmp');
const rpc = require('./weh-rpc');
const { spawn } = require('child_process');
const os = require('os');
const base64 = require("base64-js");
import fs from 'node:fs';
import path from 'path';
import tmp from 'tmp';
import { spawn } from 'child_process';
import os from 'os';
import base64 from "base64-js";

const uniqueFileNames = {};
const MAX_FILE_ENTRIES = 1000;

rpc.listen({
export default ({rpc}) => rpc.listen({
// In test suite
"listFiles": (directory) => {
return new Promise((resolve, reject) => {
Expand Down
18 changes: 9 additions & 9 deletions app/src/logger.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
let simplelogger = require("simple-node-logger");
import simplelogger from "simple-node-logger";

let logfile = process.env.WEH_NATIVE_LOGFILE;
const logfile = process.env.WEH_NATIVE_LOGFILE;
//const logfile = "/run/user/1000/vdhcoapp.log"; // debug

if (!logfile) {
module.exports = {
export default () => (!logfile) ? (
{
info: () => {},
error: () => {},
warn: () => {},
log: () => {},
};
} else {
let logger = simplelogger.createSimpleFileLogger(logfile);
module.exports = logger;
}
}
) : (
simplelogger.createSimpleFileLogger(logfile)
);
46 changes: 32 additions & 14 deletions app/src/main.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
const config = require('config.json');
const converter = require('./converter');
const os = require("os");
import config from './config.js';

import os from 'os';

const globalState = {
config,
logger: null,
rpc: null,
converter: null,
};

function info() {
let result = {
Expand All @@ -13,7 +20,7 @@ function info() {
target: config.target,
home: os.homedir() || ""
};
return converter.info().then((convInfo) => {
return globalState.converter.info().then((convInfo) => {
return Object.assign(result, {
converterBinary: convInfo.converterBinary,
converterBase: convInfo.program,
Expand All @@ -27,9 +34,9 @@ function info() {
}

if (process.argv[2] == "install") {
require("./native-autoinstall").install();
(await import("./native-autoinstall.js")).install();
} else if (process.argv[2] == "uninstall") {
require("./native-autoinstall").uninstall();
(await import("./native-autoinstall.js")).uninstall();
} else if (process.argv[2] == "--version") {
console.log(config.meta.version);
} else if (process.argv[2] == "--info") {
Expand All @@ -54,19 +61,27 @@ Options:
console.log(help);
} else {

require('./native-messaging');
const logger = require('./logger');
const rpc = require('./weh-rpc');
// note: this disables the exception handler
// so exceptions will silently fail
// fix: WEH_NATIVE_LOGFILE=/dev/stderr vdhcoapp

const logger = (await import('./logger.js')).default();
globalState.logger = logger;

const rpc = (await import('./weh-rpc.js')).default();
rpc.setLogger(logger);
rpc.setDebugLevel(2);
globalState.rpc = rpc;

require('./file');
require('./downloads');
require('./request');
require('./vm');
const converter = (await import('./converter.js')).default(globalState);
globalState.converter = converter;

converter.star_listening();
(await import('./file.js')).default(globalState);
(await import('./downloads.js')).default(globalState);
(await import('./request.js')).default(globalState);
(await import('./vm.js')).default(globalState);

converter.start_listening();

rpc.listen({
// In test suite
Expand All @@ -85,6 +100,9 @@ Options:
info,
});

// start listening for RPC requests from stdin
(await import('./native-messaging.js')).default(globalState);

let m = `vdhcoapp is running successfully. `;
m += `This is not intended to be used directly from the command line. `;
m += `You should press Ctrl+C to exit. `;
Expand Down
23 changes: 13 additions & 10 deletions app/src/native-autoinstall.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,16 @@
const os = require("os");
const path = require("path");
const { spawn, exec } = require('child_process');
const config = require('config.json');
import os from "os";
import path from "path";
import { spawn, exec } from "child_process";
import config from "./config.js";

import { createRequire } from 'node:module';
const require = createRequire(import.meta.url);

let fs;
if (process.versions.node.startsWith("10")) {
fs = require('fs').promises;
fs = await require('fs').promises;
} else {
fs = require('node:fs/promises');
fs = await require('node:fs/promises');
}

const STORES = Object.keys(config.store);
Expand Down Expand Up @@ -170,12 +173,12 @@ async function install_uninstall(uninstall = false) {
}
}

exports.install = () => {
export const install = async () => {
console.log("Installing…");
install_uninstall();
await install_uninstall();
};

exports.uninstall = () => {
export const uninstall = async () => {
console.log("Uninstalling…");
install_uninstall(true);
await install_uninstall(true);
};
5 changes: 3 additions & 2 deletions app/src/native-messaging.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
const rpc = require('./weh-rpc');
const logger = require('./logger');
export default ({logger, rpc}) => {

logger.info("\n\n\n\n=================== started ====================");

Expand Down Expand Up @@ -56,3 +55,5 @@ rpc.setPost(Send);
process.stdin.on('data', (chunk) => {
AppendInputString(chunk);
});

}
8 changes: 5 additions & 3 deletions app/src/request.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
const rpc = require('./weh-rpc');
const got = require('got');
const logger = require('./logger');
import got from 'got';

let currentIndex = 0;

Expand All @@ -9,6 +7,8 @@ let requestStore = {};
const MAX_SIZE = 50000;
const EXPIRE_DATA_TIMEOUT = 30000;

export default ({logger, rpc}) => {

function GetData(id) {
let reqInfo = requestStore[id];
if (!reqInfo) {
Expand Down Expand Up @@ -184,3 +184,5 @@ rpc.listen({
return GetData(id);
}
});

}
5 changes: 2 additions & 3 deletions app/src/vm.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
const vm = require('vm');
const rpc = require('./weh-rpc');
import vm from 'vm';

rpc.listen({
export default ({rpc}) => rpc.listen({
"vm.run": async (code) => {
const sandbox = {};
const script = new vm.Script(code);
Expand Down
2 changes: 1 addition & 1 deletion app/src/weh-rpc.js
Original file line number Diff line number Diff line change
Expand Up @@ -194,4 +194,4 @@ class RPC {

}

module.exports = new RPC();
export default () => new RPC();