Skip to content

Commit 8730c76

Browse files
Merge pull request #62 from ArzamastsevVladyslav/feature/HCK-3559-pk-fk-constraiints
Feature/hck 3559 pk fk constraiints
2 parents 5475d6a + f9b89ff commit 8730c76

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

54 files changed

+4580
-2298
lines changed
Lines changed: 103 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,103 @@
1+
const {getAlterScriptDtos} = require("./alterScriptFromDeltaHelper");
2+
3+
const {AlterScriptDto} = require('./types/AlterScriptDto');
4+
5+
/**
6+
* @return {(dtos: AlterScriptDto[], shouldApplyDropStatements: boolean) => string}
7+
* */
8+
const joinAlterScriptDtosIntoScript = (_) => (dtos, shouldApplyDropStatements) => {
9+
const {commentIfDeactivated} = require('../utils/general')(_);
10+
return dtos.map((dto) => {
11+
if (dto.isActivated === false) {
12+
return dto.scripts
13+
.map((scriptDto) => commentIfDeactivated(scriptDto.script, {
14+
isActivated: false,
15+
isPartOfLine: false,
16+
}));
17+
}
18+
if (!shouldApplyDropStatements) {
19+
return dto.scripts
20+
.map((scriptDto) => commentIfDeactivated(scriptDto.script, {
21+
isActivated: !scriptDto.isDropScript,
22+
isPartOfLine: false,
23+
}));
24+
}
25+
return dto.scripts.map((scriptDto) => scriptDto.script);
26+
})
27+
.flat()
28+
.filter(Boolean)
29+
.map((scriptLine) => scriptLine.trim())
30+
.filter(Boolean)
31+
.join('\n\n');
32+
}
33+
34+
/**
35+
* @param data {CoreData}
36+
* @param app {App}
37+
* @return {string}
38+
* */
39+
const buildEntityLevelAlterScript = (data, app) => {
40+
const _ = app.require('lodash');
41+
const alterScriptDtos = getAlterScriptDtos(data, app);
42+
const shouldApplyDropStatements = data.options?.additionalOptions?.some(
43+
option => option.id === 'applyDropStatements' && option.value,
44+
);
45+
46+
return joinAlterScriptDtosIntoScript(_)(alterScriptDtos, shouldApplyDropStatements);
47+
}
48+
49+
/**
50+
* @param data {CoreData}
51+
* @param app {App}
52+
* @return { boolean}
53+
* */
54+
const doesEntityLevelAlterScriptContainDropStatements = (data, app) => {
55+
const alterScriptDtos = getAlterScriptDtos(data, app);
56+
return alterScriptDtos
57+
.some(alterScriptDto => alterScriptDto.isActivated && alterScriptDto
58+
.scripts.some(scriptModificationDto => scriptModificationDto.isDropScript));
59+
}
60+
61+
const mapCoreDataForContainerLevelScripts = (data) => {
62+
return {
63+
...data,
64+
jsonSchema: data.collections[0],
65+
internalDefinitions: Object.values(data.internalDefinitions)[0],
66+
}
67+
}
68+
69+
/**
70+
* @param data {CoreData}
71+
* @param app {App}
72+
* @return {string}
73+
* */
74+
const buildContainerLevelAlterScript = (data, app) => {
75+
const preparedData = mapCoreDataForContainerLevelScripts(data);
76+
const _ = app.require('lodash');
77+
const alterScriptDtos = getAlterScriptDtos(preparedData, app);
78+
const shouldApplyDropStatements = preparedData.options?.additionalOptions?.some(
79+
option => option.id === 'applyDropStatements' && option.value,
80+
);
81+
82+
return joinAlterScriptDtosIntoScript(_)(alterScriptDtos, shouldApplyDropStatements);
83+
}
84+
85+
/**
86+
* @param data {CoreData}
87+
* @param app {App}
88+
* @return { boolean}
89+
* */
90+
const doesContainerLevelAlterScriptContainDropStatements = (data, app) => {
91+
const preparedData = mapCoreDataForContainerLevelScripts(data);
92+
const alterScriptDtos = getAlterScriptDtos(preparedData, app);
93+
return alterScriptDtos
94+
.some(alterScriptDto => alterScriptDto.isActivated && alterScriptDto
95+
.scripts.some(scriptModificationDto => scriptModificationDto.isDropScript));
96+
}
97+
98+
module.exports = {
99+
buildEntityLevelAlterScript,
100+
doesEntityLevelAlterScriptContainDropStatements,
101+
buildContainerLevelAlterScript,
102+
doesContainerLevelAlterScriptContainDropStatements
103+
}

0 commit comments

Comments
 (0)