@duckmind/deepquark-darwin-arm64 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.deepquark/skills/bundled/data-storytelling/SKILL.md +453 -0
- package/.deepquark/skills/bundled/docx/LICENSE.txt +30 -0
- package/.deepquark/skills/bundled/docx/SKILL.md +481 -0
- package/.deepquark/skills/bundled/docx/scripts/__init__.py +1 -0
- package/.deepquark/skills/bundled/docx/scripts/accept_changes.py +135 -0
- package/.deepquark/skills/bundled/docx/scripts/comment.py +318 -0
- package/.deepquark/skills/bundled/docx/scripts/office/helpers/__init__.py +0 -0
- package/.deepquark/skills/bundled/docx/scripts/office/helpers/merge_runs.py +199 -0
- package/.deepquark/skills/bundled/docx/scripts/office/helpers/simplify_redlines.py +197 -0
- package/.deepquark/skills/bundled/docx/scripts/office/pack.py +159 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/mce/mc.xsd +75 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.deepquark/skills/bundled/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.deepquark/skills/bundled/docx/scripts/office/soffice.py +183 -0
- package/.deepquark/skills/bundled/docx/scripts/office/unpack.py +132 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validate.py +111 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validators/__init__.py +15 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validators/base.py +847 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validators/docx.py +446 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validators/pptx.py +275 -0
- package/.deepquark/skills/bundled/docx/scripts/office/validators/redlining.py +247 -0
- package/.deepquark/skills/bundled/docx/scripts/templates/comments.xml +3 -0
- package/.deepquark/skills/bundled/docx/scripts/templates/commentsExtended.xml +3 -0
- package/.deepquark/skills/bundled/docx/scripts/templates/commentsExtensible.xml +3 -0
- package/.deepquark/skills/bundled/docx/scripts/templates/commentsIds.xml +3 -0
- package/.deepquark/skills/bundled/docx/scripts/templates/people.xml +3 -0
- package/.deepquark/skills/bundled/drawio-architect/SKILL.md +300 -0
- package/.deepquark/skills/bundled/drawio-architect/references/architecture-patterns.md +236 -0
- package/.deepquark/skills/bundled/drawio-architect/references/branding.md +180 -0
- package/.deepquark/skills/bundled/drawio-architect/references/cloud-icons.md +493 -0
- package/.deepquark/skills/bundled/drawio-architect/references/style-guide.md +268 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/ARCHITECTURE_REVIEW.md +495 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/AUTONOMY_VERIFICATION.md +420 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/COMPETITIVE_ANALYSIS.md +179 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/CONTEXT_OPTIMIZATION.md +293 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/QUICK_START.md +167 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/README.md +259 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/SKILL.md +754 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/WORD_PRECISION_AUDIT.md +476 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/reference/methodology.md +384 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/requirements.txt +10 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/citation_manager.py +177 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/md_to_html.py +330 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/research_engine.py +578 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/source_evaluator.py +292 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/validate_report.py +354 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/verify_citations.py +430 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/scripts/verify_html.py +220 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/templates/mckinsey_report_template.html +443 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/templates/report_template.md +414 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/tests/fixtures/invalid_report.md +27 -0
- package/.deepquark/skills/bundled/duckmind-deep-research/tests/fixtures/valid_report.md +114 -0
- package/.deepquark/skills/bundled/duckmind-multimodal/SKILL.md +171 -0
- package/.deepquark/skills/bundled/duckmind-multimodal/references/image-generation.md +131 -0
- package/.deepquark/skills/bundled/duckmind-multimodal/references/pdf-processing.md +120 -0
- package/.deepquark/skills/bundled/duckmind-transcribe/SKILL.md +70 -0
- package/.deepquark/skills/bundled/duckmind-transcribe/scripts/transcribe.sh +134 -0
- package/.deepquark/skills/bundled/excel-analysis/SKILL.md +247 -0
- package/.deepquark/skills/bundled/knowledge-graph/SKILL.md +385 -0
- package/.deepquark/skills/bundled/knowledge-graph/STANDARDS.md +461 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/cli.ts +588 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/config.ts +630 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/connection-profile.ts +629 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/container.ts +756 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/mcp-client.ts +1310 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/output-formatter.ts +997 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/token-metrics.ts +335 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/transformation-log.ts +137 -0
- package/.deepquark/skills/bundled/knowledge-graph/lib/wrapper-config.ts +113 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/.env.example +129 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/compare-embeddings.ts +175 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/config-falkordb.yaml +108 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/config-neo4j.yaml +111 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/diagnose.ts +483 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-falkordb-dev.yml +146 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-falkordb.yml +151 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-neo4j-dev-local.yml +161 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-neo4j-dev.yml +161 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-neo4j.yml +169 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-production.yml +128 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose-test.yml +10 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/docker-compose.yml +84 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/entrypoint.sh +40 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/install.ts +2054 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/podman-compose-falkordb.yml +78 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/podman-compose-neo4j.yml +88 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/podman-compose.yml +83 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-all-llms-mcp.ts +387 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-embedding-models.ts +201 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-embedding-providers.ts +641 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-graphiti-model.ts +217 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-grok-correct.ts +141 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-grok-llms-mcp.ts +386 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-grok-models.ts +173 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-llama-extraction.ts +188 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-mcp-final.ts +240 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-mcp-live.ts +187 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-mcp-session.ts +127 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-model-combinations.ts +316 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-ollama-models.ts +228 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-openrouter-models.ts +460 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-real-life-mcp.ts +311 -0
- package/.deepquark/skills/bundled/knowledge-graph/server/test-search-debug.ts +199 -0
- package/.deepquark/skills/bundled/knowledge-graph/tools/Install.md +104 -0
- package/.deepquark/skills/bundled/knowledge-graph/tools/README.md +120 -0
- package/.deepquark/skills/bundled/knowledge-graph/tools/knowledge-cli.ts +996 -0
- package/.deepquark/skills/bundled/knowledge-graph/tools/server-cli.ts +531 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/BulkImport.md +514 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/CaptureEpisode.md +242 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/ClearGraph.md +392 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/GetRecent.md +352 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/GetStatus.md +373 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/HealthReport.md +212 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/InvestigateEntity.md +142 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/OntologyManagement.md +201 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/RunMaintenance.md +302 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/SearchByDate.md +255 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/SearchFacts.md +382 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/SearchKnowledge.md +374 -0
- package/.deepquark/skills/bundled/knowledge-graph/workflows/StixImport.md +212 -0
- package/.deepquark/skills/bundled/pdf/LICENSE.txt +30 -0
- package/.deepquark/skills/bundled/pdf/SKILL.md +314 -0
- package/.deepquark/skills/bundled/pdf/forms.md +294 -0
- package/.deepquark/skills/bundled/pdf/reference.md +612 -0
- package/.deepquark/skills/bundled/pdf/scripts/check_bounding_boxes.py +65 -0
- package/.deepquark/skills/bundled/pdf/scripts/check_fillable_fields.py +11 -0
- package/.deepquark/skills/bundled/pdf/scripts/convert_pdf_to_images.py +33 -0
- package/.deepquark/skills/bundled/pdf/scripts/create_validation_image.py +37 -0
- package/.deepquark/skills/bundled/pdf/scripts/extract_form_field_info.py +122 -0
- package/.deepquark/skills/bundled/pdf/scripts/extract_form_structure.py +115 -0
- package/.deepquark/skills/bundled/pdf/scripts/fill_fillable_fields.py +98 -0
- package/.deepquark/skills/bundled/pdf/scripts/fill_pdf_form_with_annotations.py +107 -0
- package/.deepquark/skills/bundled/perplexity-search/SKILL.md +447 -0
- package/.deepquark/skills/bundled/perplexity-search/assets/.env.example +16 -0
- package/.deepquark/skills/bundled/perplexity-search/references/model_comparison.md +386 -0
- package/.deepquark/skills/bundled/perplexity-search/references/openrouter_setup.md +454 -0
- package/.deepquark/skills/bundled/perplexity-search/references/search_strategies.md +258 -0
- package/.deepquark/skills/bundled/perplexity-search/scripts/perplexity_search.py +277 -0
- package/.deepquark/skills/bundled/perplexity-search/scripts/setup_env.py +171 -0
- package/.deepquark/skills/bundled/pptx/LICENSE.txt +30 -0
- package/.deepquark/skills/bundled/pptx/SKILL.md +232 -0
- package/.deepquark/skills/bundled/pptx/editing.md +205 -0
- package/.deepquark/skills/bundled/pptx/pptxgenjs.md +420 -0
- package/.deepquark/skills/bundled/pptx/scripts/__init__.py +0 -0
- package/.deepquark/skills/bundled/pptx/scripts/add_slide.py +195 -0
- package/.deepquark/skills/bundled/pptx/scripts/clean.py +286 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/helpers/__init__.py +0 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/helpers/merge_runs.py +199 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/helpers/simplify_redlines.py +197 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/pack.py +159 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/mce/mc.xsd +75 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/soffice.py +183 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/unpack.py +132 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validate.py +111 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validators/__init__.py +15 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validators/base.py +847 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validators/docx.py +446 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validators/pptx.py +275 -0
- package/.deepquark/skills/bundled/pptx/scripts/office/validators/redlining.py +247 -0
- package/.deepquark/skills/bundled/pptx/scripts/thumbnail.py +289 -0
- package/.deepquark/skills/bundled/text-to-pdf-automation/SKILL.md +91 -0
- package/.deepquark/skills/bundled/web-fetch/SKILL.md +56 -0
- package/.deepquark/skills/bundled/web-fetch/scripts/fetch.sh +54 -0
- package/.deepquark/skills/bundled/xlsx/LICENSE.txt +30 -0
- package/.deepquark/skills/bundled/xlsx/SKILL.md +292 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/helpers/__init__.py +0 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/helpers/merge_runs.py +199 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/helpers/simplify_redlines.py +197 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/pack.py +159 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/mce/mc.xsd +75 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +560 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +67 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +14 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/soffice.py +183 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/unpack.py +132 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validate.py +111 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validators/__init__.py +15 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validators/base.py +847 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validators/docx.py +446 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validators/pptx.py +275 -0
- package/.deepquark/skills/bundled/xlsx/scripts/office/validators/redlining.py +247 -0
- package/.deepquark/skills/bundled/xlsx/scripts/recalc.py +184 -0
- package/.deepquark/skills/bundled/youtube-downloader/SKILL.md +99 -0
- package/.deepquark/skills/bundled/youtube-downloader/scripts/download_video.py +145 -0
- package/.deepquark/skills/bundled/youtube-transcribe-skill/SKILL.md +116 -0
- package/LICENSE +21 -0
- package/bin/deepquark +0 -0
- package/package.json +16 -0
|
@@ -0,0 +1,386 @@
|
|
|
1
|
+
#!/usr/bin/env bun
|
|
2
|
+
/**
|
|
3
|
+
* Grok LLM Models MCP Test
|
|
4
|
+
* Tests all Grok model variants for real-life entity extraction via Graphiti
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { $ } from 'bun';
|
|
8
|
+
|
|
9
|
+
const MCP_URL = 'http://localhost:8000/mcp';
|
|
10
|
+
const ACCEPT = 'application/json, text/event-stream';
|
|
11
|
+
const ENV_FILE = '../../config/.env';
|
|
12
|
+
|
|
13
|
+
// All Grok models from benchmark (sorted by cost)
|
|
14
|
+
const GROK_MODELS = [
|
|
15
|
+
{ name: 'Grok 4 Fast', model: 'x-ai/grok-4-fast', cost: 0.28 },
|
|
16
|
+
{ name: 'Grok 4.1 Fast', model: 'x-ai/grok-4.1-fast', cost: Math.LOG10E },
|
|
17
|
+
{ name: 'Grok 3 Mini', model: 'x-ai/grok-3-mini', cost: 0.56 },
|
|
18
|
+
{ name: 'Grok 3', model: 'x-ai/grok-3', cost: 2.163 },
|
|
19
|
+
{ name: 'Grok 4', model: 'x-ai/grok-4', cost: 11.842 },
|
|
20
|
+
];
|
|
21
|
+
|
|
22
|
+
const OPENROUTER_API_KEY = process.env.OPENROUTER_API_KEY;
|
|
23
|
+
if (!OPENROUTER_API_KEY) {
|
|
24
|
+
console.error('โ OPENROUTER_API_KEY required');
|
|
25
|
+
console.log('\nUsage: OPENROUTER_API_KEY=sk-or-v1-... bun test-grok-llms-mcp.ts');
|
|
26
|
+
process.exit(1);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// Test episode - complex enough to test extraction quality
|
|
30
|
+
const TEST_EPISODE = {
|
|
31
|
+
name: 'Grok Test Episode',
|
|
32
|
+
body: "During the Q4 planning meeting at TechCorp headquarters in Austin, CEO Sarah Martinez announced a strategic partnership with CloudBase Inc. The $50 million deal, facilitated by Morgan Stanley, will integrate CloudBase's AI platform into TechCorp's enterprise suite by March 2026.",
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
// Expected entities to find
|
|
36
|
+
const EXPECTED_ENTITIES = ['TechCorp', 'Sarah Martinez', 'CloudBase', 'Morgan Stanley', 'Austin'];
|
|
37
|
+
|
|
38
|
+
let sessionId: string | null = null;
|
|
39
|
+
|
|
40
|
+
async function mcpRequest(method: string, params: any = {}): Promise<any> {
|
|
41
|
+
const headers: Record<string, string> = {
|
|
42
|
+
'Content-Type': 'application/json',
|
|
43
|
+
Accept: ACCEPT,
|
|
44
|
+
};
|
|
45
|
+
if (sessionId) headers['mcp-session-id'] = sessionId;
|
|
46
|
+
|
|
47
|
+
try {
|
|
48
|
+
const res = await fetch(MCP_URL, {
|
|
49
|
+
method: 'POST',
|
|
50
|
+
headers,
|
|
51
|
+
body: JSON.stringify({ jsonrpc: '2.0', id: Date.now(), method, params }),
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
const newSessionId = res.headers.get('mcp-session-id');
|
|
55
|
+
if (newSessionId) sessionId = newSessionId;
|
|
56
|
+
|
|
57
|
+
const text = await res.text();
|
|
58
|
+
let result: any = null;
|
|
59
|
+
let error: any = null;
|
|
60
|
+
|
|
61
|
+
for (const line of text.split('\n')) {
|
|
62
|
+
if (line.startsWith('data: ')) {
|
|
63
|
+
try {
|
|
64
|
+
const data = JSON.parse(line.slice(6));
|
|
65
|
+
if (data.result) result = data.result;
|
|
66
|
+
if (data.error) error = data.error;
|
|
67
|
+
} catch {}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (!result && !error) {
|
|
72
|
+
try {
|
|
73
|
+
const json = JSON.parse(text);
|
|
74
|
+
result = json.result;
|
|
75
|
+
error = json.error;
|
|
76
|
+
} catch {}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return { result, error };
|
|
80
|
+
} catch (e: any) {
|
|
81
|
+
return { error: { message: e.message } };
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
async function callTool(
|
|
86
|
+
name: string,
|
|
87
|
+
args: any
|
|
88
|
+
): Promise<{ success: boolean; data: any; duration: number }> {
|
|
89
|
+
const start = Date.now();
|
|
90
|
+
const { result, error } = await mcpRequest('tools/call', { name, arguments: args });
|
|
91
|
+
const duration = Date.now() - start;
|
|
92
|
+
|
|
93
|
+
if (error) return { success: false, data: error, duration };
|
|
94
|
+
|
|
95
|
+
let data: any = result;
|
|
96
|
+
try {
|
|
97
|
+
if (result?.content?.[0]?.text) {
|
|
98
|
+
data = JSON.parse(result.content[0].text);
|
|
99
|
+
}
|
|
100
|
+
} catch {}
|
|
101
|
+
|
|
102
|
+
return { success: true, data, duration };
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
async function waitForHealth(maxWait = 60000): Promise<boolean> {
|
|
106
|
+
const start = Date.now();
|
|
107
|
+
while (Date.now() - start < maxWait) {
|
|
108
|
+
try {
|
|
109
|
+
const res = await fetch('http://localhost:8000/health', {
|
|
110
|
+
signal: AbortSignal.timeout(2000),
|
|
111
|
+
});
|
|
112
|
+
if (res.ok) return true;
|
|
113
|
+
} catch {}
|
|
114
|
+
await Bun.sleep(2000);
|
|
115
|
+
}
|
|
116
|
+
return false;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
async function updateEnvAndRestart(modelName: string): Promise<boolean> {
|
|
120
|
+
// Read current env
|
|
121
|
+
const envPath = Bun.file(ENV_FILE);
|
|
122
|
+
let envContent = await envPath.text();
|
|
123
|
+
|
|
124
|
+
// Update MODEL_NAME lines
|
|
125
|
+
envContent = envContent.replace(
|
|
126
|
+
/MADEINOZ_KNOWLEDGE_MODEL_NAME=.*/g,
|
|
127
|
+
`MADEINOZ_KNOWLEDGE_MODEL_NAME=${modelName}`
|
|
128
|
+
);
|
|
129
|
+
envContent = envContent.replace(/^MODEL_NAME=.*/gm, `MODEL_NAME=${modelName}`);
|
|
130
|
+
|
|
131
|
+
// Write updated env
|
|
132
|
+
await Bun.write(ENV_FILE, envContent);
|
|
133
|
+
|
|
134
|
+
// Restart container
|
|
135
|
+
try {
|
|
136
|
+
await $`docker-compose -f docker-compose-neo4j.yml up -d --force-recreate graphiti-mcp`.quiet();
|
|
137
|
+
await Bun.sleep(5000); // Initial wait
|
|
138
|
+
return await waitForHealth();
|
|
139
|
+
} catch (e: any) {
|
|
140
|
+
console.log(` โ Restart failed: ${e.message}`);
|
|
141
|
+
return false;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
async function checkExtractedEntities(groupId: string): Promise<string[]> {
|
|
146
|
+
try {
|
|
147
|
+
const result =
|
|
148
|
+
await $`docker exec madeinoz-knowledge-neo4j cypher-shell -u neo4j -p madeinozknowledge "MATCH (n:Entity {group_id: '${groupId}'}) RETURN n.name as name"`.text();
|
|
149
|
+
|
|
150
|
+
// Parse cypher-shell output
|
|
151
|
+
const lines = result.split('\n').slice(1); // Skip header
|
|
152
|
+
const entities: string[] = [];
|
|
153
|
+
for (const line of lines) {
|
|
154
|
+
const name = line.replace(/"/g, '').trim();
|
|
155
|
+
if (name && name !== 'name') entities.push(name);
|
|
156
|
+
}
|
|
157
|
+
return entities;
|
|
158
|
+
} catch {
|
|
159
|
+
return [];
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
async function checkLogs(): Promise<{ success: boolean; error?: string }> {
|
|
164
|
+
try {
|
|
165
|
+
const logs =
|
|
166
|
+
await $`docker-compose -f docker-compose-neo4j.yml logs --tail=30 graphiti-mcp`.text();
|
|
167
|
+
|
|
168
|
+
if (logs.includes('Successfully processed episode')) {
|
|
169
|
+
return { success: true };
|
|
170
|
+
}
|
|
171
|
+
if (logs.includes('Failed to process episode')) {
|
|
172
|
+
const match = logs.match(/Failed to process episode.*?: (.+)/);
|
|
173
|
+
return { success: false, error: match?.[1] || 'Unknown error' };
|
|
174
|
+
}
|
|
175
|
+
return { success: false, error: 'Processing not completed' };
|
|
176
|
+
} catch {
|
|
177
|
+
return { success: false, error: 'Could not read logs' };
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
async function testModel(model: (typeof GROK_MODELS)[0], index: number): Promise<any> {
|
|
182
|
+
const groupId = `grok-test-${index}`;
|
|
183
|
+
sessionId = null;
|
|
184
|
+
|
|
185
|
+
const result = {
|
|
186
|
+
name: model.name,
|
|
187
|
+
model: model.model,
|
|
188
|
+
cost: model.cost,
|
|
189
|
+
works: false,
|
|
190
|
+
entitiesFound: 0,
|
|
191
|
+
expectedFound: 0,
|
|
192
|
+
error: null as string | null,
|
|
193
|
+
extractionTimeMs: 0,
|
|
194
|
+
};
|
|
195
|
+
|
|
196
|
+
// Initialize MCP session
|
|
197
|
+
const initRes = await mcpRequest('initialize', {
|
|
198
|
+
protocolVersion: '2024-11-05',
|
|
199
|
+
capabilities: {},
|
|
200
|
+
clientInfo: { name: 'grok-test', version: '1.0' },
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
if (initRes.error) {
|
|
204
|
+
result.error = `Init failed: ${initRes.error.message}`;
|
|
205
|
+
return result;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
await mcpRequest('notifications/initialized', {});
|
|
209
|
+
|
|
210
|
+
// Add test episode
|
|
211
|
+
const addStart = Date.now();
|
|
212
|
+
const addRes = await callTool('add_memory', {
|
|
213
|
+
name: TEST_EPISODE.name,
|
|
214
|
+
episode_body: TEST_EPISODE.body,
|
|
215
|
+
source: 'text',
|
|
216
|
+
group_id: groupId,
|
|
217
|
+
});
|
|
218
|
+
|
|
219
|
+
if (!addRes.success) {
|
|
220
|
+
result.error = `add_memory failed: ${JSON.stringify(addRes.data).slice(0, 100)}`;
|
|
221
|
+
return result;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
// Wait for async processing (up to 30 seconds)
|
|
225
|
+
console.log(' โณ Waiting for extraction...');
|
|
226
|
+
let processed = false;
|
|
227
|
+
for (let i = 0; i < 15; i++) {
|
|
228
|
+
await Bun.sleep(2000);
|
|
229
|
+
const logCheck = await checkLogs();
|
|
230
|
+
if (logCheck.success) {
|
|
231
|
+
processed = true;
|
|
232
|
+
break;
|
|
233
|
+
}
|
|
234
|
+
if (logCheck.error?.includes('validation error')) {
|
|
235
|
+
result.error = logCheck.error;
|
|
236
|
+
return result;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
result.extractionTimeMs = Date.now() - addStart;
|
|
241
|
+
|
|
242
|
+
if (!processed) {
|
|
243
|
+
// Check logs for error
|
|
244
|
+
const logCheck = await checkLogs();
|
|
245
|
+
if (!logCheck.success) {
|
|
246
|
+
result.error = logCheck.error || 'Extraction timeout';
|
|
247
|
+
return result;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
// Check extracted entities
|
|
252
|
+
const entities = await checkExtractedEntities(groupId);
|
|
253
|
+
result.entitiesFound = entities.length;
|
|
254
|
+
|
|
255
|
+
// Count how many expected entities were found
|
|
256
|
+
for (const expected of EXPECTED_ENTITIES) {
|
|
257
|
+
const found = entities.some(
|
|
258
|
+
(e) =>
|
|
259
|
+
e.toLowerCase().includes(expected.toLowerCase()) ||
|
|
260
|
+
expected.toLowerCase().includes(e.toLowerCase())
|
|
261
|
+
);
|
|
262
|
+
if (found) result.expectedFound++;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
result.works = result.entitiesFound >= 3 && result.expectedFound >= 3;
|
|
266
|
+
|
|
267
|
+
return result;
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
async function main() {
|
|
271
|
+
console.log('โ'.repeat(70));
|
|
272
|
+
console.log('๐ค Grok LLM Models MCP Test');
|
|
273
|
+
console.log('โ'.repeat(70));
|
|
274
|
+
console.log(`\nTest Episode: "${TEST_EPISODE.body.slice(0, 80)}..."`);
|
|
275
|
+
console.log(`Expected Entities: ${EXPECTED_ENTITIES.join(', ')}`);
|
|
276
|
+
console.log(`\nGrok models to test: ${GROK_MODELS.length}`);
|
|
277
|
+
|
|
278
|
+
const results: any[] = [];
|
|
279
|
+
|
|
280
|
+
for (let i = 0; i < GROK_MODELS.length; i++) {
|
|
281
|
+
const model = GROK_MODELS[i];
|
|
282
|
+
console.log(`\n${'โ'.repeat(70)}`);
|
|
283
|
+
console.log(`[${i + 1}/${GROK_MODELS.length}] ${model.name} ($${model.cost}/1K)`);
|
|
284
|
+
console.log(`${'โ'.repeat(70)}`);
|
|
285
|
+
|
|
286
|
+
// Update config and restart
|
|
287
|
+
console.log(` ๐ Configuring ${model.model}...`);
|
|
288
|
+
const started = await updateEnvAndRestart(model.model);
|
|
289
|
+
|
|
290
|
+
if (!started) {
|
|
291
|
+
console.log(' โ Container failed to start');
|
|
292
|
+
results.push({
|
|
293
|
+
name: model.name,
|
|
294
|
+
model: model.model,
|
|
295
|
+
cost: model.cost,
|
|
296
|
+
works: false,
|
|
297
|
+
error: 'Container failed',
|
|
298
|
+
});
|
|
299
|
+
continue;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
// Verify model is configured
|
|
303
|
+
const logs =
|
|
304
|
+
await $`docker-compose -f docker-compose-neo4j.yml logs --tail=5 graphiti-mcp`.text();
|
|
305
|
+
if (!logs.includes(model.model)) {
|
|
306
|
+
console.log(' โ ๏ธ Model not reflected in logs, continuing anyway...');
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
console.log(' โ
Container ready');
|
|
310
|
+
console.log(' ๐ฅ Testing entity extraction...');
|
|
311
|
+
|
|
312
|
+
const result = await testModel(model, i);
|
|
313
|
+
results.push(result);
|
|
314
|
+
|
|
315
|
+
if (result.works) {
|
|
316
|
+
console.log(
|
|
317
|
+
` โ
PASS - ${result.entitiesFound} entities, ${result.expectedFound}/${EXPECTED_ENTITIES.length} expected (${result.extractionTimeMs}ms)`
|
|
318
|
+
);
|
|
319
|
+
} else {
|
|
320
|
+
console.log(
|
|
321
|
+
` โ FAIL - ${result.error || `Only ${result.expectedFound}/${EXPECTED_ENTITIES.length} expected entities`}`
|
|
322
|
+
);
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
// Summary
|
|
327
|
+
console.log(`\n${'โ'.repeat(70)}`);
|
|
328
|
+
console.log('๐ GROK MODEL RESULTS');
|
|
329
|
+
console.log(`${'โ'.repeat(70)}`);
|
|
330
|
+
|
|
331
|
+
const working = results.filter((r) => r.works);
|
|
332
|
+
const failed = results.filter((r) => !r.works);
|
|
333
|
+
|
|
334
|
+
console.log(`\nโ
WORKING MODELS (${working.length}/${results.length}):`);
|
|
335
|
+
if (working.length > 0) {
|
|
336
|
+
console.log('| Model | Cost/1K | Entities | Time |');
|
|
337
|
+
console.log('|-------|---------|----------|------|');
|
|
338
|
+
for (const r of working.sort((a, b) => a.cost - b.cost)) {
|
|
339
|
+
console.log(
|
|
340
|
+
`| ${r.name.padEnd(20)} | $${r.cost.toFixed(4).padStart(6)} | ${r.entitiesFound}/${r.expectedFound} | ${r.extractionTimeMs}ms |`
|
|
341
|
+
);
|
|
342
|
+
}
|
|
343
|
+
} else {
|
|
344
|
+
console.log(' (none)');
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
if (failed.length > 0) {
|
|
348
|
+
console.log(`\nโ FAILED MODELS (${failed.length}/${results.length}):`);
|
|
349
|
+
console.log('| Model | Cost/1K | Error |');
|
|
350
|
+
console.log('|-------|---------|-------|');
|
|
351
|
+
for (const r of failed) {
|
|
352
|
+
const error = (r.error || 'Unknown').slice(0, 50);
|
|
353
|
+
console.log(`| ${r.name.padEnd(20)} | $${r.cost.toFixed(4).padStart(6)} | ${error} |`);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
// Save results
|
|
358
|
+
await Bun.write(
|
|
359
|
+
'grok-mcp-results.json',
|
|
360
|
+
JSON.stringify(
|
|
361
|
+
{
|
|
362
|
+
results,
|
|
363
|
+
summary: {
|
|
364
|
+
total: results.length,
|
|
365
|
+
working: working.length,
|
|
366
|
+
failed: failed.length,
|
|
367
|
+
workingModels: working.map((r) => r.model),
|
|
368
|
+
cheapestWorking: working.sort((a, b) => a.cost - b.cost)[0]?.name || 'None',
|
|
369
|
+
},
|
|
370
|
+
testEpisode: TEST_EPISODE,
|
|
371
|
+
expectedEntities: EXPECTED_ENTITIES,
|
|
372
|
+
timestamp: new Date().toISOString(),
|
|
373
|
+
},
|
|
374
|
+
null,
|
|
375
|
+
2
|
|
376
|
+
)
|
|
377
|
+
);
|
|
378
|
+
|
|
379
|
+
console.log('\n๐ Results saved to grok-mcp-results.json');
|
|
380
|
+
|
|
381
|
+
// Restore to GPT-4o-mini (known working)
|
|
382
|
+
console.log('\n๐ Restoring GPT-4o-mini configuration...');
|
|
383
|
+
await updateEnvAndRestart('openai/gpt-4o-mini');
|
|
384
|
+
}
|
|
385
|
+
|
|
386
|
+
main().catch(console.error);
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
#!/usr/bin/env bun
|
|
2
|
+
/**
|
|
3
|
+
* Test Grok models via OpenRouter
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const OPENROUTER_API_KEY = process.env.OPENROUTER_API_KEY;
|
|
7
|
+
const OPENROUTER_BASE_URL = 'https://openrouter.ai/api/v1';
|
|
8
|
+
|
|
9
|
+
if (!OPENROUTER_API_KEY) {
|
|
10
|
+
console.error('โ OPENROUTER_API_KEY required');
|
|
11
|
+
process.exit(1);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
// Grok models on OpenRouter
|
|
15
|
+
const GROK_MODELS = [
|
|
16
|
+
{ id: 'x-ai/grok-2-1212', name: 'Grok 2', inputPrice: 2.0, outputPrice: 10.0 },
|
|
17
|
+
{ id: 'x-ai/grok-2-vision-1212', name: 'Grok 2 Vision', inputPrice: 2.0, outputPrice: 10.0 },
|
|
18
|
+
{ id: 'x-ai/grok-beta', name: 'Grok Beta', inputPrice: 5.0, outputPrice: 15.0 },
|
|
19
|
+
];
|
|
20
|
+
|
|
21
|
+
const TEST_CASES = [
|
|
22
|
+
{
|
|
23
|
+
name: 'Basic Entity Extraction',
|
|
24
|
+
text: 'John Smith works at Acme Corp in New York. He met Sarah Jones yesterday to discuss the Q4 budget.',
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
name: 'Technical Content',
|
|
28
|
+
text: 'The PAI system uses Neo4j for graph storage and OpenAI for embeddings. It was created by Daniel Miessler.',
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
name: 'Complex Relationships',
|
|
32
|
+
text: `Alice, the CTO of TechStart, acquired DataFlow Inc last month. Bob, who was DataFlow's CEO, now reports to Alice.`,
|
|
33
|
+
},
|
|
34
|
+
];
|
|
35
|
+
|
|
36
|
+
const PROMPT = (
|
|
37
|
+
text: string
|
|
38
|
+
) => `Extract entities and relationships from this text. Return ONLY valid JSON.
|
|
39
|
+
|
|
40
|
+
Text: "${text}"
|
|
41
|
+
|
|
42
|
+
Format: {"entities": [{"name": "string", "type": "PERSON|ORGANIZATION|LOCATION"}], "relationships": [{"source": "string", "target": "string", "type": "string"}]}`;
|
|
43
|
+
|
|
44
|
+
function extractJSON(text: string): any | null {
|
|
45
|
+
const clean = text
|
|
46
|
+
.replace(/```json\n?/g, '')
|
|
47
|
+
.replace(/```\n?/g, '')
|
|
48
|
+
.trim();
|
|
49
|
+
try {
|
|
50
|
+
const obj = JSON.parse(clean);
|
|
51
|
+
if (obj.entities && obj.relationships) return obj;
|
|
52
|
+
} catch {}
|
|
53
|
+
const match = clean.match(/\{[\s\S]*"entities"[\s\S]*"relationships"[\s\S]*\}/);
|
|
54
|
+
if (match) {
|
|
55
|
+
try {
|
|
56
|
+
return JSON.parse(match[0]);
|
|
57
|
+
} catch {}
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
async function testModel(model: (typeof GROK_MODELS)[0]) {
|
|
63
|
+
console.log(`\n๐ Testing: ${model.name} (${model.id})`);
|
|
64
|
+
console.log(` ${'โ'.repeat(50)}`);
|
|
65
|
+
|
|
66
|
+
let passed = 0;
|
|
67
|
+
let totalMs = 0;
|
|
68
|
+
let totalInput = 0;
|
|
69
|
+
let totalOutput = 0;
|
|
70
|
+
|
|
71
|
+
for (const test of TEST_CASES) {
|
|
72
|
+
const start = Date.now();
|
|
73
|
+
try {
|
|
74
|
+
const res = await fetch(`${OPENROUTER_BASE_URL}/chat/completions`, {
|
|
75
|
+
method: 'POST',
|
|
76
|
+
headers: {
|
|
77
|
+
Authorization: `Bearer ${OPENROUTER_API_KEY}`,
|
|
78
|
+
'Content-Type': 'application/json',
|
|
79
|
+
},
|
|
80
|
+
body: JSON.stringify({
|
|
81
|
+
model: model.id,
|
|
82
|
+
messages: [{ role: 'user', content: PROMPT(test.text) }],
|
|
83
|
+
temperature: 0.1,
|
|
84
|
+
max_tokens: 1000,
|
|
85
|
+
}),
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
const ms = Date.now() - start;
|
|
89
|
+
totalMs += ms;
|
|
90
|
+
|
|
91
|
+
if (!res.ok) {
|
|
92
|
+
const err = await res.text();
|
|
93
|
+
console.log(` โ ${test.name}: HTTP ${res.status} - ${err.slice(0, 80)}`);
|
|
94
|
+
continue;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
const data = (await res.json()) as any;
|
|
98
|
+
const content = data.choices?.[0]?.message?.content || '';
|
|
99
|
+
totalInput += data.usage?.prompt_tokens || 0;
|
|
100
|
+
totalOutput += data.usage?.completion_tokens || 0;
|
|
101
|
+
|
|
102
|
+
const json = extractJSON(content);
|
|
103
|
+
if (json) {
|
|
104
|
+
console.log(
|
|
105
|
+
` โ
${test.name}: ${json.entities.length} entities, ${json.relationships.length} rels (${ms}ms)`
|
|
106
|
+
);
|
|
107
|
+
passed++;
|
|
108
|
+
} else {
|
|
109
|
+
console.log(` โ ${test.name}: Invalid JSON (${ms}ms)`);
|
|
110
|
+
}
|
|
111
|
+
} catch (err: any) {
|
|
112
|
+
console.log(` โ ${test.name}: ${err.message}`);
|
|
113
|
+
}
|
|
114
|
+
await new Promise((r) => setTimeout(r, 500));
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
const avgMs = Math.round(totalMs / TEST_CASES.length);
|
|
118
|
+
const avgInput = Math.round(totalInput / TEST_CASES.length);
|
|
119
|
+
const avgOutput = Math.round(totalOutput / TEST_CASES.length);
|
|
120
|
+
const cost = ((avgInput / 1e6) * model.inputPrice + (avgOutput / 1e6) * model.outputPrice) * 1000;
|
|
121
|
+
|
|
122
|
+
return {
|
|
123
|
+
model: model.name,
|
|
124
|
+
id: model.id,
|
|
125
|
+
passRate: (passed / TEST_CASES.length) * 100,
|
|
126
|
+
avgMs,
|
|
127
|
+
cost,
|
|
128
|
+
inputPrice: model.inputPrice,
|
|
129
|
+
outputPrice: model.outputPrice,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
async function main() {
|
|
134
|
+
console.log('โ'.repeat(60));
|
|
135
|
+
console.log('๐งช Grok Model Test (via OpenRouter)');
|
|
136
|
+
console.log('โ'.repeat(60));
|
|
137
|
+
|
|
138
|
+
const results = [];
|
|
139
|
+
for (const model of GROK_MODELS) {
|
|
140
|
+
results.push(await testModel(model));
|
|
141
|
+
await new Promise((r) => setTimeout(r, 1000));
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
console.log(`\n${'โ'.repeat(80)}`);
|
|
145
|
+
console.log('๐ GROK MODELS COMPARISON');
|
|
146
|
+
console.log(`${'โ'.repeat(80)}\n`);
|
|
147
|
+
|
|
148
|
+
console.log(
|
|
149
|
+
'| Model | Pass Rate | Avg Time | Input $/M | Output $/M | Cost/1K Calls |'
|
|
150
|
+
);
|
|
151
|
+
console.log(
|
|
152
|
+
'|-----------------|-----------|----------|-----------|------------|---------------|'
|
|
153
|
+
);
|
|
154
|
+
for (const r of results) {
|
|
155
|
+
if (r.passRate > 0) {
|
|
156
|
+
console.log(
|
|
157
|
+
`| ${r.model.padEnd(15)} | ${r.passRate.toFixed(0).padStart(7)}% | ${(`${r.avgMs}ms`).padStart(8)} | $${r.inputPrice.toFixed(2).padStart(7)} | $${r.outputPrice.toFixed(2).padStart(8)} | $${r.cost.toFixed(4).padStart(11)} |`
|
|
158
|
+
);
|
|
159
|
+
} else {
|
|
160
|
+
console.log(
|
|
161
|
+
`| ${r.model.padEnd(15)} | FAILED | - | - | - | - |`
|
|
162
|
+
);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
await Bun.write(
|
|
167
|
+
'grok-test-results.json',
|
|
168
|
+
JSON.stringify({ results, timestamp: new Date().toISOString() }, null, 2)
|
|
169
|
+
);
|
|
170
|
+
console.log('\n๐ Results saved to grok-test-results.json');
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
main();
|