Skip to content

Commit

Permalink
feat(compartment-mapper): expose loadCompartmentForArchive
Browse files Browse the repository at this point in the history
This extracts a function, `loadCompartmentForArchive()`, from `digestLocation()` in `archive.js`, and exposes it.  This function returns archival-ready data structures, in addition to a record of the compartment renames which `makeArchiveCompartmentMap()` performs.

The intent is to leverage the module resolution performed by the function, which is reflected in its output.  A consumer can use the information therein to perform additional operations on the tree (e.g., parse ASTs).

# Conflicts:
#	packages/compartment-mapper/src/types.js
  • Loading branch information
boneskull committed Mar 28, 2024
1 parent 0372012 commit 8f632a2
Show file tree
Hide file tree
Showing 9 changed files with 87 additions and 25 deletions.
1 change: 1 addition & 0 deletions packages/compartment-mapper/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ export {
writeArchive,
mapLocation,
hashLocation,
loadCompartmentForArchive,
} from './src/archive.js';
export {
parseArchive,
Expand Down
80 changes: 55 additions & 25 deletions packages/compartment-mapper/src/archive.js
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,7 @@ const captureSourceLocations = async (sources, captureSourceLocation) => {
/**
* @param {CompartmentMapDescriptor} compartmentMap
* @param {Sources} sources
* @returns {{archiveCompartmentMap: CompartmentMapDescriptor, archiveSources: Sources}}
* @returns {import('./types.js').MakeArchiveCompartmentMapResult}
*/
export const makeArchiveCompartmentMap = (compartmentMap, sources) => {
const {
Expand Down Expand Up @@ -282,29 +282,27 @@ export const makeArchiveCompartmentMap = (compartmentMap, sources) => {
// accept all valid compartment maps.
assertCompartmentMap(archiveCompartmentMap);

return { archiveCompartmentMap, archiveSources };
return { archiveCompartmentMap, archiveSources, compartmentRenames };
};

/**
* @param {ReadFn | ReadPowers} powers
* @param {string} moduleLocation
* @param {ArchiveOptions} [options]
* @returns {Promise<{sources: Sources, compartmentMapBytes: Uint8Array, sha512?: string}>}
* @param {import('./types.js').LoadCompartmentForArchiveOptions & ArchiveOptions} options
* @returns {Promise<import('./types.js').LoadCompartmentForArchiveResult>}
*/
const digestLocation = async (powers, moduleLocation, options) => {
const {
moduleTransforms,
modules: exitModules = {},
dev = false,
tags = new Set(),
captureSourceLocation = undefined,
searchSuffixes = undefined,
commonDependencies = undefined,
importHook: exitModuleImportHook = undefined,
policy = undefined,
sourceMapHook = undefined,
} = options || {};
const { read, computeSha512 } = unpackReadPowers(powers);
export const loadCompartmentForArchive = async ({
readPowers,
moduleLocation,
moduleTransforms,
modules: exitModules = {},
dev = false,
tags = new Set(),
searchSuffixes = undefined,
commonDependencies = undefined,
importHook: exitModuleImportHook = undefined,
policy = undefined,
sourceMapHook = undefined,
}) => {
const { read, computeSha512 } = unpackReadPowers(readPowers);
const {
packageLocation,
packageDescriptorText,
Expand All @@ -321,7 +319,7 @@ const digestLocation = async (powers, moduleLocation, options) => {
packageDescriptorLocation,
);
const compartmentMap = await compartmentMapForNodeModules(
powers,
readPowers,
packageLocation,
tags,
packageDescriptor,
Expand Down Expand Up @@ -362,6 +360,15 @@ const digestLocation = async (powers, moduleLocation, options) => {
archiveOnly: true,
});
await compartment.load(entryModuleSpecifier);

/** @type {string|undefined} */
let compartmentMapSha512;
if (computeSha512 !== undefined) {
const compartmentMapText = JSON.stringify(compartmentMap, null, 2);
const compartmentMapBytes = textEncoder.encode(compartmentMapText);
compartmentMapSha512 = computeSha512(compartmentMapBytes);
}

if (policy) {
// retain all attenuators.
await Promise.all(
Expand All @@ -371,10 +378,33 @@ const digestLocation = async (powers, moduleLocation, options) => {
);
}

const { archiveCompartmentMap, archiveSources } = makeArchiveCompartmentMap(
compartmentMap,
sources,
);
const { archiveCompartmentMap, archiveSources, compartmentRenames } =
makeArchiveCompartmentMap(compartmentMap, sources);

return {
archiveCompartmentMap,
archiveSources,
compartmentMapSha512,
compartmentRenames,
computeSha512,
};
};

/**
* @param {ReadFn | ReadPowers} powers
* @param {string} moduleLocation
* @param {ArchiveOptions} [options]
* @returns {Promise<{sources: Sources, compartmentMapBytes: Uint8Array, sha512?: string}>}
*/
const digestLocation = async (powers, moduleLocation, options = {}) => {
const { captureSourceLocation = undefined } = options;

const { archiveCompartmentMap, archiveSources, computeSha512 } =
await loadCompartmentForArchive({
readPowers: powers,
moduleLocation,
...options,
});

const archiveCompartmentMapText = JSON.stringify(
archiveCompartmentMap,
Expand Down
26 changes: 26 additions & 0 deletions packages/compartment-mapper/src/types.js
Original file line number Diff line number Diff line change
Expand Up @@ -525,3 +525,29 @@ export {};
* @typedef CryptoAPI
* @property {typeof import('crypto').createHash} createHash
*/

/**
* @typedef LoadCompartmentForArchiveOptions
* @property {ReadFn | ReadPowers} readPowers
* @property {string} moduleLocation
*/

/**
* Return value of `loadCompartmentForArchive`.
*
* @typedef LoadCompartmentForArchiveResult
* @property {CompartmentMapDescriptor} archiveCompartmentMap
* @property {Sources} archiveSources
* @property {Record<string, string>} compartmentRenames
* @property {string} [compartmentMapSha512]
* @property {HashFn} [computeSha512]
*/

/**
* Return value of `makeArchiveCompartmentMap`
*
* @typedef MakeArchiveCompartmentMapResult
* @property {CompartmentMapDescriptor} archiveCompartmentMap
* @property {Sources} archiveSources
* @property {Record<string, string>} compartmentRenames
*/
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ Generated by [AVA](https://avajs.dev).
`TypeError: Failed to load module "./main.js" in package "file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/" (1 underlying failures: Cannot find external module "missing" in package file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/␊
at load (file://.../ses/src/module-load.js:…)␊
at async loadCompartmentForArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async digestLocation (file://.../compartment-mapper/src/archive.js:…)␊
at async makeAndHashArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async makeArchive (file://.../compartment-mapper/src/archive.js:…)␊
Expand All @@ -40,6 +41,7 @@ Generated by [AVA](https://avajs.dev).
`TypeError: Failed to load module "./main.js" in package "file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/" (1 underlying failures: Cannot find external module "missing" in package file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/␊
at load (file://.../ses/src/module-load.js:…)␊
at async loadCompartmentForArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async digestLocation (file://.../compartment-mapper/src/archive.js:…)␊
at async makeAndHashArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async makeArchive (file://.../compartment-mapper/src/archive.js:…)␊
Expand All @@ -52,6 +54,7 @@ Generated by [AVA](https://avajs.dev).
`TypeError: Failed to load module "./main.js" in package "file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/" (1 underlying failures: Cannot find external module "missing" in package file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/␊
at load (file://.../ses/src/module-load.js:…)␊
at async loadCompartmentForArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async digestLocation (file://.../compartment-mapper/src/archive.js:…)␊
at async makeAndHashArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async makeArchive (file://.../compartment-mapper/src/archive.js:…)␊
Expand All @@ -65,6 +68,7 @@ Generated by [AVA](https://avajs.dev).
`TypeError: Failed to load module "./main.js" in package "file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/" (1 underlying failures: Cannot find external module "missing" in package file://.../compartment-mapper/test/fixtures-error-handling/node_modules/esm/␊
at load (file://.../ses/src/module-load.js:…)␊
at async loadCompartmentForArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async digestLocation (file://.../compartment-mapper/src/archive.js:…)␊
at async makeAndHashArchive (file://.../compartment-mapper/src/archive.js:…)␊
at async makeArchive (file://.../compartment-mapper/src/archive.js:…)␊
Expand Down
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file modified packages/compartment-mapper/test/snapshots/test-policy.js.snap
Binary file not shown.
1 change: 1 addition & 0 deletions packages/compartment-mapper/types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ export {
writeArchive,
mapLocation,
hashLocation,
loadCompartmentForArchive,
} from './src/archive.js';
export {
parseArchive,
Expand Down

0 comments on commit 8f632a2

Please sign in to comment.