@loonylabs/llm-middleware 2.0.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/.env.example +21 -0
- package/LICENSE +21 -0
- package/README.md +629 -0
- package/dist/examples/character-generator/character-generator.messages.d.ts +9 -0
- package/dist/examples/character-generator/character-generator.messages.d.ts.map +1 -0
- package/dist/examples/character-generator/character-generator.messages.js +54 -0
- package/dist/examples/character-generator/character-generator.messages.js.map +1 -0
- package/dist/examples/character-generator/character-generator.usecase.d.ts +129 -0
- package/dist/examples/character-generator/character-generator.usecase.d.ts.map +1 -0
- package/dist/examples/character-generator/character-generator.usecase.js +209 -0
- package/dist/examples/character-generator/character-generator.usecase.js.map +1 -0
- package/dist/examples/character-generator/create-character.messages.d.ts +11 -0
- package/dist/examples/character-generator/create-character.messages.d.ts.map +1 -0
- package/dist/examples/character-generator/create-character.messages.js +38 -0
- package/dist/examples/character-generator/create-character.messages.js.map +1 -0
- package/dist/examples/flat-formatter-demo/product-preset.example.d.ts +99 -0
- package/dist/examples/flat-formatter-demo/product-preset.example.d.ts.map +1 -0
- package/dist/examples/flat-formatter-demo/product-preset.example.js +85 -0
- package/dist/examples/flat-formatter-demo/product-preset.example.js.map +1 -0
- package/dist/examples/simple-chat/chat.controller.d.ts +15 -0
- package/dist/examples/simple-chat/chat.controller.d.ts.map +1 -0
- package/dist/examples/simple-chat/chat.controller.js +39 -0
- package/dist/examples/simple-chat/chat.controller.js.map +1 -0
- package/dist/examples/simple-chat/chat.messages.d.ts +10 -0
- package/dist/examples/simple-chat/chat.messages.d.ts.map +1 -0
- package/dist/examples/simple-chat/chat.messages.js +17 -0
- package/dist/examples/simple-chat/chat.messages.js.map +1 -0
- package/dist/examples/simple-chat/chat.usecase.d.ts +33 -0
- package/dist/examples/simple-chat/chat.usecase.d.ts.map +1 -0
- package/dist/examples/simple-chat/chat.usecase.js +40 -0
- package/dist/examples/simple-chat/chat.usecase.js.map +1 -0
- package/dist/examples/simple-chat/index.d.ts +3 -0
- package/dist/examples/simple-chat/index.d.ts.map +1 -0
- package/dist/examples/simple-chat/index.js +57 -0
- package/dist/examples/simple-chat/index.js.map +1 -0
- package/dist/examples/story-generator/story-generator.messages.d.ts +13 -0
- package/dist/examples/story-generator/story-generator.messages.d.ts.map +1 -0
- package/dist/examples/story-generator/story-generator.messages.js +41 -0
- package/dist/examples/story-generator/story-generator.messages.js.map +1 -0
- package/dist/examples/story-generator/story-generator.usecase.d.ts +115 -0
- package/dist/examples/story-generator/story-generator.usecase.d.ts.map +1 -0
- package/dist/examples/story-generator/story-generator.usecase.js +121 -0
- package/dist/examples/story-generator/story-generator.usecase.js.map +1 -0
- package/dist/examples/tweet-generator/tweet-generator.messages.d.ts +15 -0
- package/dist/examples/tweet-generator/tweet-generator.messages.d.ts.map +1 -0
- package/dist/examples/tweet-generator/tweet-generator.messages.js +40 -0
- package/dist/examples/tweet-generator/tweet-generator.messages.js.map +1 -0
- package/dist/examples/tweet-generator/tweet-generator.usecase.d.ts +92 -0
- package/dist/examples/tweet-generator/tweet-generator.usecase.d.ts.map +1 -0
- package/dist/examples/tweet-generator/tweet-generator.usecase.js +116 -0
- package/dist/examples/tweet-generator/tweet-generator.usecase.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/controllers/base/base.controller.d.ts +16 -0
- package/dist/middleware/controllers/base/base.controller.d.ts.map +1 -0
- package/dist/middleware/controllers/base/base.controller.js +38 -0
- package/dist/middleware/controllers/base/base.controller.js.map +1 -0
- package/dist/middleware/controllers/base/index.d.ts +2 -0
- package/dist/middleware/controllers/base/index.d.ts.map +1 -0
- package/dist/middleware/controllers/base/index.js +19 -0
- package/dist/middleware/controllers/base/index.js.map +1 -0
- package/dist/middleware/index.d.ts +7 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +27 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/services/data-flow-logger/data-flow-logger.service.d.ts +127 -0
- package/dist/middleware/services/data-flow-logger/data-flow-logger.service.d.ts.map +1 -0
- package/dist/middleware/services/data-flow-logger/data-flow-logger.service.js +341 -0
- package/dist/middleware/services/data-flow-logger/data-flow-logger.service.js.map +1 -0
- package/dist/middleware/services/data-flow-logger/index.d.ts +2 -0
- package/dist/middleware/services/data-flow-logger/index.d.ts.map +1 -0
- package/dist/middleware/services/data-flow-logger/index.js +18 -0
- package/dist/middleware/services/data-flow-logger/index.js.map +1 -0
- package/dist/middleware/services/flat-formatter/flat-formatter.service.d.ts +86 -0
- package/dist/middleware/services/flat-formatter/flat-formatter.service.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/flat-formatter.service.js +333 -0
- package/dist/middleware/services/flat-formatter/flat-formatter.service.js.map +1 -0
- package/dist/middleware/services/flat-formatter/index.d.ts +4 -0
- package/dist/middleware/services/flat-formatter/index.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/index.js +28 -0
- package/dist/middleware/services/flat-formatter/index.js.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/base-preset.d.ts +68 -0
- package/dist/middleware/services/flat-formatter/presets/base-preset.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/base-preset.js +238 -0
- package/dist/middleware/services/flat-formatter/presets/base-preset.js.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/index.d.ts +5 -0
- package/dist/middleware/services/flat-formatter/presets/index.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/index.js +28 -0
- package/dist/middleware/services/flat-formatter/presets/index.js.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/types/entity-types.d.ts +23 -0
- package/dist/middleware/services/flat-formatter/presets/types/entity-types.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/types/entity-types.js +3 -0
- package/dist/middleware/services/flat-formatter/presets/types/entity-types.js.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/types/processed-entity-types.d.ts +30 -0
- package/dist/middleware/services/flat-formatter/presets/types/processed-entity-types.d.ts.map +1 -0
- package/dist/middleware/services/flat-formatter/presets/types/processed-entity-types.js +3 -0
- package/dist/middleware/services/flat-formatter/presets/types/processed-entity-types.js.map +1 -0
- package/dist/middleware/services/index.d.ts +10 -0
- package/dist/middleware/services/index.d.ts.map +1 -0
- package/dist/middleware/services/index.js +28 -0
- package/dist/middleware/services/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/index.d.ts +3 -0
- package/dist/middleware/services/json-cleaner/helpers/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/index.js +19 -0
- package/dist/middleware/services/json-cleaner/helpers/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/json-cleaner.analyzer.d.ts +52 -0
- package/dist/middleware/services/json-cleaner/helpers/json-cleaner.analyzer.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/json-cleaner.analyzer.js +271 -0
- package/dist/middleware/services/json-cleaner/helpers/json-cleaner.analyzer.js.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/json-validation.helper.d.ts +83 -0
- package/dist/middleware/services/json-cleaner/helpers/json-validation.helper.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/helpers/json-validation.helper.js +326 -0
- package/dist/middleware/services/json-cleaner/helpers/json-validation.helper.js.map +1 -0
- package/dist/middleware/services/json-cleaner/index.d.ts +9 -0
- package/dist/middleware/services/json-cleaner/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/index.js +31 -0
- package/dist/middleware/services/json-cleaner/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner-logger.d.ts +59 -0
- package/dist/middleware/services/json-cleaner/json-cleaner-logger.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner-logger.js +164 -0
- package/dist/middleware/services/json-cleaner/json-cleaner-logger.js.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.orchestrator.d.ts +56 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.orchestrator.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.orchestrator.js +178 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.orchestrator.js.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.service.d.ts +94 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.service.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.service.js +175 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.service.js.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.types.d.ts +92 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.types.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.types.js +3 -0
- package/dist/middleware/services/json-cleaner/json-cleaner.types.js.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/index.d.ts +4 -0
- package/dist/middleware/services/json-cleaner/parsers/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/index.js +20 -0
- package/dist/middleware/services/json-cleaner/parsers/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/json-extractor.parser.d.ts +32 -0
- package/dist/middleware/services/json-cleaner/parsers/json-extractor.parser.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/json-extractor.parser.js +148 -0
- package/dist/middleware/services/json-cleaner/parsers/json-extractor.parser.js.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/markdown.parser.d.ts +19 -0
- package/dist/middleware/services/json-cleaner/parsers/markdown.parser.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/markdown.parser.js +43 -0
- package/dist/middleware/services/json-cleaner/parsers/markdown.parser.js.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/think-tag.parser.d.ts +19 -0
- package/dist/middleware/services/json-cleaner/parsers/think-tag.parser.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/parsers/think-tag.parser.js +37 -0
- package/dist/middleware/services/json-cleaner/parsers/think-tag.parser.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-context.d.ts +40 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-context.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-context.js +138 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-context.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-engine.d.ts +74 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-engine.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-engine.js +230 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-engine.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-recipe.d.ts +16 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-recipe.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-recipe.js +179 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/cleaning-recipe.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/conditions.d.ts +88 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/conditions.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/conditions.js +178 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/conditions.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-builder.d.ts +51 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-builder.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-builder.js +219 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-builder.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-steps.d.ts +62 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-steps.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-steps.js +217 -0
- package/dist/middleware/services/json-cleaner/recipe-system/core/recipe-steps.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/factory.d.ts +46 -0
- package/dist/middleware/services/json-cleaner/recipe-system/factory.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/factory.js +52 -0
- package/dist/middleware/services/json-cleaner/recipe-system/factory.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/index.d.ts +12 -0
- package/dist/middleware/services/json-cleaner/recipe-system/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/index.js +28 -0
- package/dist/middleware/services/json-cleaner/recipe-system/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/detectors.d.ts +55 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/detectors.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/detectors.js +348 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/detectors.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/fixers.d.ts +70 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/fixers.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/fixers.js +568 -0
- package/dist/middleware/services/json-cleaner/recipe-system/operations/fixers.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/recipes/templates.d.ts +11 -0
- package/dist/middleware/services/json-cleaner/recipe-system/recipes/templates.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/recipes/templates.js +103 -0
- package/dist/middleware/services/json-cleaner/recipe-system/recipes/templates.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/operation.types.d.ts +171 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/operation.types.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/operation.types.js +3 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/operation.types.js.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/recipe.types.d.ts +224 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/recipe.types.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/recipe.types.js +3 -0
- package/dist/middleware/services/json-cleaner/recipe-system/types/recipe.types.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/aggressive.cleaner.d.ts +29 -0
- package/dist/middleware/services/json-cleaner/strategies/aggressive.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/aggressive.cleaner.js +128 -0
- package/dist/middleware/services/json-cleaner/strategies/aggressive.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/base-cleaner.strategy.d.ts +38 -0
- package/dist/middleware/services/json-cleaner/strategies/base-cleaner.strategy.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/base-cleaner.strategy.js +18 -0
- package/dist/middleware/services/json-cleaner/strategies/base-cleaner.strategy.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/comma-fixer.cleaner.d.ts +65 -0
- package/dist/middleware/services/json-cleaner/strategies/comma-fixer.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/comma-fixer.cleaner.js +420 -0
- package/dist/middleware/services/json-cleaner/strategies/comma-fixer.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/control-character.cleaner.d.ts +50 -0
- package/dist/middleware/services/json-cleaner/strategies/control-character.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/control-character.cleaner.js +416 -0
- package/dist/middleware/services/json-cleaner/strategies/control-character.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/duplicate-key.cleaner.d.ts +27 -0
- package/dist/middleware/services/json-cleaner/strategies/duplicate-key.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/duplicate-key.cleaner.js +84 -0
- package/dist/middleware/services/json-cleaner/strategies/duplicate-key.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/index.d.ts +8 -0
- package/dist/middleware/services/json-cleaner/strategies/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/index.js +24 -0
- package/dist/middleware/services/json-cleaner/strategies/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/string-escaper.cleaner.d.ts +23 -0
- package/dist/middleware/services/json-cleaner/strategies/string-escaper.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/string-escaper.cleaner.js +65 -0
- package/dist/middleware/services/json-cleaner/strategies/string-escaper.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/structural-repair.cleaner.d.ts +48 -0
- package/dist/middleware/services/json-cleaner/strategies/structural-repair.cleaner.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/strategies/structural-repair.cleaner.js +188 -0
- package/dist/middleware/services/json-cleaner/strategies/structural-repair.cleaner.js.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/console-logger.util.d.ts +50 -0
- package/dist/middleware/services/json-cleaner/utils/console-logger.util.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/console-logger.util.js +95 -0
- package/dist/middleware/services/json-cleaner/utils/console-logger.util.js.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/control-char-diagnostics.util.d.ts +59 -0
- package/dist/middleware/services/json-cleaner/utils/control-char-diagnostics.util.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/control-char-diagnostics.util.js +326 -0
- package/dist/middleware/services/json-cleaner/utils/control-char-diagnostics.util.js.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/index.d.ts +3 -0
- package/dist/middleware/services/json-cleaner/utils/index.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/index.js +19 -0
- package/dist/middleware/services/json-cleaner/utils/index.js.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/json-inspector.util.d.ts +27 -0
- package/dist/middleware/services/json-cleaner/utils/json-inspector.util.d.ts.map +1 -0
- package/dist/middleware/services/json-cleaner/utils/json-inspector.util.js +139 -0
- package/dist/middleware/services/json-cleaner/utils/json-inspector.util.js.map +1 -0
- package/dist/middleware/services/llm/index.d.ts +5 -0
- package/dist/middleware/services/llm/index.d.ts.map +1 -0
- package/dist/middleware/services/llm/index.js +25 -0
- package/dist/middleware/services/llm/index.js.map +1 -0
- package/dist/middleware/services/llm/llm.service.d.ts +43 -0
- package/dist/middleware/services/llm/llm.service.d.ts.map +1 -0
- package/dist/middleware/services/llm/llm.service.js +70 -0
- package/dist/middleware/services/llm/llm.service.js.map +1 -0
- package/dist/middleware/services/llm/providers/base-llm-provider.d.ts +37 -0
- package/dist/middleware/services/llm/providers/base-llm-provider.d.ts.map +1 -0
- package/dist/middleware/services/llm/providers/base-llm-provider.js +41 -0
- package/dist/middleware/services/llm/providers/base-llm-provider.js.map +1 -0
- package/dist/middleware/services/llm/providers/index.d.ts +3 -0
- package/dist/middleware/services/llm/providers/index.d.ts.map +1 -0
- package/dist/middleware/services/llm/providers/index.js +25 -0
- package/dist/middleware/services/llm/providers/index.js.map +1 -0
- package/dist/middleware/services/llm/providers/ollama-provider.d.ts +39 -0
- package/dist/middleware/services/llm/providers/ollama-provider.d.ts.map +1 -0
- package/dist/middleware/services/llm/providers/ollama-provider.js +398 -0
- package/dist/middleware/services/llm/providers/ollama-provider.js.map +1 -0
- package/dist/middleware/services/llm/types/common.types.d.ts +81 -0
- package/dist/middleware/services/llm/types/common.types.d.ts.map +1 -0
- package/dist/middleware/services/llm/types/common.types.js +17 -0
- package/dist/middleware/services/llm/types/common.types.js.map +1 -0
- package/dist/middleware/services/llm/types/index.d.ts +3 -0
- package/dist/middleware/services/llm/types/index.d.ts.map +1 -0
- package/dist/middleware/services/llm/types/index.js +21 -0
- package/dist/middleware/services/llm/types/index.js.map +1 -0
- package/dist/middleware/services/llm/types/ollama.types.d.ts +48 -0
- package/dist/middleware/services/llm/types/ollama.types.d.ts.map +1 -0
- package/dist/middleware/services/llm/types/ollama.types.js +8 -0
- package/dist/middleware/services/llm/types/ollama.types.js.map +1 -0
- package/dist/middleware/services/llm/utils/debug-llm.utils.d.ts +42 -0
- package/dist/middleware/services/llm/utils/debug-llm.utils.d.ts.map +1 -0
- package/dist/middleware/services/llm/utils/debug-llm.utils.js +325 -0
- package/dist/middleware/services/llm/utils/debug-llm.utils.js.map +1 -0
- package/dist/middleware/services/llm/utils/index.d.ts +3 -0
- package/dist/middleware/services/llm/utils/index.d.ts.map +1 -0
- package/dist/middleware/services/llm/utils/index.js +19 -0
- package/dist/middleware/services/llm/utils/index.js.map +1 -0
- package/dist/middleware/services/llm/utils/text-analysis.utils.d.ts +75 -0
- package/dist/middleware/services/llm/utils/text-analysis.utils.d.ts.map +1 -0
- package/dist/middleware/services/llm/utils/text-analysis.utils.js +197 -0
- package/dist/middleware/services/llm/utils/text-analysis.utils.js.map +1 -0
- package/dist/middleware/services/model-parameter-manager/index.d.ts +2 -0
- package/dist/middleware/services/model-parameter-manager/index.d.ts.map +1 -0
- package/dist/middleware/services/model-parameter-manager/index.js +18 -0
- package/dist/middleware/services/model-parameter-manager/index.js.map +1 -0
- package/dist/middleware/services/model-parameter-manager/model-parameter-manager.service.d.ts +165 -0
- package/dist/middleware/services/model-parameter-manager/model-parameter-manager.service.d.ts.map +1 -0
- package/dist/middleware/services/model-parameter-manager/model-parameter-manager.service.js +325 -0
- package/dist/middleware/services/model-parameter-manager/model-parameter-manager.service.js.map +1 -0
- package/dist/middleware/services/request-formatter/index.d.ts +2 -0
- package/dist/middleware/services/request-formatter/index.d.ts.map +1 -0
- package/dist/middleware/services/request-formatter/index.js +18 -0
- package/dist/middleware/services/request-formatter/index.js.map +1 -0
- package/dist/middleware/services/request-formatter/request-formatter.service.d.ts +71 -0
- package/dist/middleware/services/request-formatter/request-formatter.service.d.ts.map +1 -0
- package/dist/middleware/services/request-formatter/request-formatter.service.js +230 -0
- package/dist/middleware/services/request-formatter/request-formatter.service.js.map +1 -0
- package/dist/middleware/services/response-processor.service.d.ts +106 -0
- package/dist/middleware/services/response-processor.service.d.ts.map +1 -0
- package/dist/middleware/services/response-processor.service.js +236 -0
- package/dist/middleware/services/response-processor.service.js.map +1 -0
- package/dist/middleware/services/token-estimator/index.d.ts +2 -0
- package/dist/middleware/services/token-estimator/index.d.ts.map +1 -0
- package/dist/middleware/services/token-estimator/index.js +18 -0
- package/dist/middleware/services/token-estimator/index.js.map +1 -0
- package/dist/middleware/services/token-estimator/token-estimator.service.d.ts +97 -0
- package/dist/middleware/services/token-estimator/token-estimator.service.d.ts.map +1 -0
- package/dist/middleware/services/token-estimator/token-estimator.service.js +190 -0
- package/dist/middleware/services/token-estimator/token-estimator.service.js.map +1 -0
- package/dist/middleware/services/use-case-metrics-logger/index.d.ts +2 -0
- package/dist/middleware/services/use-case-metrics-logger/index.d.ts.map +1 -0
- package/dist/middleware/services/use-case-metrics-logger/index.js +18 -0
- package/dist/middleware/services/use-case-metrics-logger/index.js.map +1 -0
- package/dist/middleware/services/use-case-metrics-logger/use-case-metrics-logger.service.d.ts +89 -0
- package/dist/middleware/services/use-case-metrics-logger/use-case-metrics-logger.service.d.ts.map +1 -0
- package/dist/middleware/services/use-case-metrics-logger/use-case-metrics-logger.service.js +112 -0
- package/dist/middleware/services/use-case-metrics-logger/use-case-metrics-logger.service.js.map +1 -0
- package/dist/middleware/shared/config/app.config.d.ts +3 -0
- package/dist/middleware/shared/config/app.config.d.ts.map +1 -0
- package/dist/middleware/shared/config/app.config.js +76 -0
- package/dist/middleware/shared/config/app.config.js.map +1 -0
- package/dist/middleware/shared/config/index.d.ts +4 -0
- package/dist/middleware/shared/config/index.d.ts.map +1 -0
- package/dist/middleware/shared/config/index.js +21 -0
- package/dist/middleware/shared/config/index.js.map +1 -0
- package/dist/middleware/shared/config/logging.config.d.ts +49 -0
- package/dist/middleware/shared/config/logging.config.d.ts.map +1 -0
- package/dist/middleware/shared/config/logging.config.js +16 -0
- package/dist/middleware/shared/config/logging.config.js.map +1 -0
- package/dist/middleware/shared/config/models.config.d.ts +19 -0
- package/dist/middleware/shared/config/models.config.d.ts.map +1 -0
- package/dist/middleware/shared/config/models.config.js +39 -0
- package/dist/middleware/shared/config/models.config.js.map +1 -0
- package/dist/middleware/shared/constants/index.d.ts +2 -0
- package/dist/middleware/shared/constants/index.d.ts.map +1 -0
- package/dist/middleware/shared/constants/index.js +19 -0
- package/dist/middleware/shared/constants/index.js.map +1 -0
- package/dist/middleware/shared/constants/json-formatting.constants.d.ts +36 -0
- package/dist/middleware/shared/constants/json-formatting.constants.d.ts.map +1 -0
- package/dist/middleware/shared/constants/json-formatting.constants.js +81 -0
- package/dist/middleware/shared/constants/json-formatting.constants.js.map +1 -0
- package/dist/middleware/shared/types/base-request.types.d.ts +27 -0
- package/dist/middleware/shared/types/base-request.types.d.ts.map +1 -0
- package/dist/middleware/shared/types/base-request.types.js +3 -0
- package/dist/middleware/shared/types/base-request.types.js.map +1 -0
- package/dist/middleware/shared/types/client-info.d.ts +8 -0
- package/dist/middleware/shared/types/client-info.d.ts.map +1 -0
- package/dist/middleware/shared/types/client-info.js +3 -0
- package/dist/middleware/shared/types/client-info.js.map +1 -0
- package/dist/middleware/shared/types/index.d.ts +43 -0
- package/dist/middleware/shared/types/index.d.ts.map +1 -0
- package/dist/middleware/shared/types/index.js +20 -0
- package/dist/middleware/shared/types/index.js.map +1 -0
- package/dist/middleware/shared/utils/http.utils.d.ts +25 -0
- package/dist/middleware/shared/utils/http.utils.d.ts.map +1 -0
- package/dist/middleware/shared/utils/http.utils.js +44 -0
- package/dist/middleware/shared/utils/http.utils.js.map +1 -0
- package/dist/middleware/shared/utils/index.d.ts +5 -0
- package/dist/middleware/shared/utils/index.d.ts.map +1 -0
- package/dist/middleware/shared/utils/index.js +22 -0
- package/dist/middleware/shared/utils/index.js.map +1 -0
- package/dist/middleware/shared/utils/logging.utils.d.ts +30 -0
- package/dist/middleware/shared/utils/logging.utils.d.ts.map +1 -0
- package/dist/middleware/shared/utils/logging.utils.js +91 -0
- package/dist/middleware/shared/utils/logging.utils.js.map +1 -0
- package/dist/middleware/shared/utils/memory-management.utils.d.ts +10 -0
- package/dist/middleware/shared/utils/memory-management.utils.d.ts.map +1 -0
- package/dist/middleware/shared/utils/memory-management.utils.js +31 -0
- package/dist/middleware/shared/utils/memory-management.utils.js.map +1 -0
- package/dist/middleware/shared/utils/validation.utils.d.ts +12 -0
- package/dist/middleware/shared/utils/validation.utils.d.ts.map +1 -0
- package/dist/middleware/shared/utils/validation.utils.js +36 -0
- package/dist/middleware/shared/utils/validation.utils.js.map +1 -0
- package/dist/middleware/usecases/base/base-ai.usecase.d.ts +72 -0
- package/dist/middleware/usecases/base/base-ai.usecase.d.ts.map +1 -0
- package/dist/middleware/usecases/base/base-ai.usecase.js +125 -0
- package/dist/middleware/usecases/base/base-ai.usecase.js.map +1 -0
- package/dist/middleware/usecases/base/index.d.ts +2 -0
- package/dist/middleware/usecases/base/index.d.ts.map +1 -0
- package/dist/middleware/usecases/base/index.js +18 -0
- package/dist/middleware/usecases/base/index.js.map +1 -0
- package/package.json +97 -0
|
@@ -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("./think-tag.parser"), exports);
|
|
18
|
+
__exportStar(require("./markdown.parser"), exports);
|
|
19
|
+
__exportStar(require("./json-extractor.parser"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,oDAAkC;AAClC,0DAAwC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Parser } from '../json-cleaner.types';
|
|
2
|
+
/**
|
|
3
|
+
* Advanced JSON extractor parser
|
|
4
|
+
* Attempts to extract valid JSON from complex responses
|
|
5
|
+
*/
|
|
6
|
+
export declare class JsonExtractor implements Parser {
|
|
7
|
+
name: string;
|
|
8
|
+
/**
|
|
9
|
+
* Check if this parser can handle the input
|
|
10
|
+
*/
|
|
11
|
+
canParse(input: string): boolean;
|
|
12
|
+
/**
|
|
13
|
+
* Parse and extract JSON using multiple extraction strategies
|
|
14
|
+
*/
|
|
15
|
+
parse(input: string): {
|
|
16
|
+
json: string;
|
|
17
|
+
thinking: string;
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Extract JSON block by finding balanced braces
|
|
21
|
+
*/
|
|
22
|
+
private extractJsonBlock;
|
|
23
|
+
/**
|
|
24
|
+
* Extract JSON using common patterns
|
|
25
|
+
*/
|
|
26
|
+
private extractByPattern;
|
|
27
|
+
/**
|
|
28
|
+
* Basic cleanup of common JSON issues
|
|
29
|
+
*/
|
|
30
|
+
private basicCleanup;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=json-extractor.parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"json-extractor.parser.d.ts","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/json-extractor.parser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C;;;GAGG;AACH,qBAAa,aAAc,YAAW,MAAM;IACnC,IAAI,SAAoB;IAE/B;;OAEG;IACI,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAKvC;;OAEG;IACI,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE;IA4B/D;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAgDxB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IA8BxB;;OAEG;IACH,OAAO,CAAC,YAAY;CAuBrB"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JsonExtractor = void 0;
|
|
4
|
+
const json_cleaner_logger_1 = require("../json-cleaner-logger");
|
|
5
|
+
/**
|
|
6
|
+
* Advanced JSON extractor parser
|
|
7
|
+
* Attempts to extract valid JSON from complex responses
|
|
8
|
+
*/
|
|
9
|
+
class JsonExtractor {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.name = 'JSON Extractor';
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Check if this parser can handle the input
|
|
15
|
+
*/
|
|
16
|
+
canParse(input) {
|
|
17
|
+
// Can handle any input as it's the fallback parser
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Parse and extract JSON using multiple extraction strategies
|
|
22
|
+
*/
|
|
23
|
+
parse(input) {
|
|
24
|
+
const originalInput = input;
|
|
25
|
+
let result = input.trim();
|
|
26
|
+
// Strategy 1: Try to find JSON blocks between curly braces
|
|
27
|
+
const jsonBlock = this.extractJsonBlock(result);
|
|
28
|
+
if (jsonBlock) {
|
|
29
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, originalInput, jsonBlock);
|
|
30
|
+
return { json: jsonBlock, thinking: '' };
|
|
31
|
+
}
|
|
32
|
+
// Strategy 2: Try to extract from patterns
|
|
33
|
+
const patternExtracted = this.extractByPattern(result);
|
|
34
|
+
if (patternExtracted) {
|
|
35
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, originalInput, patternExtracted);
|
|
36
|
+
return { json: patternExtracted, thinking: '' };
|
|
37
|
+
}
|
|
38
|
+
// Strategy 3: Clean obvious issues
|
|
39
|
+
const cleaned = this.basicCleanup(result);
|
|
40
|
+
if (cleaned !== result) {
|
|
41
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, originalInput, cleaned);
|
|
42
|
+
return { json: cleaned, thinking: '' };
|
|
43
|
+
}
|
|
44
|
+
return { json: result, thinking: '' };
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Extract JSON block by finding balanced braces
|
|
48
|
+
*/
|
|
49
|
+
extractJsonBlock(text) {
|
|
50
|
+
let braceCount = 0;
|
|
51
|
+
let startIndex = -1;
|
|
52
|
+
let inString = false;
|
|
53
|
+
let escapeNext = false;
|
|
54
|
+
for (let i = 0; i < text.length; i++) {
|
|
55
|
+
const char = text[i];
|
|
56
|
+
if (escapeNext) {
|
|
57
|
+
escapeNext = false;
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
if (char === '\\' && inString) {
|
|
61
|
+
escapeNext = true;
|
|
62
|
+
continue;
|
|
63
|
+
}
|
|
64
|
+
if (char === '"' && !escapeNext) {
|
|
65
|
+
inString = !inString;
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
if (!inString) {
|
|
69
|
+
if (char === '{') {
|
|
70
|
+
if (braceCount === 0) {
|
|
71
|
+
startIndex = i;
|
|
72
|
+
}
|
|
73
|
+
braceCount++;
|
|
74
|
+
}
|
|
75
|
+
else if (char === '}') {
|
|
76
|
+
braceCount--;
|
|
77
|
+
if (braceCount === 0 && startIndex >= 0) {
|
|
78
|
+
const jsonCandidate = text.substring(startIndex, i + 1);
|
|
79
|
+
try {
|
|
80
|
+
JSON.parse(jsonCandidate);
|
|
81
|
+
return jsonCandidate;
|
|
82
|
+
}
|
|
83
|
+
catch (e) {
|
|
84
|
+
// Continue searching
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return null;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Extract JSON using common patterns
|
|
94
|
+
*/
|
|
95
|
+
extractByPattern(text) {
|
|
96
|
+
// Pattern 1: JSON after "response:" or similar
|
|
97
|
+
const responsePattern = /(?:response|result|json|output):\s*(\{.*\})/is;
|
|
98
|
+
const responseMatch = text.match(responsePattern);
|
|
99
|
+
if (responseMatch) {
|
|
100
|
+
try {
|
|
101
|
+
JSON.parse(responseMatch[1]);
|
|
102
|
+
return responseMatch[1];
|
|
103
|
+
}
|
|
104
|
+
catch (e) {
|
|
105
|
+
// Continue with other patterns
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
// Pattern 2: JSON in the middle of text
|
|
109
|
+
const jsonPattern = /\{[^{}]*(?:\{[^{}]*\}[^{}]*)*\}/g;
|
|
110
|
+
const matches = text.match(jsonPattern);
|
|
111
|
+
if (matches) {
|
|
112
|
+
for (const match of matches) {
|
|
113
|
+
try {
|
|
114
|
+
JSON.parse(match);
|
|
115
|
+
return match;
|
|
116
|
+
}
|
|
117
|
+
catch (e) {
|
|
118
|
+
// Continue with next match
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Basic cleanup of common JSON issues
|
|
126
|
+
*/
|
|
127
|
+
basicCleanup(text) {
|
|
128
|
+
let result = text;
|
|
129
|
+
// Remove common prefixes
|
|
130
|
+
result = result.replace(/^(?:Here's the|The|Response:|Result:)\s*/i, '');
|
|
131
|
+
// Remove trailing text after JSON
|
|
132
|
+
const jsonMatch = result.match(/^(.*?)(?:\n\n|$)/s);
|
|
133
|
+
if (jsonMatch) {
|
|
134
|
+
result = jsonMatch[1];
|
|
135
|
+
}
|
|
136
|
+
// Fix common JSON issues
|
|
137
|
+
result = result
|
|
138
|
+
// Remove trailing commas
|
|
139
|
+
.replace(/,(\s*[}\]])/g, '$1')
|
|
140
|
+
// Fix single quotes
|
|
141
|
+
.replace(/'/g, '"')
|
|
142
|
+
// Remove control characters
|
|
143
|
+
.replace(/[\x00-\x1F\x7F]/g, '');
|
|
144
|
+
return result.trim();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
exports.JsonExtractor = JsonExtractor;
|
|
148
|
+
//# sourceMappingURL=json-extractor.parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"json-extractor.parser.js","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/json-extractor.parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Parser } from '../json-cleaner.types';
|
|
2
|
+
/**
|
|
3
|
+
* Parser for removing Markdown formatting from input
|
|
4
|
+
*/
|
|
5
|
+
export declare class MarkdownParser implements Parser {
|
|
6
|
+
name: string;
|
|
7
|
+
/**
|
|
8
|
+
* Check if this parser can handle the input
|
|
9
|
+
*/
|
|
10
|
+
canParse(input: string): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Parse and extract JSON by removing markdown blocks
|
|
13
|
+
*/
|
|
14
|
+
parse(input: string): {
|
|
15
|
+
json: string;
|
|
16
|
+
thinking: string;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=markdown.parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markdown.parser.d.ts","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/markdown.parser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C;;GAEG;AACH,qBAAa,cAAe,YAAW,MAAM;IACpC,IAAI,SAAqB;IAEhC;;OAEG;IACI,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAIvC;;OAEG;IACI,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE;CAwBhE"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MarkdownParser = void 0;
|
|
4
|
+
const json_cleaner_logger_1 = require("../json-cleaner-logger");
|
|
5
|
+
/**
|
|
6
|
+
* Parser for removing Markdown formatting from input
|
|
7
|
+
*/
|
|
8
|
+
class MarkdownParser {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.name = 'Markdown Parser';
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Check if this parser can handle the input
|
|
14
|
+
*/
|
|
15
|
+
canParse(input) {
|
|
16
|
+
return input.startsWith('```') || input.includes('```json') || input.includes('```');
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Parse and extract JSON by removing markdown blocks
|
|
20
|
+
*/
|
|
21
|
+
parse(input) {
|
|
22
|
+
let result = input;
|
|
23
|
+
// Remove Markdown JSON blocks
|
|
24
|
+
if (result.startsWith('```json')) {
|
|
25
|
+
const beforeMarkdown = result;
|
|
26
|
+
result = result.replace(/```json\s*/, '').replace(/\s*```$/, '');
|
|
27
|
+
if (beforeMarkdown !== result) {
|
|
28
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, beforeMarkdown, result);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
// Remove general Markdown blocks
|
|
32
|
+
else if (result.startsWith('```')) {
|
|
33
|
+
const beforeMarkdown = result;
|
|
34
|
+
result = result.replace(/```\s*/, '').replace(/\s*```$/, '');
|
|
35
|
+
if (beforeMarkdown !== result) {
|
|
36
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, beforeMarkdown, result);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return { json: result, thinking: '' };
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.MarkdownParser = MarkdownParser;
|
|
43
|
+
//# sourceMappingURL=markdown.parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markdown.parser.js","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/markdown.parser.ts"],"names":[],"mappings":";;;AAAA,gEAAgF;AAGhF;;GAEG;AACH,MAAa,cAAc;IAA3B;QACS,SAAI,GAAG,iBAAiB,CAAC;IAoClC,CAAC;IAlCC;;OAEG;IACI,QAAQ,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvF,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,KAAa;QACxB,IAAI,MAAM,GAAG,KAAK,CAAC;QAEnB,8BAA8B;QAC9B,IAAI,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YACjC,MAAM,cAAc,GAAG,MAAM,CAAC;YAC9B,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAEjE,IAAI,cAAc,KAAK,MAAM,EAAE,CAAC;gBAC9B,uCAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QACD,iCAAiC;aAC5B,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YAClC,MAAM,cAAc,GAAG,MAAM,CAAC;YAC9B,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAE7D,IAAI,cAAc,KAAK,MAAM,EAAE,CAAC;gBAC9B,uCAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;IACxC,CAAC;CACF;AArCD,wCAqCC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Parser } from '../json-cleaner.types';
|
|
2
|
+
/**
|
|
3
|
+
* Parser for removing <think>...</think> tags from input
|
|
4
|
+
*/
|
|
5
|
+
export declare class ThinkTagParser implements Parser {
|
|
6
|
+
name: string;
|
|
7
|
+
/**
|
|
8
|
+
* Check if this parser can handle the input
|
|
9
|
+
*/
|
|
10
|
+
canParse(input: string): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Parse and extract JSON by removing think tags
|
|
13
|
+
*/
|
|
14
|
+
parse(input: string): {
|
|
15
|
+
json: string;
|
|
16
|
+
thinking: string;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=think-tag.parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"think-tag.parser.d.ts","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/think-tag.parser.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C;;GAEG;AACH,qBAAa,cAAe,YAAW,MAAM;IACpC,IAAI,SAAsB;IAEjC;;OAEG;IACI,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAIvC;;OAEG;IACI,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE;CAkBhE"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ThinkTagParser = void 0;
|
|
4
|
+
const json_cleaner_logger_1 = require("../json-cleaner-logger");
|
|
5
|
+
/**
|
|
6
|
+
* Parser for removing <think>...</think> tags from input
|
|
7
|
+
*/
|
|
8
|
+
class ThinkTagParser {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.name = 'Think Tag Parser';
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Check if this parser can handle the input
|
|
14
|
+
*/
|
|
15
|
+
canParse(input) {
|
|
16
|
+
return input.includes('<think>') && input.includes('</think>');
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Parse and extract JSON by removing think tags
|
|
20
|
+
*/
|
|
21
|
+
parse(input) {
|
|
22
|
+
let thinking = '';
|
|
23
|
+
// Extract thinking content first
|
|
24
|
+
const thinkMatch = input.match(/<think>([\s\S]*?)<\/think>/);
|
|
25
|
+
if (thinkMatch && thinkMatch[1]) {
|
|
26
|
+
thinking = thinkMatch[1].trim();
|
|
27
|
+
}
|
|
28
|
+
// Remove <think>...</think> blocks from the text
|
|
29
|
+
const result = input.replace(/<think>[\s\S]*?<\/think>/g, '').trim();
|
|
30
|
+
if (input !== result) {
|
|
31
|
+
json_cleaner_logger_1.JsonCleanerLogger.logParser(this.name, input, result);
|
|
32
|
+
}
|
|
33
|
+
return { json: result, thinking };
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.ThinkTagParser = ThinkTagParser;
|
|
37
|
+
//# sourceMappingURL=think-tag.parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"think-tag.parser.js","sourceRoot":"","sources":["../../../../../src/middleware/services/json-cleaner/parsers/think-tag.parser.ts"],"names":[],"mappings":";;;AAAA,gEAAgF;AAGhF;;GAEG;AACH,MAAa,cAAc;IAA3B;QACS,SAAI,GAAG,kBAAkB,CAAC;IA8BnC,CAAC;IA5BC;;OAEG;IACI,QAAQ,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IACjE,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,KAAa;QACxB,IAAI,QAAQ,GAAG,EAAE,CAAC;QAElB,iCAAiC;QACjC,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAC7D,IAAI,UAAU,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;YAChC,QAAQ,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAClC,CAAC;QAED,iDAAiD;QACjD,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,2BAA2B,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QAErE,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;YACrB,uCAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QACxD,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IACpC,CAAC;CACF;AA/BD,wCA+BC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { CleaningContext, Detection, ChangeDescription, ContextMetadata, ContextStats, ChangeLocation } from '../types/operation.types';
|
|
2
|
+
export declare class CleaningContextImpl implements CleaningContext {
|
|
3
|
+
currentJson: string;
|
|
4
|
+
readonly originalJson: string;
|
|
5
|
+
readonly detections: Map<string, Detection[]>;
|
|
6
|
+
readonly checkpoints: Map<string, string>;
|
|
7
|
+
readonly changes: ChangeDescription[];
|
|
8
|
+
readonly metadata: ContextMetadata;
|
|
9
|
+
constructor(json: string, metadata?: Partial<ContextMetadata>);
|
|
10
|
+
addDetection(type: string, location: number | ChangeLocation, confidence?: number, metadata?: Record<string, any>): void;
|
|
11
|
+
hasDetection(type: string): boolean;
|
|
12
|
+
getDetections(type: string): Detection[];
|
|
13
|
+
createCheckpoint(name: string): void;
|
|
14
|
+
rollbackTo(name: string): boolean;
|
|
15
|
+
updateJson(newJson: string): void;
|
|
16
|
+
recordChange(change: ChangeDescription): void;
|
|
17
|
+
getStats(): ContextStats;
|
|
18
|
+
isValidJson(): boolean;
|
|
19
|
+
getDetectionsByConfidence(minConfidence?: number): Detection[];
|
|
20
|
+
getChangesByType(type: ChangeDescription['type']): ChangeDescription[];
|
|
21
|
+
getSizeChange(): number;
|
|
22
|
+
getChangeRate(): number;
|
|
23
|
+
analyzePatterns(): {
|
|
24
|
+
hasControlChars: boolean;
|
|
25
|
+
hasMissingCommas: boolean;
|
|
26
|
+
hasExtraCommas: boolean;
|
|
27
|
+
hasUnescapedQuotes: boolean;
|
|
28
|
+
hasStructuralIssues: boolean;
|
|
29
|
+
hasMarkdownBlocks: boolean;
|
|
30
|
+
hasThinkTags: boolean;
|
|
31
|
+
estimatedErrorCount: number;
|
|
32
|
+
};
|
|
33
|
+
private detectMissingCommas;
|
|
34
|
+
private detectExtraCommas;
|
|
35
|
+
private detectUnescapedQuotes;
|
|
36
|
+
private detectStructuralIssues;
|
|
37
|
+
private estimateErrorCount;
|
|
38
|
+
toString(): string;
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=cleaning-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleaning-context.d.ts","sourceRoot":"","sources":["../../../../../../src/middleware/services/json-cleaner/recipe-system/core/cleaning-context.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,EACf,SAAS,EACT,iBAAiB,EACjB,eAAe,EACf,YAAY,EACZ,cAAc,EACf,MAAM,0BAA0B,CAAC;AAElC,qBAAa,mBAAoB,YAAW,eAAe;IAClD,WAAW,EAAE,MAAM,CAAC;IAC3B,SAAgB,YAAY,EAAE,MAAM,CAAC;IACrC,SAAgB,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC,CAAa;IACjE,SAAgB,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IAC7D,SAAgB,OAAO,EAAE,iBAAiB,EAAE,CAAM;IAClD,SAAgB,QAAQ,EAAE,eAAe,CAAC;gBAE9B,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC;IAW7D,YAAY,CACV,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,MAAM,GAAG,cAAc,EACjC,UAAU,GAAE,MAAY,EACxB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAC7B,IAAI;IAaP,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAInC,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,EAAE;IAIxC,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAKpC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAYjC,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAIjC,YAAY,CAAC,MAAM,EAAE,iBAAiB,GAAG,IAAI;IAI7C,QAAQ,IAAI,YAAY;IAYxB,WAAW,IAAI,OAAO;IAStB,yBAAyB,CAAC,aAAa,GAAE,MAAY,GAAG,SAAS,EAAE;IAQnE,gBAAgB,CAAC,IAAI,EAAE,iBAAiB,CAAC,MAAM,CAAC,GAAG,iBAAiB,EAAE;IAItE,aAAa,IAAI,MAAM;IAIvB,aAAa,IAAI,MAAM;IAKvB,eAAe,IAAI;QACjB,eAAe,EAAE,OAAO,CAAC;QACzB,gBAAgB,EAAE,OAAO,CAAC;QAC1B,cAAc,EAAE,OAAO,CAAC;QACxB,kBAAkB,EAAE,OAAO,CAAC;QAC5B,mBAAmB,EAAE,OAAO,CAAC;QAC7B,iBAAiB,EAAE,OAAO,CAAC;QAC3B,YAAY,EAAE,OAAO,CAAC;QACtB,mBAAmB,EAAE,MAAM,CAAC;KAC7B;IAeD,OAAO,CAAC,mBAAmB;IAM3B,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,qBAAqB;IAI7B,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,kBAAkB;IAU1B,QAAQ,IAAI,MAAM;CAInB"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CleaningContextImpl = void 0;
|
|
4
|
+
class CleaningContextImpl {
|
|
5
|
+
constructor(json, metadata) {
|
|
6
|
+
this.detections = new Map();
|
|
7
|
+
this.checkpoints = new Map();
|
|
8
|
+
this.changes = [];
|
|
9
|
+
this.currentJson = json;
|
|
10
|
+
this.originalJson = json;
|
|
11
|
+
this.metadata = {
|
|
12
|
+
startTime: Date.now(),
|
|
13
|
+
source: 'unknown',
|
|
14
|
+
mode: 'adaptive',
|
|
15
|
+
...metadata
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
addDetection(type, location, confidence = 1.0, metadata) {
|
|
19
|
+
if (!this.detections.has(type)) {
|
|
20
|
+
this.detections.set(type, []);
|
|
21
|
+
}
|
|
22
|
+
this.detections.get(type).push({
|
|
23
|
+
type,
|
|
24
|
+
location,
|
|
25
|
+
confidence,
|
|
26
|
+
metadata
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
hasDetection(type) {
|
|
30
|
+
return this.detections.has(type) && this.detections.get(type).length > 0;
|
|
31
|
+
}
|
|
32
|
+
getDetections(type) {
|
|
33
|
+
return this.detections.get(type) || [];
|
|
34
|
+
}
|
|
35
|
+
createCheckpoint(name) {
|
|
36
|
+
this.checkpoints.set(name, this.currentJson);
|
|
37
|
+
console.log(`[CleaningContext] Created checkpoint '${name}' with ${this.currentJson.length} chars`);
|
|
38
|
+
}
|
|
39
|
+
rollbackTo(name) {
|
|
40
|
+
const checkpoint = this.checkpoints.get(name);
|
|
41
|
+
if (checkpoint) {
|
|
42
|
+
console.log(`[CleaningContext] Rolling back to checkpoint '${name}'`);
|
|
43
|
+
this.currentJson = checkpoint;
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
console.warn(`[CleaningContext] Checkpoint '${name}' not found`);
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
updateJson(newJson) {
|
|
50
|
+
this.currentJson = newJson;
|
|
51
|
+
}
|
|
52
|
+
recordChange(change) {
|
|
53
|
+
this.changes.push(change);
|
|
54
|
+
}
|
|
55
|
+
getStats() {
|
|
56
|
+
return {
|
|
57
|
+
totalChanges: this.changes.length,
|
|
58
|
+
processingTime: Date.now() - this.metadata.startTime,
|
|
59
|
+
checkpointCount: this.checkpoints.size,
|
|
60
|
+
rollbackCount: this.changes.filter(c => c.type === 'rollback').length,
|
|
61
|
+
detectionCount: Array.from(this.detections.values()).reduce((sum, arr) => sum + arr.length, 0),
|
|
62
|
+
isValid: this.isValidJson()
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
// Helper methods
|
|
66
|
+
isValidJson() {
|
|
67
|
+
try {
|
|
68
|
+
JSON.parse(this.currentJson);
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
getDetectionsByConfidence(minConfidence = 0.5) {
|
|
76
|
+
const allDetections = [];
|
|
77
|
+
for (const detectionArray of this.detections.values()) {
|
|
78
|
+
allDetections.push(...detectionArray.filter(d => d.confidence >= minConfidence));
|
|
79
|
+
}
|
|
80
|
+
return allDetections.sort((a, b) => b.confidence - a.confidence);
|
|
81
|
+
}
|
|
82
|
+
getChangesByType(type) {
|
|
83
|
+
return this.changes.filter(c => c.type === type);
|
|
84
|
+
}
|
|
85
|
+
getSizeChange() {
|
|
86
|
+
return this.currentJson.length - this.originalJson.length;
|
|
87
|
+
}
|
|
88
|
+
getChangeRate() {
|
|
89
|
+
return this.changes.length / Math.max(this.originalJson.length, 1);
|
|
90
|
+
}
|
|
91
|
+
// Analysis methods
|
|
92
|
+
analyzePatterns() {
|
|
93
|
+
const json = this.currentJson;
|
|
94
|
+
return {
|
|
95
|
+
hasControlChars: /[\x00-\x1F\x7F]/.test(json),
|
|
96
|
+
hasMissingCommas: this.detectMissingCommas(json),
|
|
97
|
+
hasExtraCommas: this.detectExtraCommas(json),
|
|
98
|
+
hasUnescapedQuotes: this.detectUnescapedQuotes(json),
|
|
99
|
+
hasStructuralIssues: this.detectStructuralIssues(json),
|
|
100
|
+
hasMarkdownBlocks: /```[\s\S]*?```/.test(json),
|
|
101
|
+
hasThinkTags: /<think>[\s\S]*?<\/think>/.test(json),
|
|
102
|
+
estimatedErrorCount: this.estimateErrorCount(json)
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
detectMissingCommas(json) {
|
|
106
|
+
return /"\s*"[^:\s]/.test(json) ||
|
|
107
|
+
/}\s*{/.test(json) ||
|
|
108
|
+
/]\s*\[/.test(json);
|
|
109
|
+
}
|
|
110
|
+
detectExtraCommas(json) {
|
|
111
|
+
return /,\s*[}\]]/.test(json) || /,,/.test(json);
|
|
112
|
+
}
|
|
113
|
+
detectUnescapedQuotes(json) {
|
|
114
|
+
return /"[^"\\]*[^\\]"[^,\]}]/.test(json);
|
|
115
|
+
}
|
|
116
|
+
detectStructuralIssues(json) {
|
|
117
|
+
const openBraces = (json.match(/\{/g) || []).length;
|
|
118
|
+
const closeBraces = (json.match(/\}/g) || []).length;
|
|
119
|
+
const openBrackets = (json.match(/\[/g) || []).length;
|
|
120
|
+
const closeBrackets = (json.match(/\]/g) || []).length;
|
|
121
|
+
return openBraces !== closeBraces || openBrackets !== closeBrackets;
|
|
122
|
+
}
|
|
123
|
+
estimateErrorCount(json) {
|
|
124
|
+
let count = 0;
|
|
125
|
+
count += (json.match(/[\x00-\x1F\x7F]/g) || []).length;
|
|
126
|
+
count += (json.match(/"[^"]*"[^,\]}:\s]/g) || []).length;
|
|
127
|
+
count += (json.match(/,\s*[}\]]/g) || []).length;
|
|
128
|
+
count += Math.abs((json.match(/\{/g) || []).length - (json.match(/\}/g) || []).length);
|
|
129
|
+
count += Math.abs((json.match(/\[/g) || []).length - (json.match(/\]/g) || []).length);
|
|
130
|
+
return count;
|
|
131
|
+
}
|
|
132
|
+
toString() {
|
|
133
|
+
const stats = this.getStats();
|
|
134
|
+
return `CleaningContext{valid: ${stats.isValid}, changes: ${stats.totalChanges}, detections: ${stats.detectionCount}, time: ${stats.processingTime}ms}`;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
exports.CleaningContextImpl = CleaningContextImpl;
|
|
138
|
+
//# sourceMappingURL=cleaning-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleaning-context.js","sourceRoot":"","sources":["../../../../../../src/middleware/services/json-cleaner/recipe-system/core/cleaning-context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { CleaningRecipe, RecipeResult } from '../types/recipe.types';
|
|
2
|
+
import { CleaningContext } from '../types/operation.types';
|
|
3
|
+
export interface CleaningOptions {
|
|
4
|
+
maxTime?: number;
|
|
5
|
+
mode?: 'conservative' | 'aggressive' | 'adaptive';
|
|
6
|
+
source?: string;
|
|
7
|
+
expectedType?: 'object' | 'array' | 'primitive';
|
|
8
|
+
targetConfidence?: number;
|
|
9
|
+
continueOnError?: boolean;
|
|
10
|
+
metadata?: Record<string, any>;
|
|
11
|
+
}
|
|
12
|
+
export interface CleaningResult {
|
|
13
|
+
success: boolean;
|
|
14
|
+
cleanedJson?: string;
|
|
15
|
+
parsedJson?: any;
|
|
16
|
+
confidence: number;
|
|
17
|
+
totalChanges: number;
|
|
18
|
+
processingTime: number;
|
|
19
|
+
originalJson: string;
|
|
20
|
+
recipeResult: RecipeResult;
|
|
21
|
+
context: CleaningContext;
|
|
22
|
+
error?: CleaningError;
|
|
23
|
+
quality: QualityMetrics;
|
|
24
|
+
}
|
|
25
|
+
export interface CleaningError {
|
|
26
|
+
code: string;
|
|
27
|
+
message: string;
|
|
28
|
+
recoverable: boolean;
|
|
29
|
+
suggestions: string[];
|
|
30
|
+
originalError?: Error;
|
|
31
|
+
}
|
|
32
|
+
export interface QualityMetrics {
|
|
33
|
+
isValidJson: boolean;
|
|
34
|
+
cleaningConfidence: number;
|
|
35
|
+
preservationRate: number;
|
|
36
|
+
changeRate: number;
|
|
37
|
+
structuralIntegrity: number;
|
|
38
|
+
contentIntegrity: number;
|
|
39
|
+
}
|
|
40
|
+
export declare class CleaningEngine {
|
|
41
|
+
private static instance;
|
|
42
|
+
static getInstance(): CleaningEngine;
|
|
43
|
+
clean(json: string, recipe: CleaningRecipe, options?: CleaningOptions): Promise<CleaningResult>;
|
|
44
|
+
validateJson(json: string): {
|
|
45
|
+
isValid: boolean;
|
|
46
|
+
suggestions: never[];
|
|
47
|
+
error?: undefined;
|
|
48
|
+
} | {
|
|
49
|
+
isValid: boolean;
|
|
50
|
+
error: string;
|
|
51
|
+
suggestions: string[];
|
|
52
|
+
};
|
|
53
|
+
analyzeAndSuggestRecipe(json: string): {
|
|
54
|
+
readonly recommendedRecipe: "conservative" | "aggressive" | "adaptive";
|
|
55
|
+
readonly reasons: string[];
|
|
56
|
+
readonly detectedIssues: string[];
|
|
57
|
+
readonly estimatedDifficulty: "medium" | "easy" | "hard";
|
|
58
|
+
};
|
|
59
|
+
getEngineStats(): {
|
|
60
|
+
readonly version: "1.0.0";
|
|
61
|
+
readonly operationsAvailable: 10;
|
|
62
|
+
readonly recipesRegistered: 5;
|
|
63
|
+
readonly averageProcessingTime: 150;
|
|
64
|
+
readonly successRate: 0.85;
|
|
65
|
+
};
|
|
66
|
+
private configureRecipe;
|
|
67
|
+
private calculateQualityMetrics;
|
|
68
|
+
private calculatePreservationRate;
|
|
69
|
+
private calculateStructuralIntegrity;
|
|
70
|
+
private safeParse;
|
|
71
|
+
private createCleaningError;
|
|
72
|
+
private generateValidationSuggestions;
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=cleaning-engine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleaning-engine.d.ts","sourceRoot":"","sources":["../../../../../../src/middleware/services/json-cleaner/recipe-system/core/cleaning-engine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAG3D,MAAM,WAAW,eAAe;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,cAAc,GAAG,YAAY,GAAG,UAAU,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,QAAQ,GAAG,OAAO,GAAG,WAAW,CAAC;IAChD,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,GAAG,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,YAAY,CAAC;IAC3B,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,OAAO,EAAE,cAAc,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,aAAa,CAAC,EAAE,KAAK,CAAC;CACvB;AAED,MAAM,WAAW,cAAc;IAC7B,WAAW,EAAE,OAAO,CAAC;IACrB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,gBAAgB,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAiB;IAExC,MAAM,CAAC,WAAW,IAAI,cAAc;IAO9B,KAAK,CACT,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,cAAc,EACtB,OAAO,GAAE,eAAoB;IAqF/B,YAAY,CAAC,IAAI,EAAE,MAAM;;;;;;;;;IAWzB,uBAAuB,CAAC,IAAI,EAAE,MAAM;;;;;;IAwCpC,cAAc;;;;;;;IAUd,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,uBAAuB;IAU/B,OAAO,CAAC,yBAAyB;IAOjC,OAAO,CAAC,4BAA4B;IAcpC,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,mBAAmB;IAiB3B,OAAO,CAAC,6BAA6B;CAQtC"}
|