@hubspot/project-parsing-lib 0.13.0-beta.0 → 0.13.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/lib/migrate.d.ts +1 -0
- package/src/lib/migrate.js +16 -8
- package/src/lib/transform.js +3 -13
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hubspot/project-parsing-lib",
|
|
3
|
-
"version": "0.13.0-beta.
|
|
3
|
+
"version": "0.13.0-beta.2",
|
|
4
4
|
"description": "Parsing library for converting projects directory structures to their intermediate representation",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"type": "module",
|
package/src/lib/migrate.d.ts
CHANGED
package/src/lib/migrate.js
CHANGED
|
@@ -2,12 +2,12 @@ import { walk } from '@hubspot/local-dev-lib/fs';
|
|
|
2
2
|
import path from 'path';
|
|
3
3
|
import fs from 'fs';
|
|
4
4
|
import { mapToUserFacingType } from './transform.js';
|
|
5
|
-
import { METAFILE_EXTENSION, Components, HS_PROJECT_JSON_FILENAME, } from './constants.js';
|
|
5
|
+
import { METAFILE_EXTENSION, Components, HS_PROJECT_JSON_FILENAME, APP_FUNCTIONS_PACKAGE_KEY, APP_FUNCTIONS_KEY, } from './constants.js';
|
|
6
6
|
import { translate } from './translate.js';
|
|
7
7
|
import { loadJsonFile } from './utils.js';
|
|
8
8
|
const IR_FILENAME = 'ir.json';
|
|
9
9
|
const filesDirectory = 'files';
|
|
10
|
-
const OUTPUT_IR_FILE = 'FULL_IR.json';
|
|
10
|
+
export const OUTPUT_IR_FILE = 'FULL_IR.json';
|
|
11
11
|
export async function migrate(inputDir, outputDir) {
|
|
12
12
|
if (!fs.existsSync(inputDir)) {
|
|
13
13
|
throw new Error(`Input directory ${inputDir} does not exist`);
|
|
@@ -35,20 +35,25 @@ export async function migrate(inputDir, outputDir) {
|
|
|
35
35
|
const irDirName = path.dirname(filename);
|
|
36
36
|
const IR = loadJsonFile(filename);
|
|
37
37
|
const { metaFilePath } = IR;
|
|
38
|
-
const
|
|
39
|
-
const fullOutputPath = path.join(sourceCodeOutputDir, getTargetDirectoryFromComponentType(
|
|
38
|
+
const component = convertIRToProjectConfig(IR);
|
|
39
|
+
const fullOutputPath = path.join(sourceCodeOutputDir, getTargetDirectoryFromComponentType(component.type));
|
|
40
40
|
// Ensure the output directory exists
|
|
41
41
|
const currentFilesDirectory = path.join(irDirName, filesDirectory);
|
|
42
42
|
ensureDirExists(currentFilesDirectory);
|
|
43
43
|
fs.cpSync(currentFilesDirectory, fullOutputPath, {
|
|
44
44
|
recursive: true,
|
|
45
45
|
});
|
|
46
|
+
// In the current component is a APP_FUNCTIONS_PACKAGE we don't want to write a hsmeta.json file
|
|
47
|
+
// since it is an auto generate component
|
|
48
|
+
if (component.type === APP_FUNCTIONS_PACKAGE_KEY) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
46
51
|
// Use the metaFilePath if provided, otherwise use the project UID
|
|
47
52
|
const hsmetaFilePath = path.join(fullOutputPath, metaFilePath
|
|
48
53
|
? path.basename(metaFilePath)
|
|
49
|
-
: `${
|
|
54
|
+
: `${component.uid}${METAFILE_EXTENSION}`);
|
|
50
55
|
// Write the hsmeta file to the output directory
|
|
51
|
-
fs.writeFileSync(hsmetaFilePath, JSON.stringify(
|
|
56
|
+
fs.writeFileSync(hsmetaFilePath, JSON.stringify(component, null, 2));
|
|
52
57
|
});
|
|
53
58
|
const IR = await translate({
|
|
54
59
|
projectSourceDir: sourceCodeOutputDir,
|
|
@@ -78,9 +83,12 @@ function convertIRToProjectConfig(IR) {
|
|
|
78
83
|
};
|
|
79
84
|
}
|
|
80
85
|
function getTargetDirectoryFromComponentType(componentType) {
|
|
81
|
-
|
|
86
|
+
let component = Components[componentType];
|
|
87
|
+
if (componentType === APP_FUNCTIONS_PACKAGE_KEY) {
|
|
88
|
+
component = Components[APP_FUNCTIONS_KEY];
|
|
89
|
+
}
|
|
82
90
|
if (!component) {
|
|
83
|
-
throw Error(
|
|
91
|
+
throw Error(`Unsupported component type: "${componentType}"`);
|
|
84
92
|
}
|
|
85
93
|
const parentDirectory = component.parentComponent
|
|
86
94
|
? Components[component.parentComponent].dir
|
package/src/lib/transform.js
CHANGED
|
@@ -2,11 +2,11 @@ import path from 'path';
|
|
|
2
2
|
import fs from 'fs';
|
|
3
3
|
import { logger } from '@hubspot/local-dev-lib/logger';
|
|
4
4
|
import { applyHsProfileVariables, getHsProfileVariables } from './profiles.js';
|
|
5
|
-
import { APP_KEY, APP_OBJECT_KEY,
|
|
5
|
+
import { APP_KEY, APP_OBJECT_KEY, Components, PROJECT_STRUCTURE, APP_FUNCTIONS_KEY, APP_FUNCTIONS_PACKAGE_KEY, USER_FACING_TO_INTERNAL_TYPE, INTERNAL_TYPE_TO_USER_FACING, PACKAGE_JSON, PACKAGE_LOCK_JSON, PROFILE_VARIABLE_TYPES, } from './constants.js';
|
|
6
6
|
import { errorMessages } from '../lang/copy.js';
|
|
7
7
|
import { getJavaNumberType } from './utils.js';
|
|
8
8
|
import { convertPathToPosixPath } from './files.js';
|
|
9
|
-
function calculateComponentDeps(fileValidationResult, parentComponents, appObjects,
|
|
9
|
+
function calculateComponentDeps(fileValidationResult, parentComponents, appObjects, appFunctionsPackageUid) {
|
|
10
10
|
let dependencies = {};
|
|
11
11
|
// If there are dependencies in the config file, pass them through
|
|
12
12
|
if (!fileValidationResult.content?.dependencies) {
|
|
@@ -32,14 +32,6 @@ function calculateComponentDeps(fileValidationResult, parentComponents, appObjec
|
|
|
32
32
|
if (type === APP_FUNCTIONS_KEY && appFunctionsPackageUid) {
|
|
33
33
|
dependencies.serverlessPackage = appFunctionsPackageUid;
|
|
34
34
|
}
|
|
35
|
-
if (type === CARDS_KEY) {
|
|
36
|
-
if (appFunctionsPackageUid) {
|
|
37
|
-
dependencies.serverlessPackage = appFunctionsPackageUid;
|
|
38
|
-
}
|
|
39
|
-
if (appFunctions.length > 0) {
|
|
40
|
-
dependencies.allAppFunctions = appFunctions;
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
35
|
}
|
|
44
36
|
return { dependencies };
|
|
45
37
|
}
|
|
@@ -62,7 +54,6 @@ export function transform(fileParseResults, translationContext, hsProfileContent
|
|
|
62
54
|
const parentTypes = Object.keys(PROJECT_STRUCTURE);
|
|
63
55
|
const parentComponents = {};
|
|
64
56
|
const allAppObjects = [];
|
|
65
|
-
const allAppFunctions = [];
|
|
66
57
|
let appUid = '';
|
|
67
58
|
let appFunctionsDirectory;
|
|
68
59
|
// Apply the profile variable overrides to the config
|
|
@@ -82,7 +73,6 @@ export function transform(fileParseResults, translationContext, hsProfileContent
|
|
|
82
73
|
}
|
|
83
74
|
if (file.content?.type === APP_FUNCTIONS_KEY) {
|
|
84
75
|
appFunctionsDirectory = path.dirname(file.file);
|
|
85
|
-
allAppFunctions.push(file.content.uid);
|
|
86
76
|
}
|
|
87
77
|
});
|
|
88
78
|
const autoGeneratedComponents = [];
|
|
@@ -106,7 +96,7 @@ export function transform(fileParseResults, translationContext, hsProfileContent
|
|
|
106
96
|
};
|
|
107
97
|
}
|
|
108
98
|
const { config, uid, type } = currentFile.content;
|
|
109
|
-
const { dependencies, errors } = calculateComponentDeps(currentFile, parentComponents, allAppObjects,
|
|
99
|
+
const { dependencies, errors } = calculateComponentDeps(currentFile, parentComponents, allAppObjects, serverlessPackageUid);
|
|
110
100
|
if (errors) {
|
|
111
101
|
currentFile.errors?.push(...errors);
|
|
112
102
|
}
|