@mcp-abap-adt/adt-backup 0.1.0
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/LICENSE +22 -0
- package/README.md +64 -0
- package/dist/bin/adt-backup.d.ts +3 -0
- package/dist/bin/adt-backup.d.ts.map +1 -0
- package/dist/bin/adt-backup.js +8 -0
- package/dist/lib/auth/NoopTokenProvider.d.ts +5 -0
- package/dist/lib/auth/NoopTokenProvider.d.ts.map +1 -0
- package/dist/lib/auth/NoopTokenProvider.js +9 -0
- package/dist/lib/auth/createTokenProvider.d.ts +4 -0
- package/dist/lib/auth/createTokenProvider.d.ts.map +1 -0
- package/dist/lib/auth/createTokenProvider.js +22 -0
- package/dist/lib/auth/getSapConfigFromBroker.d.ts +13 -0
- package/dist/lib/auth/getSapConfigFromBroker.d.ts.map +1 -0
- package/dist/lib/auth/getSapConfigFromBroker.js +184 -0
- package/dist/lib/auth/index.d.ts +4 -0
- package/dist/lib/auth/index.d.ts.map +1 -0
- package/dist/lib/auth/index.js +19 -0
- package/dist/lib/backup/backupObject.d.ts +4 -0
- package/dist/lib/backup/backupObject.d.ts.map +1 -0
- package/dist/lib/backup/backupObject.js +166 -0
- package/dist/lib/backup/index.d.ts +5 -0
- package/dist/lib/backup/index.d.ts.map +1 -0
- package/dist/lib/backup/index.js +20 -0
- package/dist/lib/backup/readBasicMetadata.d.ts +7 -0
- package/dist/lib/backup/readBasicMetadata.d.ts.map +1 -0
- package/dist/lib/backup/readBasicMetadata.js +64 -0
- package/dist/lib/backup/readMetadataXmlForType.d.ts +4 -0
- package/dist/lib/backup/readMetadataXmlForType.d.ts.map +1 -0
- package/dist/lib/backup/readMetadataXmlForType.js +100 -0
- package/dist/lib/backup/readSourceText.d.ts +4 -0
- package/dist/lib/backup/readSourceText.d.ts.map +1 -0
- package/dist/lib/backup/readSourceText.js +96 -0
- package/dist/lib/cli/applyLogEnv.d.ts +2 -0
- package/dist/lib/cli/applyLogEnv.d.ts.map +1 -0
- package/dist/lib/cli/applyLogEnv.js +50 -0
- package/dist/lib/cli/createLogger.d.ts +7 -0
- package/dist/lib/cli/createLogger.d.ts.map +1 -0
- package/dist/lib/cli/createLogger.js +30 -0
- package/dist/lib/cli/getVerbosity.d.ts +2 -0
- package/dist/lib/cli/getVerbosity.d.ts.map +1 -0
- package/dist/lib/cli/getVerbosity.js +27 -0
- package/dist/lib/cli/index.d.ts +13 -0
- package/dist/lib/cli/index.d.ts.map +1 -0
- package/dist/lib/cli/index.js +28 -0
- package/dist/lib/cli/isEnvEnabled.d.ts +2 -0
- package/dist/lib/cli/isEnvEnabled.d.ts.map +1 -0
- package/dist/lib/cli/isEnvEnabled.js +10 -0
- package/dist/lib/cli/logVerbose.d.ts +2 -0
- package/dist/lib/cli/logVerbose.d.ts.map +1 -0
- package/dist/lib/cli/logVerbose.js +9 -0
- package/dist/lib/cli/parseArgs.d.ts +2 -0
- package/dist/lib/cli/parseArgs.d.ts.map +1 -0
- package/dist/lib/cli/parseArgs.js +22 -0
- package/dist/lib/cli/redact.d.ts +4 -0
- package/dist/lib/cli/redact.d.ts.map +1 -0
- package/dist/lib/cli/redact.js +75 -0
- package/dist/lib/cli/shouldEnableAdtLogger.d.ts +2 -0
- package/dist/lib/cli/shouldEnableAdtLogger.d.ts.map +1 -0
- package/dist/lib/cli/shouldEnableAdtLogger.js +10 -0
- package/dist/lib/cli/shouldEnableBrokerLogger.d.ts +2 -0
- package/dist/lib/cli/shouldEnableBrokerLogger.d.ts.map +1 -0
- package/dist/lib/cli/shouldEnableBrokerLogger.js +9 -0
- package/dist/lib/cli/shouldEnableConnectionLogger.d.ts +2 -0
- package/dist/lib/cli/shouldEnableConnectionLogger.d.ts.map +1 -0
- package/dist/lib/cli/shouldEnableConnectionLogger.js +7 -0
- package/dist/lib/cli/shouldEnableProviderLogger.d.ts +2 -0
- package/dist/lib/cli/shouldEnableProviderLogger.d.ts.map +1 -0
- package/dist/lib/cli/shouldEnableProviderLogger.js +9 -0
- package/dist/lib/cli/shouldEnableStoreLogger.d.ts +2 -0
- package/dist/lib/cli/shouldEnableStoreLogger.d.ts.map +1 -0
- package/dist/lib/cli/shouldEnableStoreLogger.js +9 -0
- package/dist/lib/cli/usage.d.ts +2 -0
- package/dist/lib/cli/usage.d.ts.map +1 -0
- package/dist/lib/cli/usage.js +187 -0
- package/dist/lib/constants/index.d.ts +3 -0
- package/dist/lib/constants/index.d.ts.map +1 -0
- package/dist/lib/constants/index.js +18 -0
- package/dist/lib/constants/typeOrder.d.ts +3 -0
- package/dist/lib/constants/typeOrder.d.ts.map +1 -0
- package/dist/lib/constants/typeOrder.js +22 -0
- package/dist/lib/constants/xmlParser.d.ts +3 -0
- package/dist/lib/constants/xmlParser.d.ts.map +1 -0
- package/dist/lib/constants/xmlParser.js +8 -0
- package/dist/lib/crypto/computeBackupChecksum.d.ts +3 -0
- package/dist/lib/crypto/computeBackupChecksum.d.ts.map +1 -0
- package/dist/lib/crypto/computeBackupChecksum.js +14 -0
- package/dist/lib/crypto/computeCodeChecksum.d.ts +2 -0
- package/dist/lib/crypto/computeCodeChecksum.d.ts.map +1 -0
- package/dist/lib/crypto/computeCodeChecksum.js +8 -0
- package/dist/lib/crypto/decodeBase64.d.ts +2 -0
- package/dist/lib/crypto/decodeBase64.d.ts.map +1 -0
- package/dist/lib/crypto/decodeBase64.js +6 -0
- package/dist/lib/crypto/encodeBase64.d.ts +2 -0
- package/dist/lib/crypto/encodeBase64.d.ts.map +1 -0
- package/dist/lib/crypto/encodeBase64.js +6 -0
- package/dist/lib/crypto/hashText.d.ts +2 -0
- package/dist/lib/crypto/hashText.d.ts.map +1 -0
- package/dist/lib/crypto/hashText.js +7 -0
- package/dist/lib/crypto/index.d.ts +10 -0
- package/dist/lib/crypto/index.d.ts.map +1 -0
- package/dist/lib/crypto/index.js +25 -0
- package/dist/lib/crypto/stripBackupChecksum.d.ts +3 -0
- package/dist/lib/crypto/stripBackupChecksum.d.ts.map +1 -0
- package/dist/lib/crypto/stripBackupChecksum.js +8 -0
- package/dist/lib/crypto/updateTreeChecksums.d.ts +3 -0
- package/dist/lib/crypto/updateTreeChecksums.d.ts.map +1 -0
- package/dist/lib/crypto/updateTreeChecksums.js +17 -0
- package/dist/lib/crypto/verifyBackupChecksum.d.ts +3 -0
- package/dist/lib/crypto/verifyBackupChecksum.d.ts.map +1 -0
- package/dist/lib/crypto/verifyBackupChecksum.js +13 -0
- package/dist/lib/crypto/verifyTreeChecksums.d.ts +3 -0
- package/dist/lib/crypto/verifyTreeChecksums.d.ts.map +1 -0
- package/dist/lib/crypto/verifyTreeChecksums.js +22 -0
- package/dist/lib/dependencies/collectTreeDependencies.d.ts +4 -0
- package/dist/lib/dependencies/collectTreeDependencies.d.ts.map +1 -0
- package/dist/lib/dependencies/collectTreeDependencies.js +99 -0
- package/dist/lib/index.d.ts +14 -0
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/index.js +29 -0
- package/dist/lib/restore/applyTransportRequest.d.ts +2 -0
- package/dist/lib/restore/applyTransportRequest.d.ts.map +1 -0
- package/dist/lib/restore/applyTransportRequest.js +12 -0
- package/dist/lib/restore/buildRestorePlan.d.ts +12 -0
- package/dist/lib/restore/buildRestorePlan.d.ts.map +1 -0
- package/dist/lib/restore/buildRestorePlan.js +46 -0
- package/dist/lib/restore/collectDeletionTargets.d.ts +7 -0
- package/dist/lib/restore/collectDeletionTargets.d.ts.map +1 -0
- package/dist/lib/restore/collectDeletionTargets.js +23 -0
- package/dist/lib/restore/deleteBackupObjects.d.ts +4 -0
- package/dist/lib/restore/deleteBackupObjects.d.ts.map +1 -0
- package/dist/lib/restore/deleteBackupObjects.js +22 -0
- package/dist/lib/restore/index.d.ts +9 -0
- package/dist/lib/restore/index.d.ts.map +1 -0
- package/dist/lib/restore/index.js +24 -0
- package/dist/lib/restore/restoreObject.d.ts +4 -0
- package/dist/lib/restore/restoreObject.d.ts.map +1 -0
- package/dist/lib/restore/restoreObject.js +242 -0
- package/dist/lib/restore/restoreObjects.d.ts +4 -0
- package/dist/lib/restore/restoreObjects.d.ts.map +1 -0
- package/dist/lib/restore/restoreObjects.js +28 -0
- package/dist/lib/restore/restoreTreeBackup.d.ts +4 -0
- package/dist/lib/restore/restoreTreeBackup.d.ts.map +1 -0
- package/dist/lib/restore/restoreTreeBackup.js +69 -0
- package/dist/lib/restore/restoreTreeNode.d.ts +4 -0
- package/dist/lib/restore/restoreTreeNode.d.ts.map +1 -0
- package/dist/lib/restore/restoreTreeNode.js +276 -0
- package/dist/lib/restore/sortByDependencies.d.ts +3 -0
- package/dist/lib/restore/sortByDependencies.d.ts.map +1 -0
- package/dist/lib/restore/sortByDependencies.js +65 -0
- package/dist/lib/restore/sortTreeNodesByDependencies.d.ts +3 -0
- package/dist/lib/restore/sortTreeNodesByDependencies.d.ts.map +1 -0
- package/dist/lib/restore/sortTreeNodesByDependencies.js +101 -0
- package/dist/lib/run.d.ts +2 -0
- package/dist/lib/run.d.ts.map +1 -0
- package/dist/lib/run.js +748 -0
- package/dist/lib/state/index.d.ts +2 -0
- package/dist/lib/state/index.d.ts.map +1 -0
- package/dist/lib/state/index.js +17 -0
- package/dist/lib/state/verbosity.d.ts +4 -0
- package/dist/lib/state/verbosity.d.ts.map +1 -0
- package/dist/lib/state/verbosity.js +6 -0
- package/dist/lib/tree/buildConfigForNode.d.ts +3 -0
- package/dist/lib/tree/buildConfigForNode.d.ts.map +1 -0
- package/dist/lib/tree/buildConfigForNode.js +116 -0
- package/dist/lib/tree/buildPackageBackupTree.d.ts +4 -0
- package/dist/lib/tree/buildPackageBackupTree.d.ts.map +1 -0
- package/dist/lib/tree/buildPackageBackupTree.js +27 -0
- package/dist/lib/tree/buildTreeList.d.ts +13 -0
- package/dist/lib/tree/buildTreeList.d.ts.map +1 -0
- package/dist/lib/tree/buildTreeList.js +19 -0
- package/dist/lib/tree/collectTreeObjects.d.ts +3 -0
- package/dist/lib/tree/collectTreeObjects.d.ts.map +1 -0
- package/dist/lib/tree/collectTreeObjects.js +18 -0
- package/dist/lib/tree/enrichTreeNode.d.ts +4 -0
- package/dist/lib/tree/enrichTreeNode.d.ts.map +1 -0
- package/dist/lib/tree/enrichTreeNode.js +69 -0
- package/dist/lib/tree/findNodeInTree.d.ts +3 -0
- package/dist/lib/tree/findNodeInTree.d.ts.map +1 -0
- package/dist/lib/tree/findNodeInTree.js +30 -0
- package/dist/lib/tree/flattenTree.d.ts +3 -0
- package/dist/lib/tree/flattenTree.d.ts.map +1 -0
- package/dist/lib/tree/flattenTree.js +12 -0
- package/dist/lib/tree/formatTreeListText.d.ts +5 -0
- package/dist/lib/tree/formatTreeListText.d.ts.map +1 -0
- package/dist/lib/tree/formatTreeListText.js +26 -0
- package/dist/lib/tree/getNodeFunctionGroupName.d.ts +3 -0
- package/dist/lib/tree/getNodeFunctionGroupName.d.ts.map +1 -0
- package/dist/lib/tree/getNodeFunctionGroupName.js +12 -0
- package/dist/lib/tree/getNodeObjectId.d.ts +3 -0
- package/dist/lib/tree/getNodeObjectId.d.ts.map +1 -0
- package/dist/lib/tree/getNodeObjectId.js +9 -0
- package/dist/lib/tree/getNodeObjectSpec.d.ts +3 -0
- package/dist/lib/tree/getNodeObjectSpec.d.ts.map +1 -0
- package/dist/lib/tree/getNodeObjectSpec.js +21 -0
- package/dist/lib/tree/index.d.ts +13 -0
- package/dist/lib/tree/index.d.ts.map +1 -0
- package/dist/lib/tree/index.js +28 -0
- package/dist/lib/tree/isRestoreImplemented.d.ts +3 -0
- package/dist/lib/tree/isRestoreImplemented.d.ts.map +1 -0
- package/dist/lib/tree/isRestoreImplemented.js +27 -0
- package/dist/lib/tree/mapAdtTypeToSupported.d.ts +3 -0
- package/dist/lib/tree/mapAdtTypeToSupported.d.ts.map +1 -0
- package/dist/lib/tree/mapAdtTypeToSupported.js +75 -0
- package/dist/lib/tree/readPayloadForType.d.ts +7 -0
- package/dist/lib/tree/readPayloadForType.d.ts.map +1 -0
- package/dist/lib/tree/readPayloadForType.js +38 -0
- package/dist/lib/types.d.ts +60 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +2 -0
- package/dist/lib/utils/applyConfigName.d.ts +3 -0
- package/dist/lib/utils/applyConfigName.d.ts.map +1 -0
- package/dist/lib/utils/applyConfigName.js +67 -0
- package/dist/lib/utils/asArray.d.ts +2 -0
- package/dist/lib/utils/asArray.d.ts.map +1 -0
- package/dist/lib/utils/asArray.js +9 -0
- package/dist/lib/utils/asConfig.d.ts +3 -0
- package/dist/lib/utils/asConfig.d.ts.map +1 -0
- package/dist/lib/utils/asConfig.js +6 -0
- package/dist/lib/utils/diffAttributes.d.ts +17 -0
- package/dist/lib/utils/diffAttributes.d.ts.map +1 -0
- package/dist/lib/utils/diffAttributes.js +27 -0
- package/dist/lib/utils/diffUnified.d.ts +4 -0
- package/dist/lib/utils/diffUnified.d.ts.map +1 -0
- package/dist/lib/utils/diffUnified.js +142 -0
- package/dist/lib/utils/ensureDescription.d.ts +3 -0
- package/dist/lib/utils/ensureDescription.d.ts.map +1 -0
- package/dist/lib/utils/ensureDescription.js +9 -0
- package/dist/lib/utils/formatObjectSpec.d.ts +3 -0
- package/dist/lib/utils/formatObjectSpec.d.ts.map +1 -0
- package/dist/lib/utils/formatObjectSpec.js +9 -0
- package/dist/lib/utils/index.d.ts +12 -0
- package/dist/lib/utils/index.d.ts.map +1 -0
- package/dist/lib/utils/index.js +27 -0
- package/dist/lib/utils/normalizeType.d.ts +3 -0
- package/dist/lib/utils/normalizeType.d.ts.map +1 -0
- package/dist/lib/utils/normalizeType.js +43 -0
- package/dist/lib/utils/objectId.d.ts +3 -0
- package/dist/lib/utils/objectId.d.ts.map +1 -0
- package/dist/lib/utils/objectId.js +9 -0
- package/dist/lib/utils/parseBehaviorDefinitionFromClass.d.ts +2 -0
- package/dist/lib/utils/parseBehaviorDefinitionFromClass.d.ts.map +1 -0
- package/dist/lib/utils/parseBehaviorDefinitionFromClass.js +10 -0
- package/dist/lib/utils/parseObjectSpec.d.ts +3 -0
- package/dist/lib/utils/parseObjectSpec.d.ts.map +1 -0
- package/dist/lib/utils/parseObjectSpec.js +27 -0
- package/dist/lib/utils/responseToText.d.ts +4 -0
- package/dist/lib/utils/responseToText.d.ts.map +1 -0
- package/dist/lib/utils/responseToText.js +11 -0
- package/dist/lib/utils/toBackupConfig.d.ts +3 -0
- package/dist/lib/utils/toBackupConfig.d.ts.map +1 -0
- package/dist/lib/utils/toBackupConfig.js +6 -0
- package/dist/lib/verify/collectBackupNodes.d.ts +3 -0
- package/dist/lib/verify/collectBackupNodes.d.ts.map +1 -0
- package/dist/lib/verify/collectBackupNodes.js +13 -0
- package/dist/lib/verify/findOtherType.d.ts +4 -0
- package/dist/lib/verify/findOtherType.d.ts.map +1 -0
- package/dist/lib/verify/findOtherType.js +41 -0
- package/dist/lib/verify/formatVerifyResultsText.d.ts +3 -0
- package/dist/lib/verify/formatVerifyResultsText.d.ts.map +1 -0
- package/dist/lib/verify/formatVerifyResultsText.js +30 -0
- package/dist/lib/verify/getExpectedPackage.d.ts +3 -0
- package/dist/lib/verify/getExpectedPackage.d.ts.map +1 -0
- package/dist/lib/verify/getExpectedPackage.js +14 -0
- package/dist/lib/verify/index.d.ts +8 -0
- package/dist/lib/verify/index.d.ts.map +1 -0
- package/dist/lib/verify/index.js +23 -0
- package/dist/lib/verify/types.d.ts +23 -0
- package/dist/lib/verify/types.d.ts.map +1 -0
- package/dist/lib/verify/types.js +2 -0
- package/dist/lib/verify/verifyBackup.d.ts +10 -0
- package/dist/lib/verify/verifyBackup.d.ts.map +1 -0
- package/dist/lib/verify/verifyBackup.js +54 -0
- package/dist/lib/verify/verifyObjectInSystem.d.ts +5 -0
- package/dist/lib/verify/verifyObjectInSystem.d.ts.map +1 -0
- package/dist/lib/verify/verifyObjectInSystem.js +136 -0
- package/dist/lib/xml/extractMetadata.d.ts +5 -0
- package/dist/lib/xml/extractMetadata.d.ts.map +1 -0
- package/dist/lib/xml/extractMetadata.js +13 -0
- package/dist/lib/xml/findAttribute.d.ts +3 -0
- package/dist/lib/xml/findAttribute.d.ts.map +1 -0
- package/dist/lib/xml/findAttribute.js +29 -0
- package/dist/lib/xml/findNode.d.ts +3 -0
- package/dist/lib/xml/findNode.d.ts.map +1 -0
- package/dist/lib/xml/findNode.js +30 -0
- package/dist/lib/xml/findNodeValue.d.ts +3 -0
- package/dist/lib/xml/findNodeValue.d.ts.map +1 -0
- package/dist/lib/xml/findNodeValue.js +11 -0
- package/dist/lib/xml/findPackageName.d.ts +3 -0
- package/dist/lib/xml/findPackageName.d.ts.map +1 -0
- package/dist/lib/xml/findPackageName.js +35 -0
- package/dist/lib/xml/flattenXmlAttributes.d.ts +2 -0
- package/dist/lib/xml/flattenXmlAttributes.d.ts.map +1 -0
- package/dist/lib/xml/flattenXmlAttributes.js +82 -0
- package/dist/lib/xml/getAttribute.d.ts +3 -0
- package/dist/lib/xml/getAttribute.d.ts.map +1 -0
- package/dist/lib/xml/getAttribute.js +12 -0
- package/dist/lib/xml/getNodeAttribute.d.ts +3 -0
- package/dist/lib/xml/getNodeAttribute.d.ts.map +1 -0
- package/dist/lib/xml/getNodeAttribute.js +11 -0
- package/dist/lib/xml/getNodeDescription.d.ts +3 -0
- package/dist/lib/xml/getNodeDescription.d.ts.map +1 -0
- package/dist/lib/xml/getNodeDescription.js +12 -0
- package/dist/lib/xml/getNodeName.d.ts +3 -0
- package/dist/lib/xml/getNodeName.d.ts.map +1 -0
- package/dist/lib/xml/getNodeName.js +12 -0
- package/dist/lib/xml/getNodeType.d.ts +3 -0
- package/dist/lib/xml/getNodeType.d.ts.map +1 -0
- package/dist/lib/xml/getNodeType.js +12 -0
- package/dist/lib/xml/index.d.ts +19 -0
- package/dist/lib/xml/index.d.ts.map +1 -0
- package/dist/lib/xml/index.js +34 -0
- package/dist/lib/xml/isNodeObject.d.ts +3 -0
- package/dist/lib/xml/isNodeObject.d.ts.map +1 -0
- package/dist/lib/xml/isNodeObject.js +12 -0
- package/dist/lib/xml/parseBehaviorDefinitionConfig.d.ts +3 -0
- package/dist/lib/xml/parseBehaviorDefinitionConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseBehaviorDefinitionConfig.js +40 -0
- package/dist/lib/xml/parseClassConfig.d.ts +3 -0
- package/dist/lib/xml/parseClassConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseClassConfig.js +59 -0
- package/dist/lib/xml/parseDataElementConfig.d.ts +3 -0
- package/dist/lib/xml/parseDataElementConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseDataElementConfig.js +67 -0
- package/dist/lib/xml/parseDomainConfig.d.ts +3 -0
- package/dist/lib/xml/parseDomainConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseDomainConfig.js +66 -0
- package/dist/lib/xml/parseEnhancementConfig.d.ts +3 -0
- package/dist/lib/xml/parseEnhancementConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseEnhancementConfig.js +73 -0
- package/dist/lib/xml/parsePackageConfig.d.ts +3 -0
- package/dist/lib/xml/parsePackageConfig.d.ts.map +1 -0
- package/dist/lib/xml/parsePackageConfig.js +48 -0
- package/dist/lib/xml/parseTableTypeConfig.d.ts +3 -0
- package/dist/lib/xml/parseTableTypeConfig.d.ts.map +1 -0
- package/dist/lib/xml/parseTableTypeConfig.js +64 -0
- package/dist/lib/xml/readAttr.d.ts +3 -0
- package/dist/lib/xml/readAttr.d.ts.map +1 -0
- package/dist/lib/xml/readAttr.js +16 -0
- package/dist/lib/xml/toBoolean.d.ts +2 -0
- package/dist/lib/xml/toBoolean.d.ts.map +1 -0
- package/dist/lib/xml/toBoolean.js +15 -0
- package/dist/lib/xml/toNumber.d.ts +2 -0
- package/dist/lib/xml/toNumber.d.ts.map +1 -0
- package/dist/lib/xml/toNumber.js +10 -0
- package/package.json +64 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025 Oleksii Kyslytsia
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
22
|
+
|
package/README.md
ADDED
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
# @mcp-abap-adt/adt-backup
|
|
2
|
+
|
|
3
|
+
CLI for recursive ADT backups and restores using `@mcp-abap-adt/adt-clients`.
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install -g @mcp-abap-adt/adt-backup
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Auth Configuration
|
|
12
|
+
|
|
13
|
+
The CLI uses `@mcp-abap-adt/auth-broker` with stores/providers.
|
|
14
|
+
|
|
15
|
+
Options:
|
|
16
|
+
- `--destination <name>`: destination name for AuthBroker stores
|
|
17
|
+
- `--auth-root <path>`: root folder with auth configs (defaults to `AUTH_BROKER_PATH` or cwd)
|
|
18
|
+
- `--env <file>`: use a specific `.env` file (via EnvFileSessionStore)
|
|
19
|
+
|
|
20
|
+
## Usage
|
|
21
|
+
|
|
22
|
+
```bash
|
|
23
|
+
# Package backup (recursive)
|
|
24
|
+
adt-backup backup --package ZPKG_TEST --output backup.yaml --destination TRIAL
|
|
25
|
+
|
|
26
|
+
# Verify (source-only by default)
|
|
27
|
+
adt-backup verify --input backup.yaml --destination TRIAL
|
|
28
|
+
|
|
29
|
+
# Diff (all objects)
|
|
30
|
+
adt-backup diff --input backup.yaml --all --destination TRIAL
|
|
31
|
+
|
|
32
|
+
# Restore (new objects and updates activate by default)
|
|
33
|
+
adt-backup restore --input backup.yaml --mode upsert --destination TRIAL
|
|
34
|
+
Use `--no-activate-on-create` or `--no-activate-on-update` to skip activation for the respective phases.
|
|
35
|
+
|
|
36
|
+
# Extract / patch a single object payload
|
|
37
|
+
adt-backup extract --input backup.yaml --object class:ZCL_TEST --out ZCL_TEST.abap
|
|
38
|
+
adt-backup patch --input backup.yaml --object class:ZCL_TEST --file ZCL_TEST.abap
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## Help
|
|
42
|
+
|
|
43
|
+
Get general help or command-specific usage information:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
# General help
|
|
47
|
+
adt-backup --help
|
|
48
|
+
|
|
49
|
+
# Command-specific help
|
|
50
|
+
adt-backup restore --help
|
|
51
|
+
adt-backup diff --help
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
## Logging
|
|
55
|
+
|
|
56
|
+
Use `-v` for main stages, `-vv` for per-object details, and `-vvv` for ADT/connection debug logs.
|
|
57
|
+
|
|
58
|
+
## Roadmap
|
|
59
|
+
|
|
60
|
+
See `docs/roadmap.yaml` for per-object backup/restore status and the plan for remaining types.
|
|
61
|
+
|
|
62
|
+
## Changelog
|
|
63
|
+
|
|
64
|
+
See [CHANGELOG.md](./CHANGELOG.md) for a history of changes.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adt-backup.d.ts","sourceRoot":"","sources":["../../src/bin/adt-backup.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
const run_1 = require("../lib/run");
|
|
5
|
+
(0, run_1.run)().catch((error) => {
|
|
6
|
+
console.error(error instanceof Error ? error.message : error);
|
|
7
|
+
process.exit(1);
|
|
8
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NoopTokenProvider.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/NoopTokenProvider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAE7E,qBAAa,iBAAkB,YAAW,cAAc;IAChD,SAAS,IAAI,OAAO,CAAC,YAAY,CAAC;CAKzC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NoopTokenProvider = void 0;
|
|
4
|
+
class NoopTokenProvider {
|
|
5
|
+
async getTokens() {
|
|
6
|
+
throw new Error('Token provider is not configured. Ensure your destination has authorization settings or use an .env session with JWT.');
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.NoopTokenProvider = NoopTokenProvider;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { IAuthorizationConfig, ITokenProvider } from '@mcp-abap-adt/interfaces';
|
|
2
|
+
import type { createLogger } from '../cli/createLogger';
|
|
3
|
+
export declare function createTokenProvider(authConfig?: IAuthorizationConfig | null, logger?: ReturnType<typeof createLogger>): ITokenProvider;
|
|
4
|
+
//# sourceMappingURL=createTokenProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTokenProvider.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/createTokenProvider.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,oBAAoB,EACpB,cAAc,EACf,MAAM,0BAA0B,CAAC;AAElC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGxD,wBAAgB,mBAAmB,CACjC,UAAU,CAAC,EAAE,oBAAoB,GAAG,IAAI,EACxC,MAAM,CAAC,EAAE,UAAU,CAAC,OAAO,YAAY,CAAC,GACvC,cAAc,CAkBhB"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createTokenProvider = createTokenProvider;
|
|
4
|
+
const auth_providers_1 = require("@mcp-abap-adt/auth-providers");
|
|
5
|
+
const NoopTokenProvider_1 = require("../auth/NoopTokenProvider");
|
|
6
|
+
const shouldEnableProviderLogger_1 = require("../cli/shouldEnableProviderLogger");
|
|
7
|
+
function createTokenProvider(authConfig, logger) {
|
|
8
|
+
if (!authConfig ||
|
|
9
|
+
!authConfig.uaaUrl ||
|
|
10
|
+
!authConfig.uaaClientId ||
|
|
11
|
+
!authConfig.uaaClientSecret) {
|
|
12
|
+
return new NoopTokenProvider_1.NoopTokenProvider();
|
|
13
|
+
}
|
|
14
|
+
return new auth_providers_1.AuthorizationCodeProvider({
|
|
15
|
+
uaaUrl: authConfig.uaaUrl,
|
|
16
|
+
clientId: authConfig.uaaClientId,
|
|
17
|
+
clientSecret: authConfig.uaaClientSecret,
|
|
18
|
+
refreshToken: authConfig.refreshToken,
|
|
19
|
+
browser: 'system',
|
|
20
|
+
logger: (0, shouldEnableProviderLogger_1.shouldEnableProviderLogger)() ? logger : undefined,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { SapConfig } from '@mcp-abap-adt/connection';
|
|
2
|
+
import type { ITokenRefresher } from '@mcp-abap-adt/interfaces';
|
|
3
|
+
import type { createLogger } from '../cli/createLogger';
|
|
4
|
+
export declare function getSapConfigFromBroker(options: {
|
|
5
|
+
destination?: string;
|
|
6
|
+
envPath?: string;
|
|
7
|
+
authRoot?: string;
|
|
8
|
+
logger: ReturnType<typeof createLogger>;
|
|
9
|
+
}): Promise<{
|
|
10
|
+
config: SapConfig;
|
|
11
|
+
tokenRefresher?: ITokenRefresher;
|
|
12
|
+
}>;
|
|
13
|
+
//# sourceMappingURL=getSapConfigFromBroker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getSapConfigFromBroker.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/getSapConfigFromBroker.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAKxD,wBAAsB,sBAAsB,CAAC,OAAO,EAAE;IACpD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,UAAU,CAAC,OAAO,YAAY,CAAC,CAAC;CACzC,GAAG,OAAO,CAAC;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,cAAc,CAAC,EAAE,eAAe,CAAA;CAAE,CAAC,CA4BnE"}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.getSapConfigFromBroker = getSapConfigFromBroker;
|
|
37
|
+
const fs = __importStar(require("node:fs"));
|
|
38
|
+
const os = __importStar(require("node:os"));
|
|
39
|
+
const path = __importStar(require("node:path"));
|
|
40
|
+
const auth_broker_1 = require("@mcp-abap-adt/auth-broker");
|
|
41
|
+
const auth_stores_1 = require("@mcp-abap-adt/auth-stores");
|
|
42
|
+
const shouldEnableBrokerLogger_1 = require("../cli/shouldEnableBrokerLogger");
|
|
43
|
+
const shouldEnableStoreLogger_1 = require("../cli/shouldEnableStoreLogger");
|
|
44
|
+
const createTokenProvider_1 = require("./createTokenProvider");
|
|
45
|
+
async function getSapConfigFromBroker(options) {
|
|
46
|
+
const { logger } = options;
|
|
47
|
+
const brokerLogger = (0, shouldEnableBrokerLogger_1.shouldEnableBrokerLogger)() ? logger : undefined;
|
|
48
|
+
const storeLogger = (0, shouldEnableStoreLogger_1.shouldEnableStoreLogger)() ? logger : undefined;
|
|
49
|
+
const destination = options.destination || 'env';
|
|
50
|
+
if (options.envPath) {
|
|
51
|
+
const sessionStore = new auth_stores_1.EnvFileSessionStore(options.envPath, storeLogger);
|
|
52
|
+
return getConfigWithStores({
|
|
53
|
+
destination,
|
|
54
|
+
sessionStore,
|
|
55
|
+
serviceKeyStore: undefined,
|
|
56
|
+
logger,
|
|
57
|
+
brokerLogger,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
const roots = resolveAuthRoots(options.authRoot);
|
|
61
|
+
const { sessionDir, serviceKeyDir } = resolveStoreDirs(roots, destination);
|
|
62
|
+
const sessionStore = new auth_stores_1.AbapSessionStore(sessionDir, storeLogger);
|
|
63
|
+
const serviceKeyStore = new auth_stores_1.AbapServiceKeyStore(serviceKeyDir, storeLogger);
|
|
64
|
+
return getConfigWithStores({
|
|
65
|
+
destination,
|
|
66
|
+
sessionStore,
|
|
67
|
+
serviceKeyStore,
|
|
68
|
+
logger,
|
|
69
|
+
brokerLogger,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
function resolveAuthRoots(authRoot) {
|
|
73
|
+
if (authRoot) {
|
|
74
|
+
return [path.resolve(authRoot)];
|
|
75
|
+
}
|
|
76
|
+
const envPath = process.env.AUTH_BROKER_PATH;
|
|
77
|
+
if (envPath) {
|
|
78
|
+
return envPath
|
|
79
|
+
.split(/[:;]/)
|
|
80
|
+
.map((entry) => entry.trim())
|
|
81
|
+
.filter((entry) => entry.length > 0)
|
|
82
|
+
.map((entry) => path.resolve(entry));
|
|
83
|
+
}
|
|
84
|
+
if (process.platform === 'win32') {
|
|
85
|
+
return [path.join(os.homedir(), 'Documents', 'mcp-abap-adt')];
|
|
86
|
+
}
|
|
87
|
+
return [path.join(os.homedir(), '.config', 'mcp-abap-adt')];
|
|
88
|
+
}
|
|
89
|
+
function resolveStoreDirs(roots, destination) {
|
|
90
|
+
const candidates = roots.map((root) => {
|
|
91
|
+
const normalized = path.resolve(root);
|
|
92
|
+
if (normalized.endsWith(`${path.sep}sessions`)) {
|
|
93
|
+
return {
|
|
94
|
+
sessionDir: normalized,
|
|
95
|
+
serviceKeyDir: path.join(path.dirname(normalized), 'service-keys'),
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
if (normalized.endsWith(`${path.sep}service-keys`)) {
|
|
99
|
+
return {
|
|
100
|
+
sessionDir: path.join(path.dirname(normalized), 'sessions'),
|
|
101
|
+
serviceKeyDir: normalized,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
return {
|
|
105
|
+
sessionDir: path.join(normalized, 'sessions'),
|
|
106
|
+
serviceKeyDir: path.join(normalized, 'service-keys'),
|
|
107
|
+
};
|
|
108
|
+
});
|
|
109
|
+
for (const candidate of candidates) {
|
|
110
|
+
const sessionFile = path.join(candidate.sessionDir, `${destination}.env`);
|
|
111
|
+
const serviceKeyFile = path.join(candidate.serviceKeyDir, `${destination}.json`);
|
|
112
|
+
if (fs.existsSync(sessionFile) || fs.existsSync(serviceKeyFile)) {
|
|
113
|
+
return candidate;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
return candidates[0];
|
|
117
|
+
}
|
|
118
|
+
async function getConfigWithStores(options) {
|
|
119
|
+
const { destination, sessionStore, serviceKeyStore, logger, brokerLogger } = options;
|
|
120
|
+
const sessionAuthConfig = destination === 'env'
|
|
121
|
+
? null
|
|
122
|
+
: await sessionStore.getAuthorizationConfig(destination);
|
|
123
|
+
const serviceKeyAuthConfig = destination === 'env' || !serviceKeyStore?.getAuthorizationConfig
|
|
124
|
+
? null
|
|
125
|
+
: await serviceKeyStore.getAuthorizationConfig(destination);
|
|
126
|
+
const authConfig = sessionAuthConfig || serviceKeyAuthConfig;
|
|
127
|
+
const broker = new auth_broker_1.AuthBroker({
|
|
128
|
+
sessionStore,
|
|
129
|
+
serviceKeyStore,
|
|
130
|
+
tokenProvider: (0, createTokenProvider_1.createTokenProvider)(authConfig, logger),
|
|
131
|
+
}, undefined, brokerLogger);
|
|
132
|
+
const session = await sessionStore.loadSession(destination);
|
|
133
|
+
let connection = await broker.getConnectionConfig(destination);
|
|
134
|
+
if (!connection && authConfig && destination !== 'env') {
|
|
135
|
+
await broker.getToken(destination);
|
|
136
|
+
connection = await broker.getConnectionConfig(destination);
|
|
137
|
+
}
|
|
138
|
+
if (!connection) {
|
|
139
|
+
throw new Error(`Missing connection config for destination ${destination}`);
|
|
140
|
+
}
|
|
141
|
+
if (!connection.authorizationToken &&
|
|
142
|
+
!connection.username &&
|
|
143
|
+
!connection.password &&
|
|
144
|
+
authConfig &&
|
|
145
|
+
destination !== 'env') {
|
|
146
|
+
await broker.getToken(destination);
|
|
147
|
+
connection = await broker.getConnectionConfig(destination);
|
|
148
|
+
if (!connection) {
|
|
149
|
+
throw new Error(`Missing connection config for destination ${destination}`);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
const resolvedAuthType = connection.authorizationToken
|
|
153
|
+
? 'jwt'
|
|
154
|
+
: connection.username && connection.password
|
|
155
|
+
? 'basic'
|
|
156
|
+
: authConfig && destination !== 'env'
|
|
157
|
+
? 'jwt'
|
|
158
|
+
: connection.authType || 'basic';
|
|
159
|
+
const serviceUrl = connection.serviceUrl || session?.serviceUrl;
|
|
160
|
+
if (!serviceUrl) {
|
|
161
|
+
throw new Error(`Missing service URL for destination ${destination}`);
|
|
162
|
+
}
|
|
163
|
+
const config = {
|
|
164
|
+
url: serviceUrl,
|
|
165
|
+
authType: resolvedAuthType,
|
|
166
|
+
};
|
|
167
|
+
if (resolvedAuthType === 'jwt') {
|
|
168
|
+
if (!connection.authorizationToken) {
|
|
169
|
+
throw new Error(`Missing JWT token for destination ${destination}`);
|
|
170
|
+
}
|
|
171
|
+
config.jwtToken = connection.authorizationToken;
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
if (!connection.username || !connection.password) {
|
|
175
|
+
throw new Error(`Missing username/password for destination ${destination}`);
|
|
176
|
+
}
|
|
177
|
+
config.username = connection.username;
|
|
178
|
+
config.password = connection.password;
|
|
179
|
+
}
|
|
180
|
+
const tokenRefresher = resolvedAuthType === 'jwt'
|
|
181
|
+
? broker.createTokenRefresher(destination)
|
|
182
|
+
: undefined;
|
|
183
|
+
return { config, tokenRefresher };
|
|
184
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/auth/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./createTokenProvider"), exports);
|
|
18
|
+
__exportStar(require("./getSapConfigFromBroker"), exports);
|
|
19
|
+
__exportStar(require("./NoopTokenProvider"), exports);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backupObject.d.ts","sourceRoot":"","sources":["../../../src/lib/backup/backupObject.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,SAAS,EAGV,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAgB,YAAY,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAavE,wBAAsB,YAAY,CAChC,MAAM,EAAE,SAAS,EACjB,IAAI,EAAE,UAAU,GACf,OAAO,CAAC,YAAY,CAAC,CAuNvB"}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.backupObject = backupObject;
|
|
4
|
+
const applyConfigName_1 = require("../utils/applyConfigName");
|
|
5
|
+
const objectId_1 = require("../utils/objectId");
|
|
6
|
+
const parseBehaviorDefinitionFromClass_1 = require("../utils/parseBehaviorDefinitionFromClass");
|
|
7
|
+
const toBackupConfig_1 = require("../utils/toBackupConfig");
|
|
8
|
+
const extractMetadata_1 = require("../xml/extractMetadata");
|
|
9
|
+
const parseDataElementConfig_1 = require("../xml/parseDataElementConfig");
|
|
10
|
+
const parseDomainConfig_1 = require("../xml/parseDomainConfig");
|
|
11
|
+
const parsePackageConfig_1 = require("../xml/parsePackageConfig");
|
|
12
|
+
const readBasicMetadata_1 = require("./readBasicMetadata");
|
|
13
|
+
const readMetadataXmlForType_1 = require("./readMetadataXmlForType");
|
|
14
|
+
const readSourceText_1 = require("./readSourceText");
|
|
15
|
+
async function backupObject(client, spec) {
|
|
16
|
+
const id = (0, objectId_1.objectId)(spec);
|
|
17
|
+
switch (spec.type) {
|
|
18
|
+
case 'package': {
|
|
19
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
20
|
+
if (!metadataXml) {
|
|
21
|
+
throw new Error(`Package not found: ${spec.name}`);
|
|
22
|
+
}
|
|
23
|
+
const config = (0, parsePackageConfig_1.parsePackageConfig)(metadataXml);
|
|
24
|
+
return {
|
|
25
|
+
id,
|
|
26
|
+
type: spec.type,
|
|
27
|
+
name: spec.name,
|
|
28
|
+
config: (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, (0, toBackupConfig_1.toBackupConfig)(config)),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
case 'domain': {
|
|
32
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
33
|
+
if (!metadataXml) {
|
|
34
|
+
throw new Error(`Domain not found: ${spec.name}`);
|
|
35
|
+
}
|
|
36
|
+
const config = (0, parseDomainConfig_1.parseDomainConfig)(metadataXml);
|
|
37
|
+
return {
|
|
38
|
+
id,
|
|
39
|
+
type: spec.type,
|
|
40
|
+
name: spec.name,
|
|
41
|
+
config: (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, (0, toBackupConfig_1.toBackupConfig)(config)),
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
case 'dataElement': {
|
|
45
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
46
|
+
if (!metadataXml) {
|
|
47
|
+
throw new Error(`Data element not found: ${spec.name}`);
|
|
48
|
+
}
|
|
49
|
+
const config = (0, parseDataElementConfig_1.parseDataElementConfig)(metadataXml);
|
|
50
|
+
return {
|
|
51
|
+
id,
|
|
52
|
+
type: spec.type,
|
|
53
|
+
name: spec.name,
|
|
54
|
+
config: (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, (0, toBackupConfig_1.toBackupConfig)(config)),
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
case 'functionGroup': {
|
|
58
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
59
|
+
if (!metadataXml) {
|
|
60
|
+
throw new Error(`Function group not found: ${spec.name}`);
|
|
61
|
+
}
|
|
62
|
+
const metadata = (0, extractMetadata_1.extractMetadata)(metadataXml);
|
|
63
|
+
const config = {
|
|
64
|
+
functionGroupName: spec.name,
|
|
65
|
+
packageName: metadata.packageName,
|
|
66
|
+
description: metadata.description,
|
|
67
|
+
};
|
|
68
|
+
return {
|
|
69
|
+
id,
|
|
70
|
+
type: spec.type,
|
|
71
|
+
name: spec.name,
|
|
72
|
+
config: (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, (0, toBackupConfig_1.toBackupConfig)(config)),
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
case 'serviceDefinition': {
|
|
76
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
77
|
+
if (!metadataXml) {
|
|
78
|
+
throw new Error(`Service definition not found: ${spec.name}`);
|
|
79
|
+
}
|
|
80
|
+
const metadata = (0, extractMetadata_1.extractMetadata)(metadataXml);
|
|
81
|
+
const config = {
|
|
82
|
+
serviceDefinitionName: spec.name,
|
|
83
|
+
packageName: metadata.packageName,
|
|
84
|
+
description: metadata.description,
|
|
85
|
+
};
|
|
86
|
+
const source = await (0, readSourceText_1.readSourceText)(client, spec);
|
|
87
|
+
return {
|
|
88
|
+
id,
|
|
89
|
+
type: spec.type,
|
|
90
|
+
name: spec.name,
|
|
91
|
+
config: (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, (0, toBackupConfig_1.toBackupConfig)(config)),
|
|
92
|
+
source,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
case 'metadataExtension':
|
|
96
|
+
case 'behaviorDefinition': {
|
|
97
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
98
|
+
const metadata = metadataXml ? (0, extractMetadata_1.extractMetadata)(metadataXml) : {};
|
|
99
|
+
const source = await (0, readSourceText_1.readSourceText)(client, spec);
|
|
100
|
+
const config = (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, {
|
|
101
|
+
description: metadata.description,
|
|
102
|
+
packageName: metadata.packageName,
|
|
103
|
+
});
|
|
104
|
+
return {
|
|
105
|
+
id,
|
|
106
|
+
type: spec.type,
|
|
107
|
+
name: spec.name,
|
|
108
|
+
config,
|
|
109
|
+
source,
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
case 'behaviorImplementation':
|
|
113
|
+
case 'enhancement': {
|
|
114
|
+
const metadataXml = await (0, readMetadataXmlForType_1.readMetadataXmlForType)(client, spec.type, spec.name);
|
|
115
|
+
const metadata = metadataXml ? (0, extractMetadata_1.extractMetadata)(metadataXml) : {};
|
|
116
|
+
const source = await (0, readSourceText_1.readSourceText)(client, spec);
|
|
117
|
+
const config = (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, undefined, {
|
|
118
|
+
description: metadata.description,
|
|
119
|
+
packageName: metadata.packageName,
|
|
120
|
+
...(spec.type === 'behaviorImplementation' && source
|
|
121
|
+
? { behaviorDefinition: (0, parseBehaviorDefinitionFromClass_1.parseBehaviorDefinitionFromClass)(source) }
|
|
122
|
+
: {}),
|
|
123
|
+
});
|
|
124
|
+
return {
|
|
125
|
+
id,
|
|
126
|
+
type: spec.type,
|
|
127
|
+
name: spec.name,
|
|
128
|
+
config,
|
|
129
|
+
source,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
case 'functionModule': {
|
|
133
|
+
const basic = await (0, readBasicMetadata_1.readBasicMetadata)(client, spec);
|
|
134
|
+
const source = await (0, readSourceText_1.readSourceText)(client, spec);
|
|
135
|
+
const config = (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, spec.functionGroupName, {
|
|
136
|
+
functionGroupName: spec.functionGroupName,
|
|
137
|
+
functionModuleName: spec.name,
|
|
138
|
+
packageName: basic.packageName,
|
|
139
|
+
description: basic.description,
|
|
140
|
+
});
|
|
141
|
+
return {
|
|
142
|
+
id,
|
|
143
|
+
type: spec.type,
|
|
144
|
+
name: spec.name,
|
|
145
|
+
functionGroupName: spec.functionGroupName,
|
|
146
|
+
config,
|
|
147
|
+
source,
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
default: {
|
|
151
|
+
const basic = await (0, readBasicMetadata_1.readBasicMetadata)(client, spec);
|
|
152
|
+
const source = await (0, readSourceText_1.readSourceText)(client, spec);
|
|
153
|
+
const config = (0, applyConfigName_1.applyConfigName)(spec.type, spec.name, spec.functionGroupName, {
|
|
154
|
+
packageName: basic.packageName,
|
|
155
|
+
description: basic.description,
|
|
156
|
+
});
|
|
157
|
+
return {
|
|
158
|
+
id,
|
|
159
|
+
type: spec.type,
|
|
160
|
+
name: spec.name,
|
|
161
|
+
config,
|
|
162
|
+
source,
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/backup/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./backupObject"), exports);
|
|
18
|
+
__exportStar(require("./readBasicMetadata"), exports);
|
|
19
|
+
__exportStar(require("./readMetadataXmlForType"), exports);
|
|
20
|
+
__exportStar(require("./readSourceText"), exports);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { AdtClient } from '@mcp-abap-adt/adt-clients';
|
|
2
|
+
import type { ObjectSpec } from '../types';
|
|
3
|
+
export declare function readBasicMetadata(client: AdtClient, spec: ObjectSpec): Promise<{
|
|
4
|
+
description?: string;
|
|
5
|
+
packageName?: string;
|
|
6
|
+
}>;
|
|
7
|
+
//# sourceMappingURL=readBasicMetadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"readBasicMetadata.d.ts","sourceRoot":"","sources":["../../../src/lib/backup/readBasicMetadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,iBAAiB,CACrC,MAAM,EAAE,SAAS,EACjB,IAAI,EAAE,UAAU,GACf,OAAO,CAAC;IAAE,WAAW,CAAC,EAAE,MAAM,CAAC;IAAC,WAAW,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CA0DzD"}
|