**Motivations:** - Ensure all application directories have systemd services enabled at boot - Complete service installation for api-relay, filigrane-api, and clamav-api - Fix dependencies and import issues preventing clamav-api from starting **Root causes:** - Three services (api-relay, filigrane-api, clamav-api) had service files but were not installed in systemd - api-clamav had incorrect node-clamav version (0.12.1) that doesn't exist - api-clamav dependencies were not installed (node_modules missing) - ES module import syntax incompatible with CommonJS node-clamav package **Correctifs:** - Installed api-relay.service, filigrane-api.service, and clamav-api.service in /etc/systemd/system/ - Enabled all three services for automatic startup at boot - Updated api-clamav/package.json: changed node-clamav version from ^0.12.1 to ^1.0.11 - Installed npm dependencies for api-clamav - Fixed ES module import in api-clamav/src/routes/scan.js to use CommonJS-compatible syntax **Evolutions:** - All 7 application services now have systemd services enabled at boot - Complete service coverage: anchorage-api, faucet-api, signet-dashboard, userwallet, api-relay, filigrane-api, clamav-api - All services verified active and listening on their respective ports **Pages affectées:** - api-clamav/package.json - api-clamav/src/routes/scan.js - api-clamav/node_modules/ (new) - api-clamav/package-lock.json (new) - /etc/systemd/system/api-relay.service (new) - /etc/systemd/system/filigrane-api.service (new) - /etc/systemd/system/clamav-api.service (new)
69 lines
1.9 KiB
JavaScript
69 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
var callBound = require('call-bound');
|
|
var inspect = require('object-inspect');
|
|
|
|
var $TypeError = require('es-errors/type');
|
|
var $Map = GetIntrinsic('%Map%', true);
|
|
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => V} */
|
|
var $mapGet = callBound('Map.prototype.get', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K, value: V) => void} */
|
|
var $mapSet = callBound('Map.prototype.set', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
|
|
var $mapHas = callBound('Map.prototype.has', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
|
|
var $mapDelete = callBound('Map.prototype.delete', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>) => number} */
|
|
var $mapSize = callBound('Map.prototype.size', true);
|
|
|
|
/** @type {import('.')} */
|
|
module.exports = !!$Map && /** @type {Exclude<import('.'), false>} */ function getSideChannelMap() {
|
|
/** @typedef {ReturnType<typeof getSideChannelMap>} Channel */
|
|
/** @typedef {Parameters<Channel['get']>[0]} K */
|
|
/** @typedef {Parameters<Channel['set']>[1]} V */
|
|
|
|
/** @type {Map<K, V> | undefined} */ var $m;
|
|
|
|
/** @type {Channel} */
|
|
var channel = {
|
|
assert: function (key) {
|
|
if (!channel.has(key)) {
|
|
throw new $TypeError('Side channel does not contain ' + inspect(key));
|
|
}
|
|
},
|
|
'delete': function (key) {
|
|
if ($m) {
|
|
var result = $mapDelete($m, key);
|
|
if ($mapSize($m) === 0) {
|
|
$m = void undefined;
|
|
}
|
|
return result;
|
|
}
|
|
return false;
|
|
},
|
|
get: function (key) { // eslint-disable-line consistent-return
|
|
if ($m) {
|
|
return $mapGet($m, key);
|
|
}
|
|
},
|
|
has: function (key) {
|
|
if ($m) {
|
|
return $mapHas($m, key);
|
|
}
|
|
return false;
|
|
},
|
|
set: function (key, value) {
|
|
if (!$m) {
|
|
// @ts-expect-error TS can't handle narrowing a variable inside a closure
|
|
$m = new $Map();
|
|
}
|
|
$mapSet($m, key, value);
|
|
}
|
|
};
|
|
|
|
// @ts-expect-error TODO: figure out why TS is erroring here
|
|
return channel;
|
|
};
|