jitar 0.1.0 → 0.1.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/dist/core/Implementation.js +7 -0
- package/dist/core/SegmentBuilder.js +0 -1
- package/dist/core/errors/UnknownParameter.d.ts +3 -0
- package/dist/core/errors/UnknownParameter.js +6 -0
- package/dist/runtime/ClientId.d.ts +4 -0
- package/dist/runtime/ClientId.js +11 -0
- package/dist/runtime/LocalRepository.d.ts +3 -3
- package/dist/runtime/LocalRepository.js +17 -9
- package/dist/runtime/caching/CacheBuilder.js +3 -3
- package/dist/runtime/serialization/ClassSerializer.js +16 -0
- package/dist/runtime/serialization/MapSerializer.d.ts +1 -0
- package/dist/runtime/serialization/MapSerializer.js +10 -0
- package/dist/runtime/serialization/SetSerializer.d.ts +1 -0
- package/dist/runtime/serialization/SetSerializer.js +7 -0
- package/dist/runtime/serialization/errors/InvalidPropertyType.d.ts +3 -0
- package/dist/runtime/serialization/errors/InvalidPropertyType.js +6 -0
- package/dist/server/configuration/RepositoryConfiguration.d.ts +1 -0
- package/dist/server/configuration/RepositoryConfiguration.js +7 -1
- package/dist/server/configuration/StandaloneConfiguration.d.ts +1 -0
- package/dist/server/configuration/StandaloneConfiguration.js +6 -0
- package/dist/server/controllers/ModulesController.js +6 -0
- package/dist/server/utils/LocalFileManager.d.ts +1 -0
- package/dist/server/utils/LocalFileManager.js +19 -11
- package/dist/server/utils/RuntimeConfigurator.js +9 -4
- package/package.json +26 -4
- package/.eslintignore +0 -3
- package/.eslintrc +0 -16
- package/coverage/clover.xml +0 -2483
- package/coverage/coverage-final.json +0 -56
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -356
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov-report/src/core/ErrorManager.ts.html +0 -139
- package/coverage/lcov-report/src/core/Implementation.ts.html +0 -244
- package/coverage/lcov-report/src/core/ImplementationBuilder.ts.html +0 -148
- package/coverage/lcov-report/src/core/Procedure.ts.html +0 -379
- package/coverage/lcov-report/src/core/Segment.ts.html +0 -271
- package/coverage/lcov-report/src/core/SegmentBuilder.ts.html +0 -250
- package/coverage/lcov-report/src/core/Version.ts.html +0 -289
- package/coverage/lcov-report/src/core/definitions/AccessLevel.ts.html +0 -94
- package/coverage/lcov-report/src/core/definitions/index.html +0 -116
- package/coverage/lcov-report/src/core/errors/ErrorManager.ts.html +0 -139
- package/coverage/lcov-report/src/core/errors/ImplementationNotFound.ts.html +0 -121
- package/coverage/lcov-report/src/core/errors/InvalidVersionNumber.ts.html +0 -121
- package/coverage/lcov-report/src/core/errors/MissingParameterValue.ts.html +0 -121
- package/coverage/lcov-report/src/core/errors/ProcedureNotFound.ts.html +0 -121
- package/coverage/lcov-report/src/core/errors/index.html +0 -161
- package/coverage/lcov-report/src/core/index.html +0 -191
- package/coverage/lcov-report/src/core/reflection/ParameterParser.ts.html +0 -307
- package/coverage/lcov-report/src/core/reflection/ReflectionHelper.ts.html +0 -439
- package/coverage/lcov-report/src/core/reflection/index.html +0 -131
- package/coverage/lcov-report/src/core/reflection/models/ReflectionField.ts.html +0 -151
- package/coverage/lcov-report/src/core/reflection/models/ReflectionParameter.ts.html +0 -139
- package/coverage/lcov-report/src/core/reflection/models/index.html +0 -131
- package/coverage/lcov-report/src/core/utils/FqnBuilder.ts.html +0 -115
- package/coverage/lcov-report/src/core/utils/index.html +0 -116
- package/coverage/lcov-report/src/hooks.ts.html +0 -88
- package/coverage/lcov-report/src/index.html +0 -116
- package/coverage/lcov-report/src/runtime/Gateway.ts.html +0 -139
- package/coverage/lcov-report/src/runtime/LocalGateway.ts.html +0 -364
- package/coverage/lcov-report/src/runtime/LocalNode.ts.html +0 -475
- package/coverage/lcov-report/src/runtime/LocalRepository.ts.html +0 -556
- package/coverage/lcov-report/src/runtime/Node.ts.html +0 -130
- package/coverage/lcov-report/src/runtime/NodeBalancer.ts.html +0 -268
- package/coverage/lcov-report/src/runtime/NodeMonitor.ts.html +0 -274
- package/coverage/lcov-report/src/runtime/Remote.ts.html +0 -562
- package/coverage/lcov-report/src/runtime/RemoteNode.ts.html +0 -232
- package/coverage/lcov-report/src/runtime/Repository.ts.html +0 -145
- package/coverage/lcov-report/src/runtime/Runtime.ts.html +0 -226
- package/coverage/lcov-report/src/runtime/caching/ImportRewriter.ts.html +0 -313
- package/coverage/lcov-report/src/runtime/caching/ModuleAppender.ts.html +0 -208
- package/coverage/lcov-report/src/runtime/caching/RemoteBuilder.ts.html +0 -238
- package/coverage/lcov-report/src/runtime/caching/SourceAppender.ts.html +0 -256
- package/coverage/lcov-report/src/runtime/caching/definitions/Keywords.ts.html +0 -94
- package/coverage/lcov-report/src/runtime/caching/definitions/index.html +0 -116
- package/coverage/lcov-report/src/runtime/caching/index.html +0 -146
- package/coverage/lcov-report/src/runtime/caching/models/ApplicationModule.ts.html +0 -175
- package/coverage/lcov-report/src/runtime/caching/models/Implementation.ts.html +0 -208
- package/coverage/lcov-report/src/runtime/caching/models/SegmentModule.ts.html +0 -163
- package/coverage/lcov-report/src/runtime/caching/models/index.html +0 -146
- package/coverage/lcov-report/src/runtime/errors/ClientNotFound.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/InvalidClientId.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/InvalidSegmentFile.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/ModuleNotLoaded.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/NoNodeAvailable.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/RepositoryNotAvaiable.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/RuntimeNotAvailable.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/errors/index.html +0 -206
- package/coverage/lcov-report/src/runtime/hooks/dependencies.ts.html +0 -142
- package/coverage/lcov-report/src/runtime/hooks/index.html +0 -131
- package/coverage/lcov-report/src/runtime/hooks/runtime.ts.html +0 -160
- package/coverage/lcov-report/src/runtime/index.html +0 -251
- package/coverage/lcov-report/src/runtime/models/File.ts.html +0 -151
- package/coverage/lcov-report/src/runtime/models/index.html +0 -116
- package/coverage/lcov-report/src/runtime/serialization/ArraySerializer.ts.html +0 -166
- package/coverage/lcov-report/src/runtime/serialization/ClassSerializer.ts.html +0 -400
- package/coverage/lcov-report/src/runtime/serialization/MapSerializer.ts.html +0 -217
- package/coverage/lcov-report/src/runtime/serialization/ObjectSerializer.ts.html +0 -211
- package/coverage/lcov-report/src/runtime/serialization/SetSerializer.ts.html +0 -178
- package/coverage/lcov-report/src/runtime/serialization/ValueSerializer.ts.html +0 -328
- package/coverage/lcov-report/src/runtime/serialization/errors/ClassNotFound.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/serialization/errors/InvalidClass.ts.html +0 -121
- package/coverage/lcov-report/src/runtime/serialization/errors/index.html +0 -131
- package/coverage/lcov-report/src/runtime/serialization/index.html +0 -191
- package/coverage/lcov-report/src/runtime/utils/ModuleAnalyser.ts.html +0 -265
- package/coverage/lcov-report/src/runtime/utils/ModuleLoader.ts.html +0 -238
- package/coverage/lcov-report/src/runtime/utils/UrlRewriter.ts.html +0 -262
- package/coverage/lcov-report/src/runtime/utils/index.html +0 -146
- package/coverage/lcov-report/test/_fixtures/core/Implementation.fixture.ts.html +0 -184
- package/coverage/lcov-report/test/_fixtures/core/Procedure.fixture.ts.html +0 -172
- package/coverage/lcov-report/test/_fixtures/core/Segment.fixture.ts.html +0 -193
- package/coverage/lcov-report/test/_fixtures/core/SegmentBuilder.fixture.ts.html +0 -220
- package/coverage/lcov-report/test/_fixtures/core/Version.fixture.ts.html +0 -139
- package/coverage/lcov-report/test/_fixtures/core/index.html +0 -176
- package/coverage/lcov-report/test/_fixtures/core/procedures/allDefault.ts.html +0 -100
- package/coverage/lcov-report/test/_fixtures/core/procedures/hasParameters.ts.html +0 -100
- package/coverage/lcov-report/test/_fixtures/core/procedures/hasVersion_v1_0_0.ts.html +0 -115
- package/coverage/lcov-report/test/_fixtures/core/procedures/hasVersion_v1_0_5.ts.html +0 -115
- package/coverage/lcov-report/test/_fixtures/core/procedures/hasVersion_v1_1_0.ts.html +0 -115
- package/coverage/lcov-report/test/_fixtures/core/procedures/hasVersion_v1_2_3.ts.html +0 -115
- package/coverage/lcov-report/test/_fixtures/core/procedures/inModule.ts.html +0 -115
- package/coverage/lcov-report/test/_fixtures/core/procedures/index.html +0 -251
- package/coverage/lcov-report/test/_fixtures/core/procedures/isBroken.ts.html +0 -112
- package/coverage/lcov-report/test/_fixtures/core/procedures/isPrivate.ts.html +0 -112
- package/coverage/lcov-report/test/_fixtures/core/procedures/isPublic.ts.html +0 -112
- package/coverage/lcov-report/test/_fixtures/core/reflection/ReflectionHelper.fixture.ts.html +0 -241
- package/coverage/lcov-report/test/_fixtures/core/reflection/index.html +0 -116
- package/coverage/lcov-report/test/_fixtures/core/segments/default.segment.ts.html +0 -94
- package/coverage/lcov-report/test/_fixtures/core/segments/index.html +0 -116
- package/coverage/lcov-report/test/_fixtures/runtime/LocalGateway.fixture.ts.html +0 -157
- package/coverage/lcov-report/test/_fixtures/runtime/LocalNode.fixture.ts.html +0 -133
- package/coverage/lcov-report/test/_fixtures/runtime/LocalRepository.fixture.ts.html +0 -304
- package/coverage/lcov-report/test/_fixtures/runtime/NodeBalancer.fixture.ts.html +0 -142
- package/coverage/lcov-report/test/_fixtures/runtime/NodeMonitor.fixture.ts.html +0 -187
- package/coverage/lcov-report/test/_fixtures/runtime/RemoteNode.fixture.ts.html +0 -109
- package/coverage/lcov-report/test/_fixtures/runtime/caching/ImportRewriter.fixture.ts.html +0 -304
- package/coverage/lcov-report/test/_fixtures/runtime/caching/ModuleAppender.fixture.ts.html +0 -181
- package/coverage/lcov-report/test/_fixtures/runtime/caching/RemoteBuilder.fixture.ts.html +0 -217
- package/coverage/lcov-report/test/_fixtures/runtime/caching/SourceAppender.fixture.ts.html +0 -178
- package/coverage/lcov-report/test/_fixtures/runtime/caching/index.html +0 -146
- package/coverage/lcov-report/test/_fixtures/runtime/index.html +0 -206
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/firstPrivateTask.ts.html +0 -109
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/firstPublicTask.ts.html +0 -118
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/fourthPublicTask.ts.html +0 -109
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/index.html +0 -191
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/secondPrivateTask.ts.html +0 -109
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/secondPublicTask.ts.html +0 -118
- package/coverage/lcov-report/test/_fixtures/runtime/procedures/thirdPublicTask.ts.html +0 -118
- package/coverage/lcov-report/test/_fixtures/runtime/segments/first.segment.files.ts.html +0 -85
- package/coverage/lcov-report/test/_fixtures/runtime/segments/first.segment.ts.html +0 -91
- package/coverage/lcov-report/test/_fixtures/runtime/segments/index.html +0 -161
- package/coverage/lcov-report/test/_fixtures/runtime/segments/second.segment.files.ts.html +0 -85
- package/coverage/lcov-report/test/_fixtures/runtime/segments/second.segment.ts.html +0 -91
- package/coverage/lcov-report/test/_fixtures/runtime/segments.ts.html +0 -319
- package/coverage/lcov-report/test/_fixtures/runtime/serialization/ValueSerializer.fixture.ts.html +0 -394
- package/coverage/lcov-report/test/_fixtures/runtime/serialization/index.html +0 -116
- package/coverage/lcov-report/test/_fixtures/runtime/utils/ModuleAnaliser.fixture.ts.html +0 -163
- package/coverage/lcov-report/test/_fixtures/runtime/utils/index.html +0 -116
- package/coverage/lcov.info +0 -3565
- package/dist/core/AccessLevel.d.ts +0 -5
- package/dist/core/AccessLevel.js +0 -6
- package/dist/core/ImplementationBuilder.d.ts +0 -4
- package/dist/core/ImplementationBuilder.js +0 -14
- package/dist/core/errors/ErrorManager.d.ts +0 -3
- package/dist/core/errors/ErrorManager.js +0 -11
- package/dist/runtime/RemoteNodeBuilder.d.ts +0 -4
- package/dist/runtime/RemoteNodeBuilder.js +0 -10
- package/dist/runtime/caching/CachBuilder.d.ts +0 -6
- package/dist/runtime/caching/CachBuilder.js +0 -150
- package/dist/runtime/caching/ModuleAppender.d.ts +0 -5
- package/dist/runtime/caching/ModuleAppender.js +0 -22
- package/dist/runtime/caching/errors/FunctionFilenameNotFound.d.ts +0 -3
- package/dist/runtime/caching/errors/FunctionFilenameNotFound.js +0 -5
- package/dist/runtime/caching/types/models/ApplicationModule.d.ts +0 -9
- package/dist/runtime/caching/types/models/ApplicationModule.js +0 -19
- package/dist/runtime/caching/types/models/Implementation.d.ts +0 -12
- package/dist/runtime/caching/types/models/Implementation.js +0 -27
- package/dist/runtime/caching/types/models/Procedure.d.ts +0 -9
- package/dist/runtime/caching/types/models/Procedure.js +0 -15
- package/dist/runtime/caching/types/models/Segment.d.ts +0 -10
- package/dist/runtime/caching/types/models/Segment.js +0 -16
- package/dist/runtime/caching/types/models/SegmentModule.d.ts +0 -10
- package/dist/runtime/caching/types/models/SegmentModule.js +0 -14
- package/dist/server/definitions/RuntimeMode.d.ts +0 -8
- package/dist/server/definitions/RuntimeMode.js +0 -9
- package/dist/server/models/RuntimeConfiguration.d.ts +0 -12
- package/dist/server/models/RuntimeConfiguration.js +0 -68
- package/dist/server/models/ServerOptions.d.ts +0 -4
- package/dist/server/models/ServerOptions.js +0 -25
- package/jest.config.js +0 -20
- package/src/client.ts +0 -18
- package/src/core/ErrorManager.ts +0 -18
- package/src/core/Implementation.ts +0 -53
- package/src/core/Procedure.ts +0 -98
- package/src/core/Segment.ts +0 -62
- package/src/core/SegmentBuilder.ts +0 -55
- package/src/core/Version.ts +0 -68
- package/src/core/definitions/AccessLevel.ts +0 -3
- package/src/core/errors/ImplementationNotFound.ts +0 -12
- package/src/core/errors/InvalidVersionNumber.ts +0 -12
- package/src/core/errors/MissingParameterValue.ts +0 -12
- package/src/core/errors/NotImplemented.ts +0 -12
- package/src/core/errors/ProcedureNotFound.ts +0 -12
- package/src/core/interfaces/Runner.ts +0 -7
- package/src/core/reflection/ParameterParser.ts +0 -74
- package/src/core/reflection/ReflectionHelper.ts +0 -118
- package/src/core/reflection/models/ReflectionField.ts +0 -22
- package/src/core/reflection/models/ReflectionParameter.ts +0 -18
- package/src/core/types/Component.ts +0 -8
- package/src/core/types/FlexObject.ts +0 -4
- package/src/core/types/Module.ts +0 -6
- package/src/core/types/SegmentImplementation.ts +0 -9
- package/src/core/types/SegmentModule.ts +0 -9
- package/src/core/types/SegmentProcedure.ts +0 -11
- package/src/core/utils/FqnBuilder.ts +0 -11
- package/src/hooks.ts +0 -2
- package/src/lib.ts +0 -7
- package/src/runtime/Gateway.ts +0 -18
- package/src/runtime/LocalGateway.ts +0 -93
- package/src/runtime/LocalNode.ts +0 -130
- package/src/runtime/LocalRepository.ts +0 -157
- package/src/runtime/Node.ts +0 -15
- package/src/runtime/NodeBalancer.ts +0 -61
- package/src/runtime/NodeMonitor.ts +0 -63
- package/src/runtime/Proxy.ts +0 -60
- package/src/runtime/Remote.ts +0 -157
- package/src/runtime/RemoteGateway.ts +0 -40
- package/src/runtime/RemoteNode.ts +0 -49
- package/src/runtime/RemoteRepository.ts +0 -60
- package/src/runtime/Repository.ts +0 -20
- package/src/runtime/Runtime.ts +0 -47
- package/src/runtime/caching/CacheBuilder.ts +0 -424
- package/src/runtime/caching/ImportRewriter.ts +0 -76
- package/src/runtime/caching/RemoteBuilder.ts +0 -51
- package/src/runtime/caching/SourceAppender.ts +0 -57
- package/src/runtime/caching/definitions/Keywords.ts +0 -3
- package/src/runtime/caching/errors/InvalidSegmentFilename.ts +0 -8
- package/src/runtime/caching/errors/MissingModuleExport.ts +0 -8
- package/src/runtime/caching/errors/SegmentFileNotLoaded.ts +0 -8
- package/src/runtime/caching/errors/SegmentModuleNotLoaded.ts +0 -8
- package/src/runtime/caching/models/ApplicationModule.ts +0 -30
- package/src/runtime/caching/models/Implementation.ts +0 -41
- package/src/runtime/caching/models/Procedure.ts +0 -26
- package/src/runtime/caching/models/Segment.ts +0 -28
- package/src/runtime/caching/models/SegmentModule.ts +0 -26
- package/src/runtime/caching/types/SegmentFile.ts +0 -6
- package/src/runtime/caching/types/SegmentImportProperties.ts +0 -9
- package/src/runtime/caching/types/SegmentImports.ts +0 -6
- package/src/runtime/errors/ClientNotFound.ts +0 -12
- package/src/runtime/errors/FileNotFound.ts +0 -12
- package/src/runtime/errors/InvalidClientId.ts +0 -12
- package/src/runtime/errors/InvalidJitarHooks.ts +0 -12
- package/src/runtime/errors/InvalidSegmentFile.ts +0 -12
- package/src/runtime/errors/ModuleNotLoaded.ts +0 -12
- package/src/runtime/errors/NoNodeAvailable.ts +0 -12
- package/src/runtime/errors/RepositoryNotAvaiable.ts +0 -12
- package/src/runtime/errors/RuntimeNotAvailable.ts +0 -12
- package/src/runtime/errors/SegmentNotFound.ts +0 -12
- package/src/runtime/hooks/dependencies.ts +0 -19
- package/src/runtime/hooks/runtime.ts +0 -25
- package/src/runtime/interfaces/FileManager.ts +0 -19
- package/src/runtime/interfaces/HealthCheck.ts +0 -5
- package/src/runtime/interfaces/ProcedureContainer.ts +0 -9
- package/src/runtime/models/File.ts +0 -22
- package/src/runtime/serialization/ArraySerializer.ts +0 -27
- package/src/runtime/serialization/ClassSerializer.ts +0 -105
- package/src/runtime/serialization/MapSerializer.ts +0 -44
- package/src/runtime/serialization/ObjectSerializer.ts +0 -42
- package/src/runtime/serialization/SetSerializer.ts +0 -31
- package/src/runtime/serialization/ValueSerializer.ts +0 -81
- package/src/runtime/serialization/errors/ClassNotFound.ts +0 -12
- package/src/runtime/serialization/errors/InvalidClass.ts +0 -12
- package/src/runtime/serialization/interfaces/Serializer.ts +0 -10
- package/src/runtime/serialization/types/SerializableObject.ts +0 -6
- package/src/runtime/serialization/types/Serialized.ts +0 -8
- package/src/runtime/serialization/types/SerializedClass.ts +0 -13
- package/src/runtime/serialization/types/SerializedMap.ts +0 -13
- package/src/runtime/serialization/types/SerializedObject.ts +0 -4
- package/src/runtime/serialization/types/SerializedSet.ts +0 -9
- package/src/runtime/types/JitarHooks.ts +0 -10
- package/src/runtime/types/ModuleImporter.ts +0 -6
- package/src/runtime/utils/ModuleAnalyser.ts +0 -60
- package/src/runtime/utils/ModuleLoader.ts +0 -51
- package/src/runtime/utils/UrlRewriter.ts +0 -59
- package/src/server/JitarServer.ts +0 -161
- package/src/server/configuration/GatewayConfiguration.ts +0 -9
- package/src/server/configuration/NodeConfiguration.ts +0 -15
- package/src/server/configuration/ProxyConfiguration.ts +0 -16
- package/src/server/configuration/RepositoryConfiguration.ts +0 -17
- package/src/server/configuration/RuntimeConfiguration.ts +0 -30
- package/src/server/configuration/ServerOptions.ts +0 -14
- package/src/server/configuration/StandaloneConfiguration.ts +0 -21
- package/src/server/controllers/AssetsController.ts +0 -59
- package/src/server/controllers/HealthController.ts +0 -41
- package/src/server/controllers/JitarController.ts +0 -18
- package/src/server/controllers/ModulesController.ts +0 -66
- package/src/server/controllers/NodesController.ts +0 -58
- package/src/server/controllers/ProceduresController.ts +0 -31
- package/src/server/controllers/ProxyController.ts +0 -38
- package/src/server/controllers/RPCController.ts +0 -173
- package/src/server/definitions/RuntimeDefaults.ts +0 -10
- package/src/server/errors/MissingConfigurationValue.ts +0 -8
- package/src/server/errors/RuntimeNotAvaiable.ts +0 -8
- package/src/server/errors/UnknownRuntimeMode.ts +0 -8
- package/src/server/models/HealthDto.ts +0 -11
- package/src/server/models/NodeDto.ts +0 -11
- package/src/server/utils/DataConverter.ts +0 -15
- package/src/server/utils/LocalFileManager.ts +0 -122
- package/src/server/utils/RuntimeConfigurationLoader.ts +0 -19
- package/src/server/utils/RuntimeConfigurator.ts +0 -207
- package/src/server/utils/ServerOptionsReader.ts +0 -17
- package/src/server.ts +0 -16
- package/test/_fixtures/core/Implementation.fixture.ts +0 -33
- package/test/_fixtures/core/Procedure.fixture.ts +0 -33
- package/test/_fixtures/core/Segment.fixture.ts +0 -36
- package/test/_fixtures/core/SegmentBuilder.fixture.ts +0 -45
- package/test/_fixtures/core/Version.fixture.ts +0 -18
- package/test/_fixtures/core/reflection/ReflectionHelper.fixture.ts +0 -56
- package/test/_fixtures/runtime/LocalGateway.fixture.ts +0 -24
- package/test/_fixtures/runtime/LocalNode.fixture.ts +0 -16
- package/test/_fixtures/runtime/LocalRepository.fixture.ts +0 -73
- package/test/_fixtures/runtime/NodeBalancer.fixture.ts +0 -19
- package/test/_fixtures/runtime/NodeMonitor.fixture.ts +0 -34
- package/test/_fixtures/runtime/RemoteNode.fixture.ts +0 -8
- package/test/_fixtures/runtime/caching/ImportRewriter.fixture.ts +0 -81
- package/test/_fixtures/runtime/caching/RemoteBuilder.fixture.ts +0 -50
- package/test/_fixtures/runtime/caching/SourceAppender.fixture.ts +0 -35
- package/test/_fixtures/runtime/segments.ts +0 -78
- package/test/_fixtures/runtime/serialization/ValueSerializer.fixture.ts +0 -134
- package/test/_fixtures/runtime/utils/ModuleAnaliser.fixture.ts +0 -26
- package/test/core/Implementation.spec.ts +0 -89
- package/test/core/Procedure.spec.ts +0 -108
- package/test/core/Segment.spec.ts +0 -74
- package/test/core/SegmentBuilder.spec.ts +0 -39
- package/test/core/Version.spec.ts +0 -103
- package/test/core/errors/ErrorManager.spec.ts +0 -32
- package/test/core/reflection/ReflectionHelper.spec.ts +0 -128
- package/test/core/utils/FqnBuilder.spec.ts +0 -22
- package/test/runtime/LocalGateway.spec.ts +0 -40
- package/test/runtime/LocalNode.spec.ts +0 -87
- package/test/runtime/LocalRepository.spec.ts +0 -50
- package/test/runtime/NodeBalancer.spec.ts +0 -39
- package/test/runtime/NodeMonitor.spec.ts +0 -31
- package/test/runtime/RemoteNode.spec.ts +0 -43
- package/test/runtime/caching/ImportRewriter.spec.ts +0 -68
- package/test/runtime/caching/RemoteBuilder.spec.ts +0 -21
- package/test/runtime/caching/SourceAppender.spec.ts +0 -31
- package/test/runtime/serialization/ValueSerializer.spec.ts +0 -203
- package/test/runtime/utils/ModuleAnalyser.spec.ts +0 -54
- package/test/runtime/utils/UrlRewriter.spec.ts +0 -57
- package/tsconfig.json +0 -23
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller } from '@overnightjs/core';
|
|
3
|
-
import express, { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import FileNotFound from '../../runtime/errors/FileNotFound.js';
|
|
7
|
-
import LocalRepository from '../../runtime/LocalRepository.js';
|
|
8
|
-
import Proxy from '../../runtime/Proxy.js';
|
|
9
|
-
|
|
10
|
-
@Controller('')
|
|
11
|
-
export default class AssetsController
|
|
12
|
-
{
|
|
13
|
-
#repository: LocalRepository | Proxy;
|
|
14
|
-
#indexFile: string;
|
|
15
|
-
#logger: Logger;
|
|
16
|
-
|
|
17
|
-
constructor(app: express.Application, repository: LocalRepository | Proxy, indexFile: string, logger: Logger)
|
|
18
|
-
{
|
|
19
|
-
this.#repository = repository;
|
|
20
|
-
this.#indexFile = indexFile;
|
|
21
|
-
this.#logger = logger;
|
|
22
|
-
|
|
23
|
-
app.get('*', (request: Request, response: Response) => { this.#getContent(request, response) })
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
async #getContent(request: Request, response: Response): Promise<void>
|
|
27
|
-
{
|
|
28
|
-
this.#logger.info(`Got asset -> '${request.path}'`);
|
|
29
|
-
|
|
30
|
-
const path = request.path.substring(1).trim();
|
|
31
|
-
const filename = path.length === 0 ? this.#indexFile : path;
|
|
32
|
-
|
|
33
|
-
try
|
|
34
|
-
{
|
|
35
|
-
const file = await this.#repository.loadAsset(filename);
|
|
36
|
-
|
|
37
|
-
response.set('Content-Type', file.type);
|
|
38
|
-
response.set('Content-Length', String(file.size));
|
|
39
|
-
response.status(200).send(file.content);
|
|
40
|
-
}
|
|
41
|
-
catch (error: unknown)
|
|
42
|
-
{
|
|
43
|
-
if (error instanceof FileNotFound)
|
|
44
|
-
{
|
|
45
|
-
this.#logger.warn(`Failed to get asset -> '${filename}' | ${error.message}`);
|
|
46
|
-
|
|
47
|
-
response.status(404).send(error.message);
|
|
48
|
-
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
53
|
-
|
|
54
|
-
this.#logger.error(`Failed to get file content -> '${filename}' | ${message}`);
|
|
55
|
-
|
|
56
|
-
response.status(500).send(message);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller, Get } from '@overnightjs/core';
|
|
3
|
-
import { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import LocalNode from '../../runtime/LocalNode.js';
|
|
7
|
-
import Proxy from '../../runtime/Proxy.js';
|
|
8
|
-
|
|
9
|
-
@Controller('health')
|
|
10
|
-
export default class HealthController
|
|
11
|
-
{
|
|
12
|
-
#node: LocalNode | Proxy;
|
|
13
|
-
#logger: Logger;
|
|
14
|
-
|
|
15
|
-
constructor(node: LocalNode | Proxy, logger: Logger)
|
|
16
|
-
{
|
|
17
|
-
this.#node = node;
|
|
18
|
-
this.#logger = logger;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
@Get()
|
|
22
|
-
async getHealth(request: Request, response: Response): Promise<Response>
|
|
23
|
-
{
|
|
24
|
-
const health = await this.#node.getHealth();
|
|
25
|
-
const data = Object.fromEntries(health);
|
|
26
|
-
|
|
27
|
-
this.#logger.debug('Got health');
|
|
28
|
-
|
|
29
|
-
return response.status(200).send(data);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
@Get('status')
|
|
33
|
-
async isHealthy(request: Request, response: Response): Promise<Response>
|
|
34
|
-
{
|
|
35
|
-
const healthy = await this.#node.isHealthy();
|
|
36
|
-
|
|
37
|
-
this.#logger.debug('Got health status');
|
|
38
|
-
|
|
39
|
-
return response.status(200).send(healthy);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller } from '@overnightjs/core';
|
|
3
|
-
import express from 'express';
|
|
4
|
-
import path from 'path';
|
|
5
|
-
import { fileURLToPath } from 'url';
|
|
6
|
-
|
|
7
|
-
const filePath = fileURLToPath(import.meta.url);
|
|
8
|
-
const fileLocation = path.dirname(filePath);
|
|
9
|
-
const rootLocation = path.join(fileLocation, '../../')
|
|
10
|
-
|
|
11
|
-
@Controller('')
|
|
12
|
-
export default class JitarController
|
|
13
|
-
{
|
|
14
|
-
constructor(app: express.Application)
|
|
15
|
-
{
|
|
16
|
-
app.use('/jitar', express.static(rootLocation));
|
|
17
|
-
}
|
|
18
|
-
}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller, Get, Post } from '@overnightjs/core';
|
|
3
|
-
import { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import LocalRepository from '../../runtime/LocalRepository.js';
|
|
7
|
-
import Proxy from '../../runtime/Proxy.js';
|
|
8
|
-
import ValueSerializer from '../../runtime/serialization/ValueSerializer.js';
|
|
9
|
-
|
|
10
|
-
@Controller('modules')
|
|
11
|
-
export default class ModulesController
|
|
12
|
-
{
|
|
13
|
-
#repository: LocalRepository | Proxy;
|
|
14
|
-
#logger: Logger;
|
|
15
|
-
|
|
16
|
-
constructor(repository: LocalRepository | Proxy, logger: Logger)
|
|
17
|
-
{
|
|
18
|
-
this.#repository = repository;
|
|
19
|
-
this.#logger = logger;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
@Post()
|
|
23
|
-
async registerClient(request: Request, response: Response): Promise<Response>
|
|
24
|
-
{
|
|
25
|
-
const segmentFiles = request.body as string[];
|
|
26
|
-
|
|
27
|
-
const clientId = await this.#repository.registerClient(segmentFiles);
|
|
28
|
-
|
|
29
|
-
this.#logger.info(`Registered client -> ${clientId} [${segmentFiles.join(',')}]`);
|
|
30
|
-
|
|
31
|
-
return response.status(200).send(clientId);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
@Get(':clientId/*')
|
|
35
|
-
async getModule(request: Request, response: Response): Promise<Response>
|
|
36
|
-
{
|
|
37
|
-
const clientId = request.params.clientId;
|
|
38
|
-
|
|
39
|
-
const pathKey = `/${clientId}/`;
|
|
40
|
-
const pathIndex = request.path.indexOf(pathKey) + pathKey.length;
|
|
41
|
-
const filename = request.path.substring(pathIndex);
|
|
42
|
-
|
|
43
|
-
try
|
|
44
|
-
{
|
|
45
|
-
const file = await this.#repository.loadModule(clientId, filename);
|
|
46
|
-
|
|
47
|
-
this.#logger.info(`Got module -> '${filename}' (${clientId})`);
|
|
48
|
-
|
|
49
|
-
response.set('Content-Type', file.type);
|
|
50
|
-
|
|
51
|
-
return response.status(200).send(file.content);
|
|
52
|
-
}
|
|
53
|
-
catch (error: unknown)
|
|
54
|
-
{
|
|
55
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
56
|
-
|
|
57
|
-
this.#logger.error(`Failed to get module -> '${filename}' (${clientId}) | ${message}`);
|
|
58
|
-
|
|
59
|
-
const data = ValueSerializer.serialize(error);
|
|
60
|
-
|
|
61
|
-
response.setHeader('Content-Type', 'application/json');
|
|
62
|
-
|
|
63
|
-
return response.status(500).send(data);
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller, Get, Post } from '@overnightjs/core';
|
|
3
|
-
import { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import LocalGateway from '../../runtime/LocalGateway.js';
|
|
7
|
-
import RemoteNode from '../../runtime/RemoteNode.js';
|
|
8
|
-
|
|
9
|
-
import NodeDto from '../models/NodeDto.js';
|
|
10
|
-
import DataConverter from '../utils/DataConverter.js';
|
|
11
|
-
|
|
12
|
-
@Controller('nodes')
|
|
13
|
-
export default class NodesController
|
|
14
|
-
{
|
|
15
|
-
#gateway: LocalGateway;
|
|
16
|
-
#logger: Logger;
|
|
17
|
-
|
|
18
|
-
constructor(gateway: LocalGateway, logger: Logger)
|
|
19
|
-
{
|
|
20
|
-
this.#gateway = gateway;
|
|
21
|
-
this.#logger = logger;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
@Get()
|
|
25
|
-
async getNodes(request: Request, response: Response): Promise<Response>
|
|
26
|
-
{
|
|
27
|
-
const nodes = this.#gateway.nodes.map(node => { return { url: node.url, procedureNames: node.getProcedureNames() }; });
|
|
28
|
-
|
|
29
|
-
this.#logger.info('Got nodes');
|
|
30
|
-
|
|
31
|
-
return response.status(200).send(nodes);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
@Post()
|
|
35
|
-
async add(request: Request, response: Response): Promise<Response>
|
|
36
|
-
{
|
|
37
|
-
try
|
|
38
|
-
{
|
|
39
|
-
const nodeDto = await DataConverter.convert(NodeDto, request.body);
|
|
40
|
-
const node = new RemoteNode(nodeDto.url, nodeDto.procedureNames);
|
|
41
|
-
|
|
42
|
-
this.#gateway.addNode(node);
|
|
43
|
-
|
|
44
|
-
this.#logger.info(`Added node -> ${node.url}`);
|
|
45
|
-
|
|
46
|
-
return response.status(201).send();
|
|
47
|
-
}
|
|
48
|
-
catch (error: unknown)
|
|
49
|
-
{
|
|
50
|
-
const status = error instanceof Array ? 400 : 500;
|
|
51
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
52
|
-
|
|
53
|
-
this.#logger.error(`Failed to add node | ${message}`);
|
|
54
|
-
|
|
55
|
-
return response.status(status).send(error);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller, Get } from '@overnightjs/core';
|
|
3
|
-
import { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import LocalGateway from '../../runtime/LocalGateway.js';
|
|
7
|
-
import LocalNode from '../../runtime/LocalNode.js';
|
|
8
|
-
import Proxy from '../../runtime/Proxy.js';
|
|
9
|
-
|
|
10
|
-
@Controller('procedures')
|
|
11
|
-
export default class ProceduresController
|
|
12
|
-
{
|
|
13
|
-
#runtime: LocalGateway | LocalNode | Proxy;
|
|
14
|
-
#logger: Logger;
|
|
15
|
-
|
|
16
|
-
constructor(runtime: LocalGateway | LocalNode | Proxy, logger: Logger)
|
|
17
|
-
{
|
|
18
|
-
this.#runtime = runtime;
|
|
19
|
-
this.#logger = logger;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
@Get()
|
|
23
|
-
async getProcedureNames(request: Request, response: Response): Promise<Response>
|
|
24
|
-
{
|
|
25
|
-
const names = this.#runtime.getProcedureNames();
|
|
26
|
-
|
|
27
|
-
this.#logger.info('Got procedure names');
|
|
28
|
-
|
|
29
|
-
return response.status(200).send(names);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller } from '@overnightjs/core';
|
|
3
|
-
import express from 'express';
|
|
4
|
-
import expressProxy from 'express-http-proxy';
|
|
5
|
-
import { IncomingMessage } from 'http';
|
|
6
|
-
import { Logger } from 'tslog';
|
|
7
|
-
|
|
8
|
-
import Proxy from '../../runtime/Proxy.js';
|
|
9
|
-
|
|
10
|
-
@Controller('')
|
|
11
|
-
export default class ProxyController
|
|
12
|
-
{
|
|
13
|
-
#logger: Logger;
|
|
14
|
-
|
|
15
|
-
#repositoryUrl: string;
|
|
16
|
-
#runnerUrl: string;
|
|
17
|
-
|
|
18
|
-
constructor(app: express.Application, proxy: Proxy, logger: Logger)
|
|
19
|
-
{
|
|
20
|
-
this.#logger = logger;
|
|
21
|
-
|
|
22
|
-
this.#repositoryUrl = proxy.repository.url ?? '';
|
|
23
|
-
this.#runnerUrl = proxy.runner.url ?? '';
|
|
24
|
-
|
|
25
|
-
app.use('/', expressProxy((message: IncomingMessage): string => this.#selectProxy(message)));
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
#selectProxy(message: IncomingMessage): string
|
|
29
|
-
{
|
|
30
|
-
const url = message.url ?? '';
|
|
31
|
-
|
|
32
|
-
this.#logger.info(`Forwarding -> ${url}`);
|
|
33
|
-
|
|
34
|
-
return url.startsWith('/rpc')
|
|
35
|
-
? this.#runnerUrl
|
|
36
|
-
: this.#repositoryUrl;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Controller, Get, Post } from '@overnightjs/core';
|
|
3
|
-
import { Request, Response } from 'express';
|
|
4
|
-
import { Logger } from 'tslog';
|
|
5
|
-
|
|
6
|
-
import Version from '../../core/Version.js';
|
|
7
|
-
|
|
8
|
-
import ProcedureContainer from '../../runtime/interfaces/ProcedureContainer.js';
|
|
9
|
-
import ValueSerializer from '../../runtime/serialization/ValueSerializer.js';
|
|
10
|
-
|
|
11
|
-
const RPC_PARAMETERS = ['version', 'serialize'];
|
|
12
|
-
|
|
13
|
-
@Controller('rpc')
|
|
14
|
-
export default class RPCController
|
|
15
|
-
{
|
|
16
|
-
#runtime: ProcedureContainer;
|
|
17
|
-
#logger: Logger;
|
|
18
|
-
#useSerializer: boolean;
|
|
19
|
-
|
|
20
|
-
constructor(runtime: ProcedureContainer, logger: Logger, useSerializer: boolean)
|
|
21
|
-
{
|
|
22
|
-
this.#runtime = runtime;
|
|
23
|
-
this.#logger = logger;
|
|
24
|
-
this.#useSerializer = useSerializer;
|
|
25
|
-
|
|
26
|
-
this.#showProcedureInfo();
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
#showProcedureInfo()
|
|
30
|
-
{
|
|
31
|
-
const procedureNames = this.#runtime.getProcedureNames();
|
|
32
|
-
|
|
33
|
-
if (procedureNames.length === 0)
|
|
34
|
-
{
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
procedureNames.sort();
|
|
39
|
-
|
|
40
|
-
this.#logger.info('Registered RPC entries', procedureNames);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
@Get('*')
|
|
44
|
-
async runGet(request: Request, response: Response): Promise<Response>
|
|
45
|
-
{
|
|
46
|
-
const fqn = this.#extractFqn(request);
|
|
47
|
-
const version = this.#extractVersion(request);
|
|
48
|
-
const args = this.#extractQueryArguments(request);
|
|
49
|
-
const serialize = this.#extractSerialize(request);
|
|
50
|
-
|
|
51
|
-
return this.#run(fqn, version, args, response, serialize);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
@Post('*')
|
|
55
|
-
async runPost(request: Request, response: Response): Promise<Response>
|
|
56
|
-
{
|
|
57
|
-
const fqn = this.#extractFqn(request);
|
|
58
|
-
const version = this.#extractVersion(request);
|
|
59
|
-
const args = await this.#extractBodyArguments(request);
|
|
60
|
-
const serialize = this.#extractSerialize(request);
|
|
61
|
-
|
|
62
|
-
return this.#run(fqn, version, args, response, serialize);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
#extractFqn(request: Request): string
|
|
66
|
-
{
|
|
67
|
-
return request.path.substring(1);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
#extractVersion(request: Request): Version
|
|
71
|
-
{
|
|
72
|
-
return request.query.version !== undefined
|
|
73
|
-
? Version.parse(request.query.version.toString())
|
|
74
|
-
: Version.DEFAULT;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
#extractSerialize(request: Request): boolean
|
|
78
|
-
{
|
|
79
|
-
return request.query.serialize === 'true';
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
#extractQueryArguments(request: Request): Map<string, unknown>
|
|
83
|
-
{
|
|
84
|
-
const args = new Map<string, unknown>();
|
|
85
|
-
|
|
86
|
-
for (const [key, value] of Object.entries(request.query))
|
|
87
|
-
{
|
|
88
|
-
if (RPC_PARAMETERS.includes(key))
|
|
89
|
-
{
|
|
90
|
-
// We need to filter out the PRC parameters,
|
|
91
|
-
// because they are not a proceure argument.
|
|
92
|
-
|
|
93
|
-
continue;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
args.set(key, value);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
return args;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
async #extractBodyArguments(request: Request): Promise<Map<string, unknown>>
|
|
103
|
-
{
|
|
104
|
-
const args = this.#useSerializer
|
|
105
|
-
? await ValueSerializer.deserialize(request.body) as unknown
|
|
106
|
-
: request.body;
|
|
107
|
-
|
|
108
|
-
return new Map<string, unknown>(Object.entries(args));
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
async #run(fqn: string, version: Version, args: Map<string, unknown>, response: Response, serialize: boolean): Promise<Response>
|
|
112
|
-
{
|
|
113
|
-
if (this.#runtime.hasProcedure(fqn) === false)
|
|
114
|
-
{
|
|
115
|
-
return response.status(404).send(`Procedure not found -> ${fqn}`);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
try
|
|
119
|
-
{
|
|
120
|
-
const result = await this.#runtime.run(fqn, version, args);
|
|
121
|
-
|
|
122
|
-
this.#logger.info(`Ran procedure -> ${fqn} (${version.toString()})`);
|
|
123
|
-
|
|
124
|
-
return this.#createResultResponse(result, response, this.#useSerializer && serialize);
|
|
125
|
-
}
|
|
126
|
-
catch (error: unknown)
|
|
127
|
-
{
|
|
128
|
-
// When using the RPC API we need to return a human readable error message by default.
|
|
129
|
-
// Only when a serialized result is requested we can return the error object (used by the remote).
|
|
130
|
-
|
|
131
|
-
const message = error instanceof Error ? error.message : String(error);
|
|
132
|
-
const errorData = serialize ? error : message;
|
|
133
|
-
|
|
134
|
-
this.#logger.error(`Failed to run procedure -> ${fqn} (${version.toString()}) | ${message}`);
|
|
135
|
-
|
|
136
|
-
return this.#createErrorResponse(errorData, response, serialize);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
#createResultResponse(result: unknown, response: Response, serialize: boolean): Response
|
|
141
|
-
{
|
|
142
|
-
const content = this.#createResponseContent(result, serialize);
|
|
143
|
-
const contentType = this.#createResponseContentType(content);
|
|
144
|
-
|
|
145
|
-
response.setHeader('Content-Type', contentType);
|
|
146
|
-
|
|
147
|
-
return response.status(200).send(content);
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
#createErrorResponse(errorData: unknown, response: Response, serialize: boolean): Response
|
|
151
|
-
{
|
|
152
|
-
const content = this.#createResponseContent(errorData, serialize);
|
|
153
|
-
const contentType = this.#createResponseContentType(content);
|
|
154
|
-
|
|
155
|
-
response.setHeader('Content-Type', contentType);
|
|
156
|
-
|
|
157
|
-
return response.status(500).send(content);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
#createResponseContent(data: unknown, serialize: boolean): unknown
|
|
161
|
-
{
|
|
162
|
-
return serialize
|
|
163
|
-
? ValueSerializer.serialize(data)
|
|
164
|
-
: data;
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
#createResponseContentType(content: unknown): string
|
|
168
|
-
{
|
|
169
|
-
return typeof content === 'object'
|
|
170
|
-
? 'application/json'
|
|
171
|
-
: 'text/plain';
|
|
172
|
-
}
|
|
173
|
-
}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { ClassConstructor, plainToClass } from 'class-transformer';
|
|
3
|
-
import { validateOrReject } from 'class-validator';
|
|
4
|
-
|
|
5
|
-
export default class DataConverter
|
|
6
|
-
{
|
|
7
|
-
static async convert<Type extends Object>(targetClass: ClassConstructor<Type>, dataObject: object): Promise<Type>
|
|
8
|
-
{
|
|
9
|
-
const createdObject: Type = plainToClass(targetClass, dataObject);
|
|
10
|
-
|
|
11
|
-
await validateOrReject(createdObject);
|
|
12
|
-
|
|
13
|
-
return createdObject;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import fs from 'fs-extra';
|
|
3
|
-
import glob from 'glob-promise';
|
|
4
|
-
import mime from 'mime-types';
|
|
5
|
-
import path from 'path';
|
|
6
|
-
|
|
7
|
-
import FileNotFound from '../../runtime/errors/FileNotFound.js';
|
|
8
|
-
import FileManager from '../../runtime/interfaces/FileManager.js';
|
|
9
|
-
import File from '../../runtime/models/File.js';
|
|
10
|
-
|
|
11
|
-
export default class LocalFileManager implements FileManager
|
|
12
|
-
{
|
|
13
|
-
#location: string;
|
|
14
|
-
|
|
15
|
-
constructor(location: string)
|
|
16
|
-
{
|
|
17
|
-
this.#location = location;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
getRootLocation(): string
|
|
21
|
-
{
|
|
22
|
-
return path.resolve(this.#location);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
getAbsoluteLocation(filename: string): string
|
|
26
|
-
{
|
|
27
|
-
const location = filename.startsWith('/') ? filename : path.join(this.#location, filename);
|
|
28
|
-
|
|
29
|
-
return path.resolve(location);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
getRelativeLocation(filename: string): string
|
|
33
|
-
{
|
|
34
|
-
return path.relative(this.#location, filename);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
async getType(filename: string): Promise<string>
|
|
38
|
-
{
|
|
39
|
-
const location = this.getAbsoluteLocation(filename);
|
|
40
|
-
|
|
41
|
-
return mime.lookup(location) || 'application/octet-stream';
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
async getContent(filename: string): Promise<Buffer>
|
|
45
|
-
{
|
|
46
|
-
const location = this.getAbsoluteLocation(filename);
|
|
47
|
-
|
|
48
|
-
if (fs.existsSync(location) === false)
|
|
49
|
-
{
|
|
50
|
-
// Do NOT use the location in the error message,
|
|
51
|
-
// as it may contain sensitive information.
|
|
52
|
-
throw new FileNotFound(filename);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
return fs.readFile(location);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
async load(filename: string): Promise<File>
|
|
59
|
-
{
|
|
60
|
-
const type = await this.getType(filename);
|
|
61
|
-
const content = await this.getContent(filename);
|
|
62
|
-
|
|
63
|
-
return new File(filename, type, content);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
async store(filename: string, content: string): Promise<void>
|
|
67
|
-
{
|
|
68
|
-
const location = this.getAbsoluteLocation(filename);
|
|
69
|
-
const directory = path.dirname(location);
|
|
70
|
-
|
|
71
|
-
await fs.mkdir(directory, { recursive: true });
|
|
72
|
-
|
|
73
|
-
return fs.writeFile(location, content);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
async copy(source: string, destination: string): Promise<void>
|
|
77
|
-
{
|
|
78
|
-
const sourceLocation = this.getAbsoluteLocation(source);
|
|
79
|
-
const destinationLocation = this.getAbsoluteLocation(destination);
|
|
80
|
-
|
|
81
|
-
return fs.copy(sourceLocation, destinationLocation, { overwrite: true });
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
async remove(filename: string): Promise<void>
|
|
85
|
-
{
|
|
86
|
-
const location = this.getAbsoluteLocation(filename);
|
|
87
|
-
|
|
88
|
-
return fs.remove(location);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
async getModuleFileNames(): Promise<string[]>
|
|
92
|
-
{
|
|
93
|
-
const location = this.getAbsoluteLocation('./');
|
|
94
|
-
const filenames = await glob(`${location}/**/*.js`);
|
|
95
|
-
|
|
96
|
-
return filenames;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
async getSegmentFiles(): Promise<string[]>
|
|
100
|
-
{
|
|
101
|
-
const location = this.getAbsoluteLocation('./');
|
|
102
|
-
const filenames = await glob(`${location}/**/*.segment.json`);
|
|
103
|
-
|
|
104
|
-
return filenames;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
async getNodeSegmentFiles(): Promise<string[]>
|
|
108
|
-
{
|
|
109
|
-
const location = this.getAbsoluteLocation('./');
|
|
110
|
-
const filenames = await glob(`${location}/**/*.segment.local.js`);
|
|
111
|
-
|
|
112
|
-
return filenames;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
async getRepositorySegmentFiles(): Promise<string[]>
|
|
116
|
-
{
|
|
117
|
-
const location = this.getAbsoluteLocation('./');
|
|
118
|
-
const filenames = await glob(`${location}/**/*.segment.repository.js`);
|
|
119
|
-
|
|
120
|
-
return filenames;
|
|
121
|
-
}
|
|
122
|
-
}
|