#
tokens: 44696/50000 2/1784 files (page 104/145)
lines: on (toggle) GitHub
raw markdown copy reset
This is page 104 of 145. Use http://codebase.md/microsoft/semanticworkbench?lines=true&page={x} to view the full context.

# Directory Structure

```
├── .devcontainer
│   ├── .vscode
│   │   └── settings.json
│   ├── devcontainer.json
│   ├── OPTIMIZING_FOR_CODESPACES.md
│   ├── POST_SETUP_README.md
│   └── README.md
├── .dockerignore
├── .gitattributes
├── .github
│   ├── policheck.yml
│   └── workflows
│       ├── assistants-codespace-assistant.yml
│       ├── assistants-document-assistant.yml
│       ├── assistants-explorer-assistant.yml
│       ├── assistants-guided-conversation-assistant.yml
│       ├── assistants-knowledge-transfer-assistant.yml
│       ├── assistants-navigator-assistant.yml
│       ├── assistants-project-assistant.yml
│       ├── assistants-prospector-assistant.yml
│       ├── assistants-skill-assistant.yml
│       ├── libraries.yml
│       ├── mcp-server-giphy.yml
│       ├── mcp-server-memory-filesystem-edit.yml
│       ├── mcp-server-memory-user-bio.yml
│       ├── mcp-server-memory-whiteboard.yml
│       ├── mcp-server-open-deep-research-clone.yml
│       ├── mcp-server-web-research.yml
│       ├── workbench-app.yml
│       └── workbench-service.yml
├── .gitignore
├── .multi-root-tools
│   ├── Makefile
│   └── README.md
├── .vscode
│   ├── extensions.json
│   ├── launch.json
│   └── settings.json
├── ai_context
│   └── generated
│       ├── ASPIRE_ORCHESTRATOR.md
│       ├── ASSISTANT_CODESPACE.md
│       ├── ASSISTANT_DOCUMENT.md
│       ├── ASSISTANT_NAVIGATOR.md
│       ├── ASSISTANT_PROJECT.md
│       ├── ASSISTANT_PROSPECTOR.md
│       ├── ASSISTANTS_OTHER.md
│       ├── ASSISTANTS_OVERVIEW.md
│       ├── CONFIGURATION.md
│       ├── DOTNET_LIBRARIES.md
│       ├── EXAMPLES.md
│       ├── MCP_SERVERS.md
│       ├── PYTHON_LIBRARIES_AI_CLIENTS.md
│       ├── PYTHON_LIBRARIES_CORE.md
│       ├── PYTHON_LIBRARIES_EXTENSIONS.md
│       ├── PYTHON_LIBRARIES_SKILLS.md
│       ├── PYTHON_LIBRARIES_SPECIALIZED.md
│       ├── TOOLS.md
│       ├── WORKBENCH_FRONTEND.md
│       └── WORKBENCH_SERVICE.md
├── aspire-orchestrator
│   ├── .editorconfig
│   ├── Aspire.AppHost
│   │   ├── .gitignore
│   │   ├── appsettings.json
│   │   ├── Aspire.AppHost.csproj
│   │   ├── Program.cs
│   │   └── Properties
│   │       └── launchSettings.json
│   ├── Aspire.Extensions
│   │   ├── Aspire.Extensions.csproj
│   │   ├── Dashboard.cs
│   │   ├── DockerFileExtensions.cs
│   │   ├── PathNormalizer.cs
│   │   ├── UvAppHostingExtensions.cs
│   │   ├── UvAppResource.cs
│   │   ├── VirtualEnvironment.cs
│   │   └── WorkbenchServiceHostingExtensions.cs
│   ├── Aspire.ServiceDefaults
│   │   ├── Aspire.ServiceDefaults.csproj
│   │   └── Extensions.cs
│   ├── README.md
│   ├── run.sh
│   ├── SemanticWorkbench.Aspire.sln
│   └── SemanticWorkbench.Aspire.sln.DotSettings
├── assistants
│   ├── codespace-assistant
│   │   ├── .claude
│   │   │   └── settings.local.json
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── extensions.json
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── assets
│   │   │   │   ├── icon_context_transfer.svg
│   │   │   │   └── icon.svg
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   ├── helpers.py
│   │   │   ├── response
│   │   │   │   ├── __init__.py
│   │   │   │   ├── completion_handler.py
│   │   │   │   ├── models.py
│   │   │   │   ├── request_builder.py
│   │   │   │   ├── response.py
│   │   │   │   ├── step_handler.py
│   │   │   │   └── utils
│   │   │   │       ├── __init__.py
│   │   │   │       ├── abbreviations.py
│   │   │   │       ├── formatting_utils.py
│   │   │   │       ├── message_utils.py
│   │   │   │       └── openai_utils.py
│   │   │   ├── text_includes
│   │   │   │   ├── card_content_context_transfer.md
│   │   │   │   ├── card_content.md
│   │   │   │   ├── codespace_assistant_info.md
│   │   │   │   ├── context_transfer_assistant_info.md
│   │   │   │   ├── guardrails_prompt.txt
│   │   │   │   ├── guidance_prompt_context_transfer.txt
│   │   │   │   ├── guidance_prompt.txt
│   │   │   │   ├── instruction_prompt_context_transfer.txt
│   │   │   │   └── instruction_prompt.txt
│   │   │   └── whiteboard
│   │   │       ├── __init__.py
│   │   │       ├── _inspector.py
│   │   │       └── _whiteboard.py
│   │   ├── assistant.code-workspace
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── document-assistant
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── assets
│   │   │   │   └── icon.svg
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   ├── context_management
│   │   │   │   ├── __init__.py
│   │   │   │   └── inspector.py
│   │   │   ├── filesystem
│   │   │   │   ├── __init__.py
│   │   │   │   ├── _convert.py
│   │   │   │   ├── _file_sources.py
│   │   │   │   ├── _filesystem.py
│   │   │   │   ├── _inspector.py
│   │   │   │   ├── _model.py
│   │   │   │   ├── _prompts.py
│   │   │   │   └── _tasks.py
│   │   │   ├── guidance
│   │   │   │   ├── __init__.py
│   │   │   │   ├── dynamic_ui_inspector.py
│   │   │   │   ├── guidance_config.py
│   │   │   │   ├── guidance_prompts.py
│   │   │   │   └── README.md
│   │   │   ├── response
│   │   │   │   ├── __init__.py
│   │   │   │   ├── completion_handler.py
│   │   │   │   ├── models.py
│   │   │   │   ├── prompts.py
│   │   │   │   ├── responder.py
│   │   │   │   └── utils
│   │   │   │       ├── __init__.py
│   │   │   │       ├── formatting_utils.py
│   │   │   │       ├── message_utils.py
│   │   │   │       ├── openai_utils.py
│   │   │   │       ├── tokens_tiktoken.py
│   │   │   │       └── workbench_messages.py
│   │   │   ├── text_includes
│   │   │   │   └── document_assistant_info.md
│   │   │   ├── types.py
│   │   │   └── whiteboard
│   │   │       ├── __init__.py
│   │   │       ├── _inspector.py
│   │   │       └── _whiteboard.py
│   │   ├── assistant.code-workspace
│   │   ├── CLAUDE.md
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   ├── __init__.py
│   │   │   ├── test_convert.py
│   │   │   └── test_data
│   │   │       ├── blank_image.png
│   │   │       ├── Formatting Test.docx
│   │   │       ├── sample_data.csv
│   │   │       ├── sample_data.xlsx
│   │   │       ├── sample_page.html
│   │   │       ├── sample_presentation.pptx
│   │   │       └── simple_pdf.pdf
│   │   └── uv.lock
│   ├── explorer-assistant
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   ├── helpers.py
│   │   │   ├── response
│   │   │   │   ├── __init__.py
│   │   │   │   ├── model.py
│   │   │   │   ├── response_anthropic.py
│   │   │   │   ├── response_openai.py
│   │   │   │   └── response.py
│   │   │   └── text_includes
│   │   │       └── guardrails_prompt.txt
│   │   ├── assistant.code-workspace
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── guided-conversation-assistant
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── agents
│   │   │   │   ├── guided_conversation
│   │   │   │   │   ├── config.py
│   │   │   │   │   ├── definition.py
│   │   │   │   │   └── definitions
│   │   │   │   │       ├── er_triage.py
│   │   │   │   │       ├── interview.py
│   │   │   │   │       ├── patient_intake.py
│   │   │   │   │       └── poem_feedback.py
│   │   │   │   └── guided_conversation_agent.py
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   └── text_includes
│   │   │       └── guardrails_prompt.txt
│   │   ├── assistant.code-workspace
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── knowledge-transfer-assistant
│   │   ├── .claude
│   │   │   └── settings.local.json
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── agentic
│   │   │   │   ├── __init__.py
│   │   │   │   ├── analysis.py
│   │   │   │   ├── coordinator_support.py
│   │   │   │   └── team_welcome.py
│   │   │   ├── assets
│   │   │   │   ├── icon-knowledge-transfer.svg
│   │   │   │   └── icon.svg
│   │   │   ├── assistant.py
│   │   │   ├── common.py
│   │   │   ├── config.py
│   │   │   ├── conversation_clients.py
│   │   │   ├── conversation_share_link.py
│   │   │   ├── data.py
│   │   │   ├── domain
│   │   │   │   ├── __init__.py
│   │   │   │   ├── audience_manager.py
│   │   │   │   ├── information_request_manager.py
│   │   │   │   ├── knowledge_brief_manager.py
│   │   │   │   ├── knowledge_digest_manager.py
│   │   │   │   ├── learning_objectives_manager.py
│   │   │   │   └── share_manager.py
│   │   │   ├── files.py
│   │   │   ├── logging.py
│   │   │   ├── notifications.py
│   │   │   ├── respond.py
│   │   │   ├── storage_models.py
│   │   │   ├── storage.py
│   │   │   ├── string_utils.py
│   │   │   ├── text_includes
│   │   │   │   ├── assistant_info.md
│   │   │   │   ├── card_content.md
│   │   │   │   ├── coordinator_instructions.txt
│   │   │   │   ├── coordinator_role.txt
│   │   │   │   ├── knowledge_digest_instructions.txt
│   │   │   │   ├── knowledge_digest_prompt.txt
│   │   │   │   ├── share_information_request_detection.txt
│   │   │   │   ├── team_instructions.txt
│   │   │   │   ├── team_role.txt
│   │   │   │   └── welcome_message_generation.txt
│   │   │   ├── tools
│   │   │   │   ├── __init__.py
│   │   │   │   ├── base.py
│   │   │   │   ├── information_requests.py
│   │   │   │   ├── learning_objectives.py
│   │   │   │   ├── learning_outcomes.py
│   │   │   │   ├── progress_tracking.py
│   │   │   │   └── share_setup.py
│   │   │   ├── ui_tabs
│   │   │   │   ├── __init__.py
│   │   │   │   ├── brief.py
│   │   │   │   ├── common.py
│   │   │   │   ├── debug.py
│   │   │   │   ├── learning.py
│   │   │   │   └── sharing.py
│   │   │   └── utils.py
│   │   ├── CLAUDE.md
│   │   ├── docs
│   │   │   ├── design
│   │   │   │   ├── actions.md
│   │   │   │   └── inference.md
│   │   │   ├── DEV_GUIDE.md
│   │   │   ├── how-kta-works.md
│   │   │   ├── JTBD.md
│   │   │   ├── knowledge-transfer-goals.md
│   │   │   ├── learning_assistance.md
│   │   │   ├── notable_claude_conversations
│   │   │   │   ├── clarifying_quad_modal_design.md
│   │   │   │   ├── CLAUDE_PROMPTS.md
│   │   │   │   ├── transfer_state.md
│   │   │   │   └── trying_the_context_agent.md
│   │   │   └── opportunities-of-knowledge-transfer.md
│   │   ├── knowledge-transfer-assistant.code-workspace
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   ├── __init__.py
│   │   │   ├── test_artifact_loading.py
│   │   │   ├── test_inspector.py
│   │   │   ├── test_share_manager.py
│   │   │   ├── test_share_storage.py
│   │   │   ├── test_share_tools.py
│   │   │   └── test_team_mode.py
│   │   └── uv.lock
│   ├── Makefile
│   ├── navigator-assistant
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── assets
│   │   │   │   ├── card_content.md
│   │   │   │   └── icon.svg
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   ├── helpers.py
│   │   │   ├── response
│   │   │   │   ├── __init__.py
│   │   │   │   ├── completion_handler.py
│   │   │   │   ├── completion_requestor.py
│   │   │   │   ├── local_tool
│   │   │   │   │   ├── __init__.py
│   │   │   │   │   ├── add_assistant_to_conversation.py
│   │   │   │   │   ├── list_assistant_services.py
│   │   │   │   │   └── model.py
│   │   │   │   ├── models.py
│   │   │   │   ├── prompt.py
│   │   │   │   ├── request_builder.py
│   │   │   │   ├── response.py
│   │   │   │   ├── step_handler.py
│   │   │   │   └── utils
│   │   │   │       ├── __init__.py
│   │   │   │       ├── formatting_utils.py
│   │   │   │       ├── message_utils.py
│   │   │   │       ├── openai_utils.py
│   │   │   │       └── tools.py
│   │   │   ├── text_includes
│   │   │   │   ├── guardrails_prompt.md
│   │   │   │   ├── guidance_prompt.md
│   │   │   │   ├── instruction_prompt.md
│   │   │   │   ├── navigator_assistant_info.md
│   │   │   │   └── semantic_workbench_features.md
│   │   │   └── whiteboard
│   │   │       ├── __init__.py
│   │   │       ├── _inspector.py
│   │   │       └── _whiteboard.py
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── project-assistant
│   │   ├── .cspell
│   │   │   └── custom-dictionary-workspace.txt
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── agentic
│   │   │   │   ├── __init__.py
│   │   │   │   ├── act.py
│   │   │   │   ├── coordinator_next_action.py
│   │   │   │   ├── create_invitation.py
│   │   │   │   ├── detect_audience_and_takeaways.py
│   │   │   │   ├── detect_coordinator_actions.py
│   │   │   │   ├── detect_information_request_needs.py
│   │   │   │   ├── detect_knowledge_package_gaps.py
│   │   │   │   ├── focus.py
│   │   │   │   ├── respond.py
│   │   │   │   ├── team_welcome.py
│   │   │   │   └── update_digest.py
│   │   │   ├── assets
│   │   │   │   ├── icon-knowledge-transfer.svg
│   │   │   │   └── icon.svg
│   │   │   ├── assistant.py
│   │   │   ├── common.py
│   │   │   ├── config.py
│   │   │   ├── conversation_clients.py
│   │   │   ├── data.py
│   │   │   ├── domain
│   │   │   │   ├── __init__.py
│   │   │   │   ├── audience_manager.py
│   │   │   │   ├── conversation_preferences_manager.py
│   │   │   │   ├── information_request_manager.py
│   │   │   │   ├── knowledge_brief_manager.py
│   │   │   │   ├── knowledge_digest_manager.py
│   │   │   │   ├── learning_objectives_manager.py
│   │   │   │   ├── share_manager.py
│   │   │   │   ├── tasks_manager.py
│   │   │   │   └── transfer_manager.py
│   │   │   ├── errors.py
│   │   │   ├── files.py
│   │   │   ├── logging.py
│   │   │   ├── notifications.py
│   │   │   ├── prompt_utils.py
│   │   │   ├── storage.py
│   │   │   ├── string_utils.py
│   │   │   ├── text_includes
│   │   │   │   ├── actor_instructions.md
│   │   │   │   ├── assistant_info.md
│   │   │   │   ├── card_content.md
│   │   │   │   ├── coordinator_instructions copy.md
│   │   │   │   ├── coordinator_instructions.md
│   │   │   │   ├── create_invitation.md
│   │   │   │   ├── detect_audience.md
│   │   │   │   ├── detect_coordinator_actions.md
│   │   │   │   ├── detect_information_request_needs.md
│   │   │   │   ├── detect_knowledge_package_gaps.md
│   │   │   │   ├── focus.md
│   │   │   │   ├── knowledge_digest_instructions.txt
│   │   │   │   ├── team_instructions.txt
│   │   │   │   ├── to_do.md
│   │   │   │   ├── update_knowledge_brief.md
│   │   │   │   ├── update_knowledge_digest.md
│   │   │   │   └── welcome_message_generation.txt
│   │   │   ├── tools
│   │   │   │   ├── __init__.py
│   │   │   │   ├── base.py
│   │   │   │   ├── conversation_preferences.py
│   │   │   │   ├── information_requests.py
│   │   │   │   ├── learning_objectives.py
│   │   │   │   ├── learning_outcomes.py
│   │   │   │   ├── progress_tracking.py
│   │   │   │   ├── share_setup.py
│   │   │   │   ├── system_reminders.py
│   │   │   │   ├── tasks.py
│   │   │   │   └── todo.py
│   │   │   ├── ui_tabs
│   │   │   │   ├── __init__.py
│   │   │   │   ├── brief.py
│   │   │   │   ├── common.py
│   │   │   │   ├── debug.py
│   │   │   │   ├── learning.py
│   │   │   │   └── sharing.py
│   │   │   └── utils.py
│   │   ├── CLAUDE.md
│   │   ├── docs
│   │   │   ├── design
│   │   │   │   ├── actions.md
│   │   │   │   ├── control_options.md
│   │   │   │   ├── design.md
│   │   │   │   ├── inference.md
│   │   │   │   └── PXL_20250814_190140267.jpg
│   │   │   ├── DEV_GUIDE.md
│   │   │   ├── how-kta-works.md
│   │   │   ├── JTBD.md
│   │   │   ├── knowledge-transfer-goals.md
│   │   │   ├── learning_assistance.md
│   │   │   ├── notable_claude_conversations
│   │   │   │   ├── clarifying_quad_modal_design.md
│   │   │   │   ├── CLAUDE_PROMPTS.md
│   │   │   │   ├── transfer_state.md
│   │   │   │   └── trying_the_context_agent.md
│   │   │   └── opportunities-of-knowledge-transfer.md
│   │   ├── knowledge-transfer-assistant.code-workspace
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   ├── __init__.py
│   │   │   ├── test_artifact_loading.py
│   │   │   ├── test_inspector.py
│   │   │   ├── test_share_manager.py
│   │   │   ├── test_share_storage.py
│   │   │   └── test_team_mode.py
│   │   └── uv.lock
│   ├── prospector-assistant
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── assistant
│   │   │   ├── __init__.py
│   │   │   ├── agents
│   │   │   │   ├── artifact_agent.py
│   │   │   │   ├── document
│   │   │   │   │   ├── config.py
│   │   │   │   │   ├── gc_draft_content_feedback_config.py
│   │   │   │   │   ├── gc_draft_outline_feedback_config.py
│   │   │   │   │   ├── guided_conversation.py
│   │   │   │   │   └── state.py
│   │   │   │   └── document_agent.py
│   │   │   ├── artifact_creation_extension
│   │   │   │   ├── __init__.py
│   │   │   │   ├── _llm.py
│   │   │   │   ├── config.py
│   │   │   │   ├── document.py
│   │   │   │   ├── extension.py
│   │   │   │   ├── store.py
│   │   │   │   ├── test
│   │   │   │   │   ├── conftest.py
│   │   │   │   │   ├── evaluation.py
│   │   │   │   │   ├── test_completion_with_tools.py
│   │   │   │   │   └── test_extension.py
│   │   │   │   └── tools.py
│   │   │   ├── chat.py
│   │   │   ├── config.py
│   │   │   ├── form_fill_extension
│   │   │   │   ├── __init__.py
│   │   │   │   ├── config.py
│   │   │   │   ├── extension.py
│   │   │   │   ├── inspector.py
│   │   │   │   ├── state.py
│   │   │   │   └── steps
│   │   │   │       ├── __init__.py
│   │   │   │       ├── _guided_conversation.py
│   │   │   │       ├── _llm.py
│   │   │   │       ├── acquire_form_step.py
│   │   │   │       ├── extract_form_fields_step.py
│   │   │   │       ├── fill_form_step.py
│   │   │   │       └── types.py
│   │   │   ├── helpers.py
│   │   │   ├── legacy.py
│   │   │   └── text_includes
│   │   │       ├── artifact_agent_enabled.md
│   │   │       ├── guardrails_prompt.txt
│   │   │       ├── guided_conversation_agent_enabled.md
│   │   │       └── skills_agent_enabled.md
│   │   ├── assistant.code-workspace
│   │   ├── gc_learnings
│   │   │   ├── gc_learnings.md
│   │   │   └── images
│   │   │       ├── gc_conversation_plan_fcn.png
│   │   │       ├── gc_conversation_plan_template.png
│   │   │       ├── gc_execute_plan_callstack.png
│   │   │       ├── gc_functions.png
│   │   │       ├── gc_generate_plan_callstack.png
│   │   │       ├── gc_get_resource_instructions.png
│   │   │       ├── gc_get_termination_instructions.png
│   │   │       ├── gc_kernel_arguments.png
│   │   │       ├── gc_plan_calls.png
│   │   │       ├── gc_termination_instructions.png
│   │   │       ├── sk_get_chat_message_contents.png
│   │   │       ├── sk_inner_get_chat_message_contents.png
│   │   │       ├── sk_send_request_prep.png
│   │   │       └── sk_send_request.png
│   │   ├── Makefile
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   └── skill-assistant
│       ├── .env.example
│       ├── .vscode
│       │   ├── launch.json
│       │   └── settings.json
│       ├── assistant
│       │   ├── __init__.py
│       │   ├── config.py
│       │   ├── logging.py
│       │   ├── skill_assistant.py
│       │   ├── skill_engine_registry.py
│       │   ├── skill_event_mapper.py
│       │   ├── text_includes
│       │   │   └── guardrails_prompt.txt
│       │   └── workbench_helpers.py
│       ├── assistant.code-workspace
│       ├── Makefile
│       ├── pyproject.toml
│       ├── README.md
│       ├── tests
│       │   └── test_setup.py
│       └── uv.lock
├── CLAUDE.md
├── CODE_OF_CONDUCT.md
├── CONTRIBUTING.md
├── docs
│   ├── .vscode
│   │   └── settings.json
│   ├── ASSISTANT_CONFIG.md
│   ├── ASSISTANT_DEVELOPMENT_GUIDE.md
│   ├── CUSTOM_APP_REGISTRATION.md
│   ├── HOSTED_ASSISTANT_WITH_LOCAL_MCP_SERVERS.md
│   ├── images
│   │   ├── architecture-animation.gif
│   │   ├── configure_assistant.png
│   │   ├── conversation_canvas_open.png
│   │   ├── conversation_duplicate.png
│   │   ├── conversation_export.png
│   │   ├── conversation_share_dialog.png
│   │   ├── conversation_share_link.png
│   │   ├── dashboard_configured_view.png
│   │   ├── dashboard_view.png
│   │   ├── license_agreement.png
│   │   ├── message_bar.png
│   │   ├── message_inspection.png
│   │   ├── message_link.png
│   │   ├── new_prospector_assistant_dialog.png
│   │   ├── open_conversation_canvas.png
│   │   ├── prospector_example.png
│   │   ├── readme1.png
│   │   ├── readme2.png
│   │   ├── readme3.png
│   │   ├── rewind.png
│   │   ├── signin_page.png
│   │   └── splash_screen.png
│   ├── LOCAL_ASSISTANT_WITH_REMOTE_WORKBENCH.md
│   ├── SETUP_DEV_ENVIRONMENT.md
│   └── WORKBENCH_APP.md
├── examples
│   ├── dotnet
│   │   ├── .editorconfig
│   │   ├── dotnet-01-echo-bot
│   │   │   ├── appsettings.json
│   │   │   ├── dotnet-01-echo-bot.csproj
│   │   │   ├── MyAgent.cs
│   │   │   ├── MyAgentConfig.cs
│   │   │   ├── MyWorkbenchConnector.cs
│   │   │   ├── Program.cs
│   │   │   └── README.md
│   │   ├── dotnet-02-message-types-demo
│   │   │   ├── appsettings.json
│   │   │   ├── ConnectorExtensions.cs
│   │   │   ├── docs
│   │   │   │   ├── abc.png
│   │   │   │   ├── code.png
│   │   │   │   ├── config.png
│   │   │   │   ├── echo.png
│   │   │   │   ├── markdown.png
│   │   │   │   ├── mermaid.png
│   │   │   │   ├── reverse.png
│   │   │   │   └── safety-check.png
│   │   │   ├── dotnet-02-message-types-demo.csproj
│   │   │   ├── MyAgent.cs
│   │   │   ├── MyAgentConfig.cs
│   │   │   ├── MyWorkbenchConnector.cs
│   │   │   ├── Program.cs
│   │   │   └── README.md
│   │   └── dotnet-03-simple-chatbot
│   │       ├── appsettings.json
│   │       ├── ConnectorExtensions.cs
│   │       ├── dotnet-03-simple-chatbot.csproj
│   │       ├── MyAgent.cs
│   │       ├── MyAgentConfig.cs
│   │       ├── MyWorkbenchConnector.cs
│   │       ├── Program.cs
│   │       └── README.md
│   ├── Makefile
│   └── python
│       ├── python-01-echo-bot
│       │   ├── .env.example
│       │   ├── .vscode
│       │   │   ├── launch.json
│       │   │   └── settings.json
│       │   ├── assistant
│       │   │   ├── __init__.py
│       │   │   ├── chat.py
│       │   │   └── config.py
│       │   ├── assistant.code-workspace
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── python-02-simple-chatbot
│       │   ├── .env.example
│       │   ├── .vscode
│       │   │   ├── launch.json
│       │   │   └── settings.json
│       │   ├── assistant
│       │   │   ├── __init__.py
│       │   │   ├── chat.py
│       │   │   ├── config.py
│       │   │   └── text_includes
│       │   │       └── guardrails_prompt.txt
│       │   ├── assistant.code-workspace
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       └── python-03-multimodel-chatbot
│           ├── .env.example
│           ├── .vscode
│           │   ├── launch.json
│           │   └── settings.json
│           ├── assistant
│           │   ├── __init__.py
│           │   ├── chat.py
│           │   ├── config.py
│           │   ├── model_adapters.py
│           │   └── text_includes
│           │       └── guardrails_prompt.txt
│           ├── assistant.code-workspace
│           ├── Makefile
│           ├── pyproject.toml
│           ├── README.md
│           └── uv.lock
├── KNOWN_ISSUES.md
├── libraries
│   ├── dotnet
│   │   ├── .editorconfig
│   │   ├── pack.sh
│   │   ├── README.md
│   │   ├── SemanticWorkbench.sln
│   │   ├── SemanticWorkbench.sln.DotSettings
│   │   └── WorkbenchConnector
│   │       ├── AgentBase.cs
│   │       ├── AgentConfig
│   │       │   ├── AgentConfigBase.cs
│   │       │   ├── AgentConfigPropertyAttribute.cs
│   │       │   └── ConfigUtils.cs
│   │       ├── Constants.cs
│   │       ├── IAgentBase.cs
│   │       ├── icon.png
│   │       ├── Models
│   │       │   ├── Command.cs
│   │       │   ├── Conversation.cs
│   │       │   ├── ConversationEvent.cs
│   │       │   ├── DebugInfo.cs
│   │       │   ├── Insight.cs
│   │       │   ├── Message.cs
│   │       │   ├── MessageMetadata.cs
│   │       │   ├── Participant.cs
│   │       │   ├── Sender.cs
│   │       │   └── ServiceInfo.cs
│   │       ├── Storage
│   │       │   ├── AgentInfo.cs
│   │       │   ├── AgentServiceStorage.cs
│   │       │   └── IAgentServiceStorage.cs
│   │       ├── StringLoggingExtensions.cs
│   │       ├── Webservice.cs
│   │       ├── WorkbenchConfig.cs
│   │       ├── WorkbenchConnector.cs
│   │       └── WorkbenchConnector.csproj
│   ├── Makefile
│   └── python
│       ├── anthropic-client
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── anthropic_client
│       │   │   ├── __init__.py
│       │   │   ├── client.py
│       │   │   ├── config.py
│       │   │   └── messages.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── assistant-data-gen
│       │   ├── .vscode
│       │   │   ├── launch.json
│       │   │   └── settings.json
│       │   ├── assistant_data_gen
│       │   │   ├── __init__.py
│       │   │   ├── assistant_api.py
│       │   │   ├── config.py
│       │   │   ├── gce
│       │   │   │   ├── __init__.py
│       │   │   │   ├── gce_agent.py
│       │   │   │   └── prompts.py
│       │   │   └── pydantic_ai_utils.py
│       │   ├── configs
│       │   │   └── document_assistant_example_config.yaml
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── scripts
│       │   │   ├── gce_simulation.py
│       │   │   └── generate_scenario.py
│       │   └── uv.lock
│       ├── assistant-drive
│       │   ├── .gitignore
│       │   ├── .vscode
│       │   │   ├── extensions.json
│       │   │   └── settings.json
│       │   ├── assistant_drive
│       │   │   ├── __init__.py
│       │   │   ├── drive.py
│       │   │   └── tests
│       │   │       └── test_basic.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── pytest.ini
│       │   ├── README.md
│       │   ├── usage.ipynb
│       │   └── uv.lock
│       ├── assistant-extensions
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── assistant_extensions
│       │   │   ├── __init__.py
│       │   │   ├── ai_clients
│       │   │   │   └── config.py
│       │   │   ├── artifacts
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _artifacts.py
│       │   │   │   ├── _inspector.py
│       │   │   │   └── _model.py
│       │   │   ├── attachments
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _attachments.py
│       │   │   │   ├── _convert.py
│       │   │   │   ├── _model.py
│       │   │   │   ├── _shared.py
│       │   │   │   └── _summarizer.py
│       │   │   ├── chat_context_toolkit
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _config.py
│       │   │   │   ├── archive
│       │   │   │   │   ├── __init__.py
│       │   │   │   │   ├── _archive.py
│       │   │   │   │   └── _summarizer.py
│       │   │   │   ├── message_history
│       │   │   │   │   ├── __init__.py
│       │   │   │   │   ├── _history.py
│       │   │   │   │   └── _message.py
│       │   │   │   └── virtual_filesystem
│       │   │   │       ├── __init__.py
│       │   │   │       ├── _archive_file_source.py
│       │   │   │       └── _attachments_file_source.py
│       │   │   ├── dashboard_card
│       │   │   │   ├── __init__.py
│       │   │   │   └── _dashboard_card.py
│       │   │   ├── document_editor
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _extension.py
│       │   │   │   ├── _inspector.py
│       │   │   │   └── _model.py
│       │   │   ├── mcp
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _assistant_file_resource_handler.py
│       │   │   │   ├── _client_utils.py
│       │   │   │   ├── _devtunnel.py
│       │   │   │   ├── _model.py
│       │   │   │   ├── _openai_utils.py
│       │   │   │   ├── _sampling_handler.py
│       │   │   │   ├── _tool_utils.py
│       │   │   │   └── _workbench_file_resource_handler.py
│       │   │   ├── navigator
│       │   │   │   ├── __init__.py
│       │   │   │   └── _navigator.py
│       │   │   └── workflows
│       │   │       ├── __init__.py
│       │   │       ├── _model.py
│       │   │       ├── _workflows.py
│       │   │       └── runners
│       │   │           └── _user_proxy.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── test
│       │   │   └── attachments
│       │   │       └── test_attachments.py
│       │   └── uv.lock
│       ├── chat-context-toolkit
│       │   ├── .claude
│       │   │   └── settings.local.json
│       │   ├── .env.sample
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── assets
│       │   │   ├── archive_v1.png
│       │   │   ├── history_v1.png
│       │   │   └── vfs_v1.png
│       │   ├── chat_context_toolkit
│       │   │   ├── __init__.py
│       │   │   ├── archive
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _archive_reader.py
│       │   │   │   ├── _archive_task_queue.py
│       │   │   │   ├── _state.py
│       │   │   │   ├── _types.py
│       │   │   │   └── summarization
│       │   │   │       ├── __init__.py
│       │   │   │       └── _summarizer.py
│       │   │   ├── history
│       │   │   │   ├── __init__.py
│       │   │   │   ├── _budget.py
│       │   │   │   ├── _decorators.py
│       │   │   │   ├── _history.py
│       │   │   │   ├── _prioritize.py
│       │   │   │   ├── _types.py
│       │   │   │   └── tool_abbreviations
│       │   │   │       ├── __init__.py
│       │   │   │       └── _tool_abbreviations.py
│       │   │   └── virtual_filesystem
│       │   │       ├── __init__.py
│       │   │       ├── _types.py
│       │   │       ├── _virtual_filesystem.py
│       │   │       ├── README.md
│       │   │       └── tools
│       │   │           ├── __init__.py
│       │   │           ├── _ls_tool.py
│       │   │           ├── _tools.py
│       │   │           └── _view_tool.py
│       │   ├── CLAUDE.md
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── test
│       │   │   ├── archive
│       │   │   │   └── test_archive_reader.py
│       │   │   ├── history
│       │   │   │   ├── test_abbreviate_messages.py
│       │   │   │   ├── test_history.py
│       │   │   │   ├── test_pair_and_order_tool_messages.py
│       │   │   │   ├── test_prioritize.py
│       │   │   │   └── test_truncate_messages.py
│       │   │   └── virtual_filesystem
│       │   │       ├── test_virtual_filesystem.py
│       │   │       └── tools
│       │   │           ├── test_ls_tool.py
│       │   │           ├── test_tools.py
│       │   │           └── test_view_tool.py
│       │   └── uv.lock
│       ├── content-safety
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── content_safety
│       │   │   ├── __init__.py
│       │   │   ├── evaluators
│       │   │   │   ├── __init__.py
│       │   │   │   ├── azure_content_safety
│       │   │   │   │   ├── __init__.py
│       │   │   │   │   ├── config.py
│       │   │   │   │   └── evaluator.py
│       │   │   │   ├── config.py
│       │   │   │   ├── evaluator.py
│       │   │   │   └── openai_moderations
│       │   │   │       ├── __init__.py
│       │   │   │       ├── config.py
│       │   │   │       └── evaluator.py
│       │   │   └── README.md
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── events
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── events
│       │   │   ├── __init__.py
│       │   │   └── events.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── guided-conversation
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── guided_conversation
│       │   │   ├── __init__.py
│       │   │   ├── functions
│       │   │   │   ├── __init__.py
│       │   │   │   ├── conversation_plan.py
│       │   │   │   ├── execution.py
│       │   │   │   └── final_update_plan.py
│       │   │   ├── guided_conversation_agent.py
│       │   │   ├── plugins
│       │   │   │   ├── __init__.py
│       │   │   │   ├── agenda.py
│       │   │   │   └── artifact.py
│       │   │   └── utils
│       │   │       ├── __init__.py
│       │   │       ├── base_model_llm.py
│       │   │       ├── conversation_helpers.py
│       │   │       ├── openai_tool_calling.py
│       │   │       ├── plugin_helpers.py
│       │   │       └── resources.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── llm-client
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── llm_client
│       │   │   ├── __init__.py
│       │   │   └── model.py
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── Makefile
│       ├── mcp-extensions
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── Makefile
│       │   ├── mcp_extensions
│       │   │   ├── __init__.py
│       │   │   ├── _client_session.py
│       │   │   ├── _model.py
│       │   │   ├── _sampling.py
│       │   │   ├── _server_extensions.py
│       │   │   ├── _tool_utils.py
│       │   │   ├── llm
│       │   │   │   ├── __init__.py
│       │   │   │   ├── chat_completion.py
│       │   │   │   ├── helpers.py
│       │   │   │   ├── llm_types.py
│       │   │   │   ├── mcp_chat_completion.py
│       │   │   │   └── openai_chat_completion.py
│       │   │   └── server
│       │   │       ├── __init__.py
│       │   │       └── storage.py
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── tests
│       │   │   └── test_tool_utils.py
│       │   └── uv.lock
│       ├── mcp-tunnel
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── Makefile
│       │   ├── mcp_tunnel
│       │   │   ├── __init__.py
│       │   │   ├── _devtunnel.py
│       │   │   ├── _dir.py
│       │   │   └── _main.py
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   └── uv.lock
│       ├── openai-client
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── Makefile
│       │   ├── openai_client
│       │   │   ├── __init__.py
│       │   │   ├── chat_driver
│       │   │   │   ├── __init__.py
│       │   │   │   ├── chat_driver.ipynb
│       │   │   │   ├── chat_driver.py
│       │   │   │   ├── message_history_providers
│       │   │   │   │   ├── __init__.py
│       │   │   │   │   ├── in_memory_message_history_provider.py
│       │   │   │   │   ├── local_message_history_provider.py
│       │   │   │   │   ├── message_history_provider.py
│       │   │   │   │   └── tests
│       │   │   │   │       └── formatted_instructions_test.py
│       │   │   │   └── README.md
│       │   │   ├── client.py
│       │   │   ├── completion.py
│       │   │   ├── config.py
│       │   │   ├── errors.py
│       │   │   ├── logging.py
│       │   │   ├── messages.py
│       │   │   ├── tokens.py
│       │   │   └── tools.py
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── tests
│       │   │   ├── test_command_parsing.py
│       │   │   ├── test_formatted_messages.py
│       │   │   ├── test_messages.py
│       │   │   └── test_tokens.py
│       │   └── uv.lock
│       ├── semantic-workbench-api-model
│       │   ├── .vscode
│       │   │   └── settings.json
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── semantic_workbench_api_model
│       │   │   ├── __init__.py
│       │   │   ├── assistant_model.py
│       │   │   ├── assistant_service_client.py
│       │   │   ├── workbench_model.py
│       │   │   └── workbench_service_client.py
│       │   └── uv.lock
│       ├── semantic-workbench-assistant
│       │   ├── .vscode
│       │   │   ├── launch.json
│       │   │   └── settings.json
│       │   ├── Makefile
│       │   ├── pyproject.toml
│       │   ├── README.md
│       │   ├── semantic_workbench_assistant
│       │   │   ├── __init__.py
│       │   │   ├── assistant_app
│       │   │   │   ├── __init__.py
│       │   │   │   ├── assistant.py
│       │   │   │   ├── config.py
│       │   │   │   ├── content_safety.py
│       │   │   │   ├── context.py
│       │   │   │   ├── error.py
│       │   │   │   ├── export_import.py
│       │   │   │   ├── protocol.py
│       │   │   │   └── service.py
│       │   │   ├── assistant_service.py
│       │   │   ├── auth.py
│       │   │   ├── canonical.py
│       │   │   ├── command.py
│       │   │   ├── config.py
│       │   │   ├── logging_config.py
│       │   │   ├── settings.py
│       │   │   ├── start.py
│       │   │   └── storage.py
│       │   ├── tests
│       │   │   ├── conftest.py
│       │   │   ├── test_assistant_app.py
│       │   │   ├── test_canonical.py
│       │   │   ├── test_config.py
│       │   │   └── test_storage.py
│       │   └── uv.lock
│       └── skills
│           ├── .vscode
│           │   └── settings.json
│           ├── Makefile
│           ├── README.md
│           └── skill-library
│               ├── .vscode
│               │   └── settings.json
│               ├── docs
│               │   └── vs-recipe-tool.md
│               ├── Makefile
│               ├── pyproject.toml
│               ├── README.md
│               ├── skill_library
│               │   ├── __init__.py
│               │   ├── chat_driver_helpers.py
│               │   ├── cli
│               │   │   ├── azure_openai.py
│               │   │   ├── conversation_history.py
│               │   │   ├── README.md
│               │   │   ├── run_routine.py
│               │   │   ├── settings.py
│               │   │   └── skill_logger.py
│               │   ├── engine.py
│               │   ├── llm_info.txt
│               │   ├── logging.py
│               │   ├── README.md
│               │   ├── routine_stack.py
│               │   ├── skill.py
│               │   ├── skills
│               │   │   ├── common
│               │   │   │   ├── __init__.py
│               │   │   │   ├── common_skill.py
│               │   │   │   └── routines
│               │   │   │       ├── bing_search.py
│               │   │   │       ├── consolidate.py
│               │   │   │       ├── echo.py
│               │   │   │       ├── gather_context.py
│               │   │   │       ├── get_content_from_url.py
│               │   │   │       ├── gpt_complete.py
│               │   │   │       ├── select_user_intent.py
│               │   │   │       └── summarize.py
│               │   │   ├── eval
│               │   │   │   ├── __init__.py
│               │   │   │   ├── eval_skill.py
│               │   │   │   └── routines
│               │   │   │       └── eval.py
│               │   │   ├── fabric
│               │   │   │   ├── __init__.py
│               │   │   │   ├── fabric_skill.py
│               │   │   │   ├── patterns
│               │   │   │   │   ├── agility_story
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── ai
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_answers
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_candidates
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_cfp_submission
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_claims
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_comments
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_debate
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_email_headers
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_incident
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_interviewer_techniques
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_logs
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_malware
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_military_strategy
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_mistakes
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_paper
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_patent
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_personality
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_presentation
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_product_feedback
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_proposition
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_prose
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_prose_json
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_prose_pinker
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_risk
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_sales_call
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_spiritual_text
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_tech_impact
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_threat_report
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── analyze_threat_report_cmds
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── analyze_threat_report_trends
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── answer_interview_question
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── ask_secure_by_design_questions
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── ask_uncle_duke
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── capture_thinkers_work
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── check_agreement
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── clean_text
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── coding_master
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── compare_and_contrast
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── convert_to_markdown
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_5_sentence_summary
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_academic_paper
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_ai_jobs_analysis
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_aphorisms
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_art_prompt
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_better_frame
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_coding_project
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_command
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_cyber_summary
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_design_document
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_diy
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_formal_email
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_git_diff_commit
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_graph_from_input
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_hormozi_offer
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_idea_compass
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_investigation_visualization
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_keynote
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_logo
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_markmap_visualization
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_mermaid_visualization
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_mermaid_visualization_for_github
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_micro_summary
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_network_threat_landscape
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_newsletter_entry
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_npc
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_pattern
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_prd
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_prediction_block
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_quiz
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_reading_plan
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_recursive_outline
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_report_finding
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_rpg_summary
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_security_update
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_show_intro
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_sigma_rules
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_story_explanation
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_stride_threat_model
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_summary
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_tags
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_threat_scenarios
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_ttrc_graph
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_ttrc_narrative
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_upgrade_pack
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_user_story
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── create_video_chapters
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── create_visualization
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── dialog_with_socrates
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── enrich_blog_post
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── explain_code
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── explain_docs
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── explain_math
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── explain_project
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── explain_terms
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── export_data_as_csv
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_algorithm_update_recommendations
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_article_wisdom
│               │   │   │   │   │   ├── dmiessler
│               │   │   │   │   │   │   └── extract_wisdom-1.0.0
│               │   │   │   │   │   │       ├── system.md
│               │   │   │   │   │   │       └── user.md
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_book_ideas
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_book_recommendations
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_business_ideas
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_controversial_ideas
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_core_message
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_ctf_writeup
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_domains
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_extraordinary_claims
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_ideas
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_insights
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_insights_dm
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_instructions
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_jokes
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_latest_video
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_main_idea
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_most_redeeming_thing
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_patterns
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_poc
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_predictions
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_primary_problem
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_primary_solution
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_product_features
│               │   │   │   │   │   ├── dmiessler
│               │   │   │   │   │   │   └── extract_wisdom-1.0.0
│               │   │   │   │   │   │       ├── system.md
│               │   │   │   │   │   │       └── user.md
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_questions
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_recipe
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_recommendations
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_references
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_skills
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_song_meaning
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_sponsors
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_videoid
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── extract_wisdom
│               │   │   │   │   │   ├── dmiessler
│               │   │   │   │   │   │   └── extract_wisdom-1.0.0
│               │   │   │   │   │   │       ├── system.md
│               │   │   │   │   │   │       └── user.md
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_wisdom_agents
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_wisdom_dm
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── extract_wisdom_nometa
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── find_hidden_message
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── find_logical_fallacies
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── get_wow_per_minute
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── get_youtube_rss
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── humanize
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── identify_dsrp_distinctions
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── identify_dsrp_perspectives
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── identify_dsrp_relationships
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── identify_dsrp_systems
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── identify_job_stories
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── improve_academic_writing
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── improve_prompt
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── improve_report_finding
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── improve_writing
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── judge_output
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── label_and_rate
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── loaded
│               │   │   │   │   ├── md_callout
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── official_pattern_template
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── pattern_explanations.md
│               │   │   │   │   ├── prepare_7s_strategy
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── provide_guidance
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── rate_ai_response
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── rate_ai_result
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── rate_content
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── rate_value
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── raw_query
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── raycast
│               │   │   │   │   │   ├── capture_thinkers_work
│               │   │   │   │   │   ├── create_story_explanation
│               │   │   │   │   │   ├── extract_primary_problem
│               │   │   │   │   │   ├── extract_wisdom
│               │   │   │   │   │   └── yt
│               │   │   │   │   ├── recommend_artists
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── recommend_pipeline_upgrades
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── recommend_talkpanel_topics
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── refine_design_document
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── review_design
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── sanitize_broken_html_to_markdown
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── show_fabric_options_markmap
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── solve_with_cot
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── stringify
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── suggest_pattern
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize
│               │   │   │   │   │   ├── dmiessler
│               │   │   │   │   │   │   └── summarize
│               │   │   │   │   │   │       ├── system.md
│               │   │   │   │   │   │       └── user.md
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize_debate
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_git_changes
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_git_diff
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_lecture
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_legislation
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_meeting
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_micro
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize_newsletter
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize_paper
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize_prompt
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── summarize_pull-requests
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── summarize_rpg_session
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_analyze_challenge_handling
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_check_metrics
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_create_h3_career
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_create_opening_sentences
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_describe_life_outlook
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_extract_intro_sentences
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_extract_panel_topics
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_find_blindspots
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_find_negative_thinking
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_find_neglected_goals
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_give_encouragement
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_red_team_thinking
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_threat_model_plans
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_visualize_mission_goals_projects
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── t_year_in_review
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── to_flashcards
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── transcribe_minutes
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── translate
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── tweet
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── write_essay
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── write_hackerone_report
│               │   │   │   │   │   ├── README.md
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── write_latex
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── write_micro_essay
│               │   │   │   │   │   └── system.md
│               │   │   │   │   ├── write_nuclei_template_rule
│               │   │   │   │   │   ├── system.md
│               │   │   │   │   │   └── user.md
│               │   │   │   │   ├── write_pull-request
│               │   │   │   │   │   └── system.md
│               │   │   │   │   └── write_semgrep_rule
│               │   │   │   │       ├── system.md
│               │   │   │   │       └── user.md
│               │   │   │   └── routines
│               │   │   │       ├── list.py
│               │   │   │       ├── run.py
│               │   │   │       └── show.py
│               │   │   ├── guided_conversation
│               │   │   │   ├── __init__.py
│               │   │   │   ├── agenda.py
│               │   │   │   ├── artifact_helpers.py
│               │   │   │   ├── chat_completions
│               │   │   │   │   ├── fix_agenda_error.py
│               │   │   │   │   ├── fix_artifact_error.py
│               │   │   │   │   ├── generate_agenda.py
│               │   │   │   │   ├── generate_artifact_updates.py
│               │   │   │   │   ├── generate_final_artifact.py
│               │   │   │   │   └── generate_message.py
│               │   │   │   ├── conversation_guides
│               │   │   │   │   ├── __init__.py
│               │   │   │   │   ├── acrostic_poem.py
│               │   │   │   │   ├── er_triage.py
│               │   │   │   │   ├── interview.py
│               │   │   │   │   └── patient_intake.py
│               │   │   │   ├── guide.py
│               │   │   │   ├── guided_conversation_skill.py
│               │   │   │   ├── logging.py
│               │   │   │   ├── message.py
│               │   │   │   ├── resources.py
│               │   │   │   ├── routines
│               │   │   │   │   └── guided_conversation.py
│               │   │   │   └── tests
│               │   │   │       ├── conftest.py
│               │   │   │       ├── test_artifact_helpers.py
│               │   │   │       ├── test_generate_agenda.py
│               │   │   │       ├── test_generate_artifact_updates.py
│               │   │   │       ├── test_generate_final_artifact.py
│               │   │   │       └── test_resource.py
│               │   │   ├── meta
│               │   │   │   ├── __init__.py
│               │   │   │   ├── meta_skill.py
│               │   │   │   ├── README.md
│               │   │   │   └── routines
│               │   │   │       └── generate_routine.py
│               │   │   ├── posix
│               │   │   │   ├── __init__.py
│               │   │   │   ├── posix_skill.py
│               │   │   │   ├── routines
│               │   │   │   │   ├── append_file.py
│               │   │   │   │   ├── cd.py
│               │   │   │   │   ├── ls.py
│               │   │   │   │   ├── make_home_dir.py
│               │   │   │   │   ├── mkdir.py
│               │   │   │   │   ├── mv.py
│               │   │   │   │   ├── pwd.py
│               │   │   │   │   ├── read_file.py
│               │   │   │   │   ├── rm.py
│               │   │   │   │   ├── touch.py
│               │   │   │   │   └── write_file.py
│               │   │   │   └── sandbox_shell.py
│               │   │   ├── README.md
│               │   │   ├── research
│               │   │   │   ├── __init__.py
│               │   │   │   ├── README.md
│               │   │   │   ├── research_skill.py
│               │   │   │   └── routines
│               │   │   │       ├── answer_question_about_content.py
│               │   │   │       ├── evaluate_answer.py
│               │   │   │       ├── generate_research_plan.py
│               │   │   │       ├── generate_search_query.py
│               │   │   │       ├── update_research_plan.py
│               │   │   │       ├── web_research.py
│               │   │   │       └── web_search.py
│               │   │   ├── research2
│               │   │   │   ├── __init__.py
│               │   │   │   ├── README.md
│               │   │   │   ├── research_skill.py
│               │   │   │   └── routines
│               │   │   │       ├── facts.py
│               │   │   │       ├── make_final_report.py
│               │   │   │       ├── research.py
│               │   │   │       ├── search_plan.py
│               │   │   │       ├── search.py
│               │   │   │       └── visit_pages.py
│               │   │   └── web_research
│               │   │       ├── __init__.py
│               │   │       ├── README.md
│               │   │       ├── research_skill.py
│               │   │       └── routines
│               │   │           ├── facts.py
│               │   │           ├── make_final_report.py
│               │   │           ├── research.py
│               │   │           ├── search_plan.py
│               │   │           ├── search.py
│               │   │           └── visit_pages.py
│               │   ├── tests
│               │   │   ├── test_common_skill.py
│               │   │   ├── test_integration.py
│               │   │   ├── test_routine_stack.py
│               │   │   ├── tst_skill
│               │   │   │   ├── __init__.py
│               │   │   │   └── routines
│               │   │   │       ├── __init__.py
│               │   │   │       └── a_routine.py
│               │   │   └── utilities
│               │   │       ├── test_find_template_vars.py
│               │   │       ├── test_make_arg_set.py
│               │   │       ├── test_paramspec.py
│               │   │       ├── test_parse_command_string.py
│               │   │       └── test_to_string.py
│               │   ├── types.py
│               │   ├── usage.py
│               │   └── utilities.py
│               └── uv.lock
├── LICENSE
├── Makefile
├── mcp-servers
│   ├── ai-assist-content
│   │   ├── .vscode
│   │   │   └── settings.json
│   │   ├── mcp-example-brave-search.md
│   │   ├── mcp-fastmcp-typescript-README.md
│   │   ├── mcp-llms-full.txt
│   │   ├── mcp-metadata-tips.md
│   │   ├── mcp-python-sdk-README.md
│   │   ├── mcp-typescript-sdk-README.md
│   │   ├── pydanticai-documentation.md
│   │   ├── pydanticai-example-question-graph.md
│   │   ├── pydanticai-example-weather.md
│   │   ├── pydanticai-tutorial.md
│   │   └── README.md
│   ├── Makefile
│   ├── mcp-server-bing-search
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_bing_search
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── prompts
│   │   │   │   ├── __init__.py
│   │   │   │   ├── clean_website.py
│   │   │   │   └── filter_links.py
│   │   │   ├── server.py
│   │   │   ├── start.py
│   │   │   ├── tools.py
│   │   │   ├── types.py
│   │   │   ├── utils.py
│   │   │   └── web
│   │   │       ├── __init__.py
│   │   │       ├── get_content.py
│   │   │       ├── llm_processing.py
│   │   │       ├── process_website.py
│   │   │       └── search_bing.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   └── test_tools.py
│   │   └── uv.lock
│   ├── mcp-server-bundle
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_bundle
│   │   │   ├── __init__.py
│   │   │   └── main.py
│   │   ├── pyinstaller.spec
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── mcp-server-filesystem
│   │   ├── .env.example
│   │   ├── .github
│   │   │   └── workflows
│   │   │       └── ci.yml
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_filesystem
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── server.py
│   │   │   └── start.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   └── test_filesystem.py
│   │   └── uv.lock
│   ├── mcp-server-filesystem-edit
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── data
│   │   │   ├── attachments
│   │   │   │   ├── Daily Game Ideas.txt
│   │   │   │   ├── Frontend Framework Proposal.txt
│   │   │   │   ├── ReDoodle.txt
│   │   │   │   └── Research Template.tex
│   │   │   ├── test_cases.yaml
│   │   │   └── transcripts
│   │   │       ├── transcript_research_simple.md
│   │   │       ├── transcript_Startup_Idea_1_202503031513.md
│   │   │       ├── transcript_Startup_Idea_2_202503031659.md
│   │   │       └── transcript_Web_Frontends_202502281551.md
│   │   ├── Makefile
│   │   ├── mcp_server_filesystem_edit
│   │   │   ├── __init__.py
│   │   │   ├── app_handling
│   │   │   │   ├── __init__.py
│   │   │   │   ├── excel.py
│   │   │   │   ├── miktex.py
│   │   │   │   ├── office_common.py
│   │   │   │   ├── powerpoint.py
│   │   │   │   └── word.py
│   │   │   ├── config.py
│   │   │   ├── evals
│   │   │   │   ├── __init__.py
│   │   │   │   ├── common.py
│   │   │   │   ├── run_comments.py
│   │   │   │   ├── run_edit.py
│   │   │   │   └── run_ppt_edit.py
│   │   │   ├── prompts
│   │   │   │   ├── __init__.py
│   │   │   │   ├── add_comments.py
│   │   │   │   ├── analyze_comments.py
│   │   │   │   ├── latex_edit.py
│   │   │   │   ├── markdown_draft.py
│   │   │   │   ├── markdown_edit.py
│   │   │   │   └── powerpoint_edit.py
│   │   │   ├── server.py
│   │   │   ├── start.py
│   │   │   ├── tools
│   │   │   │   ├── __init__.py
│   │   │   │   ├── add_comments.py
│   │   │   │   ├── edit_adapters
│   │   │   │   │   ├── __init__.py
│   │   │   │   │   ├── common.py
│   │   │   │   │   ├── latex.py
│   │   │   │   │   └── markdown.py
│   │   │   │   ├── edit.py
│   │   │   │   └── helpers.py
│   │   │   └── types.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   ├── app_handling
│   │   │   │   ├── test_excel.py
│   │   │   │   ├── test_miktext.py
│   │   │   │   ├── test_office_common.py
│   │   │   │   ├── test_powerpoint.py
│   │   │   │   └── test_word.py
│   │   │   ├── conftest.py
│   │   │   └── tools
│   │   │       └── edit_adapters
│   │   │           ├── test_latex.py
│   │   │           └── test_markdown.py
│   │   └── uv.lock
│   ├── mcp-server-fusion
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── AddInIcon.svg
│   │   ├── config.py
│   │   ├── FusionMCPServerAddIn.manifest
│   │   ├── FusionMCPServerAddIn.py
│   │   ├── mcp_server_fusion
│   │   │   ├── __init__.py
│   │   │   ├── fusion_mcp_server.py
│   │   │   ├── fusion_utils
│   │   │   │   ├── __init__.py
│   │   │   │   ├── event_utils.py
│   │   │   │   ├── general_utils.py
│   │   │   │   └── tool_utils.py
│   │   │   ├── mcp_tools
│   │   │   │   ├── __init__.py
│   │   │   │   ├── fusion_3d_operation.py
│   │   │   │   ├── fusion_geometry.py
│   │   │   │   ├── fusion_pattern.py
│   │   │   │   └── fusion_sketch.py
│   │   │   └── vendor
│   │   │       └── README.md
│   │   ├── README.md
│   │   └── requirements.txt
│   ├── mcp-server-giphy
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── giphy_search.py
│   │   │   ├── sampling.py
│   │   │   ├── server.py
│   │   │   ├── start.py
│   │   │   └── utils.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── mcp-server-memory-user-bio
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_memory_user_bio
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── server.py
│   │   │   └── start.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── mcp-server-memory-whiteboard
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_memory_whiteboard
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── server.py
│   │   │   └── start.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── mcp-server-office
│   │   ├── .env.example
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── build.sh
│   │   ├── data
│   │   │   ├── attachments
│   │   │   │   ├── Daily Game Ideas.txt
│   │   │   │   ├── Frontend Framework Proposal.txt
│   │   │   │   └── ReDoodle.txt
│   │   │   └── word
│   │   │       ├── test_cases.yaml
│   │   │       └── transcripts
│   │   │           ├── transcript_Startup_Idea_1_202503031513.md
│   │   │           ├── transcript_Startup_Idea_2_202503031659.md
│   │   │           └── transcript_Web_Frontends_202502281551.md
│   │   ├── Makefile
│   │   ├── mcp_server
│   │   │   ├── __init__.py
│   │   │   ├── app_interaction
│   │   │   │   ├── __init__.py
│   │   │   │   ├── excel_editor.py
│   │   │   │   ├── powerpoint_editor.py
│   │   │   │   └── word_editor.py
│   │   │   ├── config.py
│   │   │   ├── constants.py
│   │   │   ├── evals
│   │   │   │   ├── __init__.py
│   │   │   │   ├── common.py
│   │   │   │   ├── run_comment_analysis.py
│   │   │   │   ├── run_feedback.py
│   │   │   │   └── run_markdown_edit.py
│   │   │   ├── helpers.py
│   │   │   ├── markdown_edit
│   │   │   │   ├── __init__.py
│   │   │   │   ├── comment_analysis.py
│   │   │   │   ├── feedback_step.py
│   │   │   │   ├── markdown_edit.py
│   │   │   │   └── utils.py
│   │   │   ├── prompts
│   │   │   │   ├── __init__.py
│   │   │   │   ├── comment_analysis.py
│   │   │   │   ├── feedback.py
│   │   │   │   ├── markdown_draft.py
│   │   │   │   └── markdown_edit.py
│   │   │   ├── server.py
│   │   │   ├── start.py
│   │   │   └── types.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── tests
│   │   │   └── test_word_editor.py
│   │   └── uv.lock
│   ├── mcp-server-open-deep-research
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server
│   │   │   ├── __init__.py
│   │   │   ├── config.py
│   │   │   ├── libs
│   │   │   │   └── open_deep_research
│   │   │   │       ├── cookies.py
│   │   │   │       ├── mdconvert.py
│   │   │   │       ├── run_agents.py
│   │   │   │       ├── text_inspector_tool.py
│   │   │   │       ├── text_web_browser.py
│   │   │   │       └── visual_qa.py
│   │   │   ├── open_deep_research.py
│   │   │   ├── server.py
│   │   │   └── start.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   └── uv.lock
│   ├── mcp-server-open-deep-research-clone
│   │   ├── .env.example
│   │   ├── .gitignore
│   │   ├── .vscode
│   │   │   ├── launch.json
│   │   │   └── settings.json
│   │   ├── Makefile
│   │   ├── mcp_server_open_deep_research_clone
│   │   │   ├── __init__.py
│   │   │   ├── azure_openai.py
│   │   │   ├── config.py
│   │   │   ├── logging.py
│   │   │   ├── sampling.py
│   │   │   ├── server.py
│   │   │   ├── start.py
│   │   │   ├── utils.py
│   │   │   └── web_research.py
│   │   ├── pyproject.toml
│   │   ├── README.md
│   │   ├── test
│   │   │   └── test_open_deep_research_clone.py
│   │   └── uv.lock
│   ├── mcp-server-template
│   │   ├── .taplo.toml
│   │   ├── .vscode
│   │   │   └── settings.json
│   │   ├── copier.yml
│   │   ├── README.md
│   │   └── template
│   │       └── {{ project_slug }}
│   │           ├── .env.example.jinja
│   │           ├── .gitignore
│   │           ├── .vscode
│   │           │   ├── launch.json.jinja
│   │           │   └── settings.json
│   │           ├── {{ module_name }}
│   │           │   ├── __init__.py
│   │           │   ├── config.py.jinja
│   │           │   ├── server.py.jinja
│   │           │   └── start.py.jinja
│   │           ├── Makefile.jinja
│   │           ├── pyproject.toml.jinja
│   │           └── README.md.jinja
│   ├── mcp-server-vscode
│   │   ├── .eslintrc.cjs
│   │   ├── .gitignore
│   │   ├── .npmrc
│   │   ├── .vscode
│   │   │   ├── extensions.json
│   │   │   ├── launch.json
│   │   │   ├── settings.json
│   │   │   └── tasks.json
│   │   ├── .vscode-test.mjs
│   │   ├── .vscodeignore
│   │   ├── ASSISTANT_BOOTSTRAP.md
│   │   ├── eslint.config.mjs
│   │   ├── images
│   │   │   └── icon.png
│   │   ├── LICENSE
│   │   ├── Makefile
│   │   ├── out
│   │   │   ├── extension.d.ts
│   │   │   ├── extension.js
│   │   │   ├── test
│   │   │   │   ├── extension.test.d.ts
│   │   │   │   └── extension.test.js
│   │   │   ├── tools
│   │   │   │   ├── code_checker.d.ts
│   │   │   │   ├── code_checker.js
│   │   │   │   ├── debug_tools.d.ts
│   │   │   │   ├── debug_tools.js
│   │   │   │   ├── focus_editor.d.ts
│   │   │   │   ├── focus_editor.js
│   │   │   │   ├── search_symbol.d.ts
│   │   │   │   └── search_symbol.js
│   │   │   └── utils
│   │   │       ├── port.d.ts
│   │   │       └── port.js
│   │   ├── package.json
│   │   ├── pnpm-lock.yaml
│   │   ├── prettier.config.cjs
│   │   ├── README.md
│   │   ├── src
│   │   │   ├── extension.d.ts
│   │   │   ├── extension.ts
│   │   │   ├── test
│   │   │   │   ├── extension.test.d.ts
│   │   │   │   └── extension.test.ts
│   │   │   ├── tools
│   │   │   │   ├── code_checker.d.ts
│   │   │   │   ├── code_checker.ts
│   │   │   │   ├── debug_tools.d.ts
│   │   │   │   ├── debug_tools.ts
│   │   │   │   ├── focus_editor.d.ts
│   │   │   │   ├── focus_editor.ts
│   │   │   │   ├── search_symbol.d.ts
│   │   │   │   └── search_symbol.ts
│   │   │   └── utils
│   │   │       ├── port.d.ts
│   │   │       └── port.ts
│   │   ├── tsconfig.json
│   │   ├── tsconfig.tsbuildinfo
│   │   ├── vsc-extension-quickstart.md
│   │   └── webpack.config.js
│   └── mcp-server-web-research
│       ├── .env.example
│       ├── .gitignore
│       ├── .vscode
│       │   ├── launch.json
│       │   └── settings.json
│       ├── Makefile
│       ├── mcp_server_web_research
│       │   ├── __init__.py
│       │   ├── azure_openai.py
│       │   ├── config.py
│       │   ├── logging.py
│       │   ├── sampling.py
│       │   ├── server.py
│       │   ├── start.py
│       │   ├── utils.py
│       │   └── web_research.py
│       ├── pyproject.toml
│       ├── README.md
│       ├── test
│       │   └── test_web_research.py
│       └── uv.lock
├── README.md
├── RESPONSIBLE_AI_FAQ.md
├── ruff.toml
├── SECURITY.md
├── semantic-workbench.code-workspace
├── SUPPORT.md
├── tools
│   ├── build_ai_context_files.py
│   ├── collect_files.py
│   ├── docker
│   │   ├── azure_website_sshd.conf
│   │   ├── docker-entrypoint.sh
│   │   ├── Dockerfile.assistant
│   │   └── Dockerfile.mcp-server
│   ├── makefiles
│   │   ├── docker-assistant.mk
│   │   ├── docker-mcp-server.mk
│   │   ├── docker.mk
│   │   ├── python.mk
│   │   ├── recursive.mk
│   │   └── shell.mk
│   ├── reset-service-data.ps1
│   ├── reset-service-data.sh
│   ├── run-app.ps1
│   ├── run-app.sh
│   ├── run-canonical-agent.ps1
│   ├── run-canonical-agent.sh
│   ├── run-dotnet-examples-with-aspire.sh
│   ├── run-python-example1.sh
│   ├── run-python-example2.ps1
│   ├── run-python-example2.sh
│   ├── run-service.ps1
│   ├── run-service.sh
│   ├── run-workbench-chatbot.ps1
│   └── run-workbench-chatbot.sh
├── workbench-app
│   ├── .dockerignore
│   ├── .env.example
│   ├── .eslintrc.cjs
│   ├── .gitignore
│   ├── .vscode
│   │   ├── launch.json
│   │   └── settings.json
│   ├── docker-entrypoint.sh
│   ├── Dockerfile
│   ├── docs
│   │   ├── APP_DEV_GUIDE.md
│   │   ├── MESSAGE_METADATA.md
│   │   ├── MESSAGE_TYPES.md
│   │   ├── README.md
│   │   └── STATE_INSPECTORS.md
│   ├── index.html
│   ├── Makefile
│   ├── nginx.conf
│   ├── package.json
│   ├── pnpm-lock.yaml
│   ├── prettier.config.cjs
│   ├── public
│   │   └── assets
│   │       ├── background-1-upscaled.jpg
│   │       ├── background-1-upscaled.png
│   │       ├── background-1.jpg
│   │       ├── background-1.png
│   │       ├── background-2.jpg
│   │       ├── background-2.png
│   │       ├── experimental-feature.jpg
│   │       ├── favicon.svg
│   │       ├── workflow-designer-1.jpg
│   │       ├── workflow-designer-outlets.jpg
│   │       ├── workflow-designer-states.jpg
│   │       └── workflow-designer-transitions.jpg
│   ├── README.md
│   ├── run.sh
│   ├── src
│   │   ├── components
│   │   │   ├── App
│   │   │   │   ├── AppFooter.tsx
│   │   │   │   ├── AppHeader.tsx
│   │   │   │   ├── AppMenu.tsx
│   │   │   │   ├── AppView.tsx
│   │   │   │   ├── CodeLabel.tsx
│   │   │   │   ├── CommandButton.tsx
│   │   │   │   ├── ConfirmLeave.tsx
│   │   │   │   ├── ContentExport.tsx
│   │   │   │   ├── ContentImport.tsx
│   │   │   │   ├── CopyButton.tsx
│   │   │   │   ├── DialogControl.tsx
│   │   │   │   ├── DynamicIframe.tsx
│   │   │   │   ├── ErrorListFromAppState.tsx
│   │   │   │   ├── ErrorMessageBar.tsx
│   │   │   │   ├── ExperimentalNotice.tsx
│   │   │   │   ├── FormWidgets
│   │   │   │   │   ├── BaseModelEditorWidget.tsx
│   │   │   │   │   ├── CustomizedArrayFieldTemplate.tsx
│   │   │   │   │   ├── CustomizedFieldTemplate.tsx
│   │   │   │   │   ├── CustomizedObjectFieldTemplate.tsx
│   │   │   │   │   └── InspectableWidget.tsx
│   │   │   │   ├── LabelWithDescription.tsx
│   │   │   │   ├── Loading.tsx
│   │   │   │   ├── MenuItemControl.tsx
│   │   │   │   ├── MiniControl.tsx
│   │   │   │   ├── MyAssistantServiceRegistrations.tsx
│   │   │   │   ├── MyItemsManager.tsx
│   │   │   │   ├── OverflowMenu.tsx
│   │   │   │   ├── PresenceMotionList.tsx
│   │   │   │   ├── ProfileSettings.tsx
│   │   │   │   └── TooltipWrapper.tsx
│   │   │   ├── Assistants
│   │   │   │   ├── ApplyConfigButton.tsx
│   │   │   │   ├── AssistantAdd.tsx
│   │   │   │   ├── AssistantConfigExportButton.tsx
│   │   │   │   ├── AssistantConfigImportButton.tsx
│   │   │   │   ├── AssistantConfiguration.tsx
│   │   │   │   ├── AssistantConfigure.tsx
│   │   │   │   ├── AssistantCreate.tsx
│   │   │   │   ├── AssistantDelete.tsx
│   │   │   │   ├── AssistantDuplicate.tsx
│   │   │   │   ├── AssistantExport.tsx
│   │   │   │   ├── AssistantImport.tsx
│   │   │   │   ├── AssistantRemove.tsx
│   │   │   │   ├── AssistantRename.tsx
│   │   │   │   ├── AssistantServiceInfo.tsx
│   │   │   │   ├── AssistantServiceMetadata.tsx
│   │   │   │   └── MyAssistants.tsx
│   │   │   ├── AssistantServiceRegistrations
│   │   │   │   ├── AssistantServiceRegistrationApiKey.tsx
│   │   │   │   ├── AssistantServiceRegistrationApiKeyReset.tsx
│   │   │   │   ├── AssistantServiceRegistrationCreate.tsx
│   │   │   │   └── AssistantServiceRegistrationRemove.tsx
│   │   │   ├── Conversations
│   │   │   │   ├── Canvas
│   │   │   │   │   ├── AssistantCanvas.tsx
│   │   │   │   │   ├── AssistantCanvasList.tsx
│   │   │   │   │   ├── AssistantInspector.tsx
│   │   │   │   │   ├── AssistantInspectorList.tsx
│   │   │   │   │   └── ConversationCanvas.tsx
│   │   │   │   ├── ChatInputPlugins
│   │   │   │   │   ├── ClearEditorPlugin.tsx
│   │   │   │   │   ├── LexicalMenu.ts
│   │   │   │   │   ├── ParticipantMentionsPlugin.tsx
│   │   │   │   │   ├── TypeaheadMenuPlugin.css
│   │   │   │   │   └── TypeaheadMenuPlugin.tsx
│   │   │   │   ├── ContentRenderers
│   │   │   │   │   ├── CodeContentRenderer.tsx
│   │   │   │   │   ├── ContentListRenderer.tsx
│   │   │   │   │   ├── ContentRenderer.tsx
│   │   │   │   │   ├── DiffRenderer.tsx
│   │   │   │   │   ├── HtmlContentRenderer.tsx
│   │   │   │   │   ├── JsonSchemaContentRenderer.tsx
│   │   │   │   │   ├── MarkdownContentRenderer.tsx
│   │   │   │   │   ├── MarkdownEditorRenderer.tsx
│   │   │   │   │   ├── MermaidContentRenderer.tsx
│   │   │   │   │   ├── MusicABCContentRenderer.css
│   │   │   │   │   └── MusicABCContentRenderer.tsx
│   │   │   │   ├── ContextWindow.tsx
│   │   │   │   ├── ConversationCreate.tsx
│   │   │   │   ├── ConversationDuplicate.tsx
│   │   │   │   ├── ConversationExport.tsx
│   │   │   │   ├── ConversationFileIcon.tsx
│   │   │   │   ├── ConversationRemove.tsx
│   │   │   │   ├── ConversationRename.tsx
│   │   │   │   ├── ConversationShare.tsx
│   │   │   │   ├── ConversationShareCreate.tsx
│   │   │   │   ├── ConversationShareList.tsx
│   │   │   │   ├── ConversationShareView.tsx
│   │   │   │   ├── ConversationsImport.tsx
│   │   │   │   ├── ConversationTranscript.tsx
│   │   │   │   ├── DebugInspector.tsx
│   │   │   │   ├── FileItem.tsx
│   │   │   │   ├── FileList.tsx
│   │   │   │   ├── InputAttachmentList.tsx
│   │   │   │   ├── InputOptionsControl.tsx
│   │   │   │   ├── InteractHistory.tsx
│   │   │   │   ├── InteractInput.tsx
│   │   │   │   ├── Message
│   │   │   │   │   ├── AttachmentSection.tsx
│   │   │   │   │   ├── ContentRenderer.tsx
│   │   │   │   │   ├── ContentSafetyNotice.tsx
│   │   │   │   │   ├── InteractMessage.tsx
│   │   │   │   │   ├── MessageActions.tsx
│   │   │   │   │   ├── MessageBase.tsx
│   │   │   │   │   ├── MessageBody.tsx
│   │   │   │   │   ├── MessageContent.tsx
│   │   │   │   │   ├── MessageFooter.tsx
│   │   │   │   │   ├── MessageHeader.tsx
│   │   │   │   │   ├── NotificationAccordion.tsx
│   │   │   │   │   └── ToolResultMessage.tsx
│   │   │   │   ├── MessageDelete.tsx
│   │   │   │   ├── MessageLink.tsx
│   │   │   │   ├── MyConversations.tsx
│   │   │   │   ├── MyShares.tsx
│   │   │   │   ├── ParticipantAvatar.tsx
│   │   │   │   ├── ParticipantAvatarGroup.tsx
│   │   │   │   ├── ParticipantItem.tsx
│   │   │   │   ├── ParticipantList.tsx
│   │   │   │   ├── ParticipantStatus.tsx
│   │   │   │   ├── RewindConversation.tsx
│   │   │   │   ├── ShareRemove.tsx
│   │   │   │   ├── SpeechButton.tsx
│   │   │   │   └── ToolCalls.tsx
│   │   │   └── FrontDoor
│   │   │       ├── Chat
│   │   │       │   ├── AssistantDrawer.tsx
│   │   │       │   ├── CanvasDrawer.tsx
│   │   │       │   ├── Chat.tsx
│   │   │       │   ├── ChatCanvas.tsx
│   │   │       │   ├── ChatControls.tsx
│   │   │       │   └── ConversationDrawer.tsx
│   │   │       ├── Controls
│   │   │       │   ├── AssistantCard.tsx
│   │   │       │   ├── AssistantSelector.tsx
│   │   │       │   ├── AssistantServiceSelector.tsx
│   │   │       │   ├── ConversationItem.tsx
│   │   │       │   ├── ConversationList.tsx
│   │   │       │   ├── ConversationListOptions.tsx
│   │   │       │   ├── NewConversationButton.tsx
│   │   │       │   ├── NewConversationForm.tsx
│   │   │       │   └── SiteMenuButton.tsx
│   │   │       ├── GlobalContent.tsx
│   │   │       └── MainContent.tsx
│   │   ├── Constants.ts
│   │   ├── global.d.ts
│   │   ├── index.css
│   │   ├── libs
│   │   │   ├── AppStorage.ts
│   │   │   ├── AuthHelper.ts
│   │   │   ├── EventSubscriptionManager.ts
│   │   │   ├── Theme.ts
│   │   │   ├── useAssistantCapabilities.ts
│   │   │   ├── useChatCanvasController.ts
│   │   │   ├── useConversationEvents.ts
│   │   │   ├── useConversationUtility.ts
│   │   │   ├── useCreateConversation.ts
│   │   │   ├── useDebugComponentLifecycle.ts
│   │   │   ├── useDragAndDrop.ts
│   │   │   ├── useEnvironment.ts
│   │   │   ├── useExportUtility.ts
│   │   │   ├── useHistoryUtility.ts
│   │   │   ├── useKeySequence.ts
│   │   │   ├── useMediaQuery.ts
│   │   │   ├── useMicrosoftGraph.ts
│   │   │   ├── useNotify.tsx
│   │   │   ├── useParticipantUtility.tsx
│   │   │   ├── useSiteUtility.ts
│   │   │   ├── useWorkbenchEventSource.ts
│   │   │   ├── useWorkbenchService.ts
│   │   │   └── Utility.ts
│   │   ├── main.tsx
│   │   ├── models
│   │   │   ├── Assistant.ts
│   │   │   ├── AssistantCapability.ts
│   │   │   ├── AssistantServiceInfo.ts
│   │   │   ├── AssistantServiceRegistration.ts
│   │   │   ├── Config.ts
│   │   │   ├── Conversation.ts
│   │   │   ├── ConversationFile.ts
│   │   │   ├── ConversationMessage.ts
│   │   │   ├── ConversationMessageDebug.ts
│   │   │   ├── ConversationParticipant.ts
│   │   │   ├── ConversationShare.ts
│   │   │   ├── ConversationShareRedemption.ts
│   │   │   ├── ConversationState.ts
│   │   │   ├── ConversationStateDescription.ts
│   │   │   ├── ServiceEnvironment.ts
│   │   │   └── User.ts
│   │   ├── redux
│   │   │   ├── app
│   │   │   │   ├── hooks.ts
│   │   │   │   ├── rtkQueryErrorLogger.ts
│   │   │   │   └── store.ts
│   │   │   └── features
│   │   │       ├── app
│   │   │       │   ├── appSlice.ts
│   │   │       │   └── AppState.ts
│   │   │       ├── chatCanvas
│   │   │       │   ├── chatCanvasSlice.ts
│   │   │       │   └── ChatCanvasState.ts
│   │   │       ├── localUser
│   │   │       │   ├── localUserSlice.ts
│   │   │       │   └── LocalUserState.ts
│   │   │       └── settings
│   │   │           ├── settingsSlice.ts
│   │   │           └── SettingsState.ts
│   │   ├── Root.tsx
│   │   ├── routes
│   │   │   ├── AcceptTerms.tsx
│   │   │   ├── AssistantEditor.tsx
│   │   │   ├── AssistantServiceRegistrationEditor.tsx
│   │   │   ├── Dashboard.tsx
│   │   │   ├── ErrorPage.tsx
│   │   │   ├── FrontDoor.tsx
│   │   │   ├── Login.tsx
│   │   │   ├── Settings.tsx
│   │   │   ├── ShareRedeem.tsx
│   │   │   └── Shares.tsx
│   │   ├── services
│   │   │   └── workbench
│   │   │       ├── assistant.ts
│   │   │       ├── assistantService.ts
│   │   │       ├── conversation.ts
│   │   │       ├── file.ts
│   │   │       ├── index.ts
│   │   │       ├── participant.ts
│   │   │       ├── share.ts
│   │   │       ├── state.ts
│   │   │       └── workbench.ts
│   │   └── vite-env.d.ts
│   ├── tools
│   │   └── filtered-ts-prune.cjs
│   ├── tsconfig.json
│   └── vite.config.ts
└── workbench-service
    ├── .env.example
    ├── .vscode
    │   ├── extensions.json
    │   ├── launch.json
    │   └── settings.json
    ├── alembic.ini
    ├── devdb
    │   ├── docker-compose.yaml
    │   └── postgresql-init.sh
    ├── Dockerfile
    ├── Makefile
    ├── migrations
    │   ├── env.py
    │   ├── README
    │   ├── script.py.mako
    │   └── versions
    │       ├── 2024_09_19_000000_69dcda481c14_init.py
    │       ├── 2024_09_19_190029_dffb1d7e219a_file_version_filename.py
    │       ├── 2024_09_20_204130_b29524775484_share.py
    │       ├── 2024_10_30_231536_039bec8edc33_index_message_type.py
    │       ├── 2024_11_04_204029_5149c7fb5a32_conversationmessagedebug.py
    │       ├── 2024_11_05_015124_245baf258e11_double_check_debugs.py
    │       ├── 2024_11_25_191056_a106de176394_drop_workflow.py
    │       ├── 2025_03_19_140136_aaaf792d4d72_set_user_title_set.py
    │       ├── 2025_03_21_153250_3763629295ad_add_assistant_template_id.py
    │       ├── 2025_05_19_163613_b2f86e981885_delete_context_transfer_assistants.py
    │       └── 2025_06_18_174328_503c739152f3_delete_knowlege_transfer_assistants.py
    ├── pyproject.toml
    ├── README.md
    ├── semantic_workbench_service
    │   ├── __init__.py
    │   ├── api.py
    │   ├── assistant_api_key.py
    │   ├── auth.py
    │   ├── azure_speech.py
    │   ├── config.py
    │   ├── controller
    │   │   ├── __init__.py
    │   │   ├── assistant_service_client_pool.py
    │   │   ├── assistant_service_registration.py
    │   │   ├── assistant.py
    │   │   ├── conversation_share.py
    │   │   ├── conversation.py
    │   │   ├── convert.py
    │   │   ├── exceptions.py
    │   │   ├── export_import.py
    │   │   ├── file.py
    │   │   ├── participant.py
    │   │   └── user.py
    │   ├── db.py
    │   ├── event.py
    │   ├── files.py
    │   ├── logging_config.py
    │   ├── middleware.py
    │   ├── query.py
    │   ├── service_user_principals.py
    │   ├── service.py
    │   └── start.py
    ├── tests
    │   ├── __init__.py
    │   ├── conftest.py
    │   ├── docker-compose.yaml
    │   ├── test_assistant_api_key.py
    │   ├── test_files.py
    │   ├── test_integration.py
    │   ├── test_middleware.py
    │   ├── test_migrations.py
    │   ├── test_workbench_service.py
    │   └── types.py
    └── uv.lock
```

# Files

--------------------------------------------------------------------------------
/workbench-app/src/components/FrontDoor/Controls/ConversationListOptions.tsx:
--------------------------------------------------------------------------------

```typescript
  1 | // Copyright (c) Microsoft. All rights reserved.
  2 | 
  3 | import {
  4 |     Button,
  5 |     Input,
  6 |     Label,
  7 |     makeStyles,
  8 |     Menu,
  9 |     MenuButtonProps,
 10 |     MenuItem,
 11 |     MenuList,
 12 |     MenuPopover,
 13 |     MenuTrigger,
 14 |     Overflow,
 15 |     Select,
 16 |     shorthands,
 17 |     SplitButton,
 18 |     Text,
 19 |     tokens,
 20 |     Toolbar,
 21 | } from '@fluentui/react-components';
 22 | import {
 23 |     CheckboxCheckedFilled,
 24 |     CheckboxIndeterminateRegular,
 25 |     CheckboxUncheckedRegular,
 26 |     DismissRegular,
 27 |     FilterRegular,
 28 |     GlassesOffRegular,
 29 |     GlassesRegular,
 30 |     PinOffRegular,
 31 |     PinRegular,
 32 |     PlugDisconnectedRegular,
 33 | } from '@fluentui/react-icons';
 34 | 
 35 | import React from 'react';
 36 | import { useConversationUtility } from '../../../libs/useConversationUtility';
 37 | import { Utility } from '../../../libs/Utility';
 38 | import { Conversation } from '../../../models/Conversation';
 39 | import { useAppSelector } from '../../../redux/app/hooks';
 40 | import { TooltipWrapper } from '../../App/TooltipWrapper';
 41 | import { ConversationRemoveDialog } from '../../Conversations/ConversationRemove';
 42 | 
 43 | const useClasses = makeStyles({
 44 |     root: {
 45 |         position: 'sticky',
 46 |         top: 0,
 47 |         display: 'flex',
 48 |         flexDirection: 'column',
 49 |         gap: tokens.spacingVerticalS,
 50 |         zIndex: tokens.zIndexPriority,
 51 |         backgroundColor: tokens.colorNeutralBackground2,
 52 |         ...shorthands.padding(tokens.spacingVerticalS, tokens.spacingHorizontalM),
 53 |     },
 54 |     header: {
 55 |         display: 'flex',
 56 |         flexDirection: 'row',
 57 |         justifyContent: 'space-between',
 58 |         alignItems: 'center',
 59 |     },
 60 |     displayOptions: {
 61 |         display: 'flex',
 62 |         flexDirection: 'row',
 63 |         justifyContent: 'space-between',
 64 |         gap: tokens.spacingHorizontalS,
 65 |     },
 66 |     displayOption: {
 67 |         display: 'flex',
 68 |         flexDirection: 'row',
 69 |         gap: tokens.spacingHorizontalXS,
 70 |         alignItems: 'center',
 71 |     },
 72 |     bulkActions: {
 73 |         display: 'flex',
 74 |         flexDirection: 'row',
 75 |         alignItems: 'center',
 76 |     },
 77 |     bulkActionsLabel: {
 78 |         marginLeft: tokens.spacingHorizontalM,
 79 |         color: tokens.colorNeutralForeground2,
 80 |     },
 81 |     toolbarTextButton: {
 82 |         minWidth: 'auto',
 83 |         paddingLeft: tokens.spacingHorizontalXS,
 84 |         paddingRight: tokens.spacingHorizontalXS,
 85 |     },
 86 | });
 87 | 
 88 | interface ConversationListOptionsProps {
 89 |     conversations?: Conversation[];
 90 |     selectedForActions: Set<string>;
 91 |     onSelectedForActionsChanged: (selected: Set<string>) => void;
 92 |     onDisplayedConversationsChanged: (conversations: Conversation[]) => void;
 93 | }
 94 | 
 95 | export const ConversationListOptions: React.FC<ConversationListOptionsProps> = (props) => {
 96 |     const { conversations, selectedForActions, onSelectedForActionsChanged, onDisplayedConversationsChanged } = props;
 97 |     const classes = useClasses();
 98 |     const localUserId = useAppSelector((state) => state.localUser.id);
 99 |     const { hasUnreadMessages, markAllAsRead, markAllAsUnread, isPinned, setPinned } = useConversationUtility();
100 |     const [filterString, setFilterString] = React.useState<string>('');
101 |     const [displayFilter, setDisplayFilter] = React.useState<string>('');
102 |     const [sortByName, setSortByName] = React.useState<boolean>(false);
103 |     const [removeConversations, setRemoveConversations] = React.useState<Conversation[]>();
104 |     const [displayedConversations, setDisplayedConversations] = React.useState<Conversation[]>(conversations || []);
105 | 
106 |     const sortByNameHelper = React.useCallback(
107 |         (a: Conversation, b: Conversation) => a.title.localeCompare(b.title),
108 |         [],
109 |     );
110 | 
111 |     const sortByDateHelper = React.useCallback((a: Conversation, b: Conversation) => {
112 |         const dateA = a.latest_message ? Utility.toDate(a.latest_message.timestamp) : Utility.toDate(a.created);
113 |         const dateB = b.latest_message ? Utility.toDate(b.latest_message.timestamp) : Utility.toDate(b.created);
114 |         return dateB.getTime() - dateA.getTime();
115 |     }, []);
116 | 
117 |     // update displayed conversations when conversations or options change
118 |     React.useEffect(() => {
119 |         // filter conversations based on display filter and filter string
120 |         const filteredConversations =
121 |             conversations?.filter((conversation) => {
122 |                 switch (displayFilter) {
123 |                     case 'Unread':
124 |                         if (!hasUnreadMessages(conversation)) {
125 |                             return false;
126 |                         }
127 |                         break;
128 |                     case 'Pinned':
129 |                         if (!isPinned(conversation)) {
130 |                             return false;
131 |                         }
132 |                         break;
133 |                     case 'Mine':
134 |                         if (conversation.ownerId !== localUserId) {
135 |                             return false;
136 |                         }
137 |                         break;
138 |                     case 'Shared with me':
139 |                         if (conversation.ownerId === localUserId) {
140 |                             return false;
141 |                         }
142 |                         break;
143 |                     default:
144 |                         break;
145 |                 }
146 | 
147 |                 return (
148 |                     !filterString ||
149 |                     (filterString && conversation.title.toLowerCase().includes(filterString.toLowerCase()))
150 |                 );
151 |             }) || [];
152 | 
153 |         // split conversations into pinned and unpinned
154 |         const splitByPinned: Record<string, Conversation[]> = { pinned: [], unpinned: [] };
155 |         filteredConversations.forEach((conversation) => {
156 |             if (isPinned(conversation)) {
157 |                 splitByPinned.pinned.push(conversation);
158 |             } else {
159 |                 splitByPinned.unpinned.push(conversation);
160 |             }
161 |         });
162 | 
163 |         const sortedConversations: Conversation[] = [];
164 |         const sortHelperForSortType = sortByName ? sortByNameHelper : sortByDateHelper;
165 | 
166 |         // sort pinned conversations
167 |         sortedConversations.push(...splitByPinned.pinned.sort(sortHelperForSortType));
168 |         // sort unpinned conversations
169 |         sortedConversations.push(...splitByPinned.unpinned.sort(sortHelperForSortType));
170 | 
171 |         setDisplayedConversations(sortedConversations);
172 |         onDisplayedConversationsChanged(sortedConversations);
173 |     }, [
174 |         conversations,
175 |         displayFilter,
176 |         filterString,
177 |         hasUnreadMessages,
178 |         isPinned,
179 |         onDisplayedConversationsChanged,
180 |         sortByName,
181 |         sortByNameHelper,
182 |         sortByDateHelper,
183 |         localUserId,
184 |     ]);
185 | 
186 |     const bulkSelectForActionsIcon = React.useMemo(() => {
187 |         const icons = {
188 |             all: <CheckboxCheckedFilled color={tokens.colorCompoundBrandBackground} />,
189 |             some: <CheckboxIndeterminateRegular color={tokens.colorCompoundBrandBackground} />,
190 |             none: <CheckboxUncheckedRegular />,
191 |         };
192 | 
193 |         if (selectedForActions.size === 0) {
194 |             return icons.none;
195 |         } else if (selectedForActions.size === displayedConversations.length) {
196 |             return icons.all;
197 |         } else {
198 |             return icons.some;
199 |         }
200 |     }, [displayedConversations, selectedForActions]);
201 | 
202 |     const handleBulkSelectForActions = React.useCallback(
203 |         (selectionType?: 'all' | 'none' | 'read' | 'unread' | 'pinned' | 'unpinned' | 'mine' | 'sharedWithMe') => {
204 |             switch (selectionType) {
205 |                 case 'all':
206 |                     onSelectedForActionsChanged(new Set(displayedConversations.map((conversation) => conversation.id)));
207 |                     break;
208 |                 case 'none':
209 |                     onSelectedForActionsChanged(new Set<string>());
210 |                     break;
211 |                 case 'read':
212 |                     onSelectedForActionsChanged(
213 |                         new Set(
214 |                             displayedConversations
215 |                                 .filter((conversation) => !hasUnreadMessages(conversation))
216 |                                 .map((conversation) => conversation.id),
217 |                         ),
218 |                     );
219 |                     break;
220 |                 case 'unread':
221 |                     onSelectedForActionsChanged(
222 |                         new Set(
223 |                             displayedConversations
224 |                                 .filter((conversation) => hasUnreadMessages(conversation))
225 |                                 .map((conversation) => conversation.id),
226 |                         ),
227 |                     );
228 |                     break;
229 |                 case 'pinned':
230 |                     onSelectedForActionsChanged(
231 |                         new Set(
232 |                             displayedConversations
233 |                                 .filter((conversation) => isPinned(conversation))
234 |                                 .map((conversation) => conversation.id),
235 |                         ),
236 |                     );
237 |                     break;
238 |                 case 'unpinned':
239 |                     onSelectedForActionsChanged(
240 |                         new Set(
241 |                             displayedConversations
242 |                                 .filter((conversation) => !isPinned(conversation))
243 |                                 .map((conversation) => conversation.id),
244 |                         ),
245 |                     );
246 |                     break;
247 |                 case 'mine':
248 |                     onSelectedForActionsChanged(
249 |                         new Set(
250 |                             displayedConversations
251 |                                 .filter((conversation) => conversation.ownerId === localUserId)
252 |                                 .map((conversation) => conversation.id),
253 |                         ),
254 |                     );
255 |                     break;
256 |                 case 'sharedWithMe':
257 |                     onSelectedForActionsChanged(
258 |                         new Set(
259 |                             displayedConversations
260 |                                 .filter((conversation) => conversation.ownerId !== localUserId)
261 |                                 .map((conversation) => conversation.id),
262 |                         ),
263 |                     );
264 |                     break;
265 |                 default:
266 |                     // handle toggle all
267 |                     if (selectedForActions.size > 0) {
268 |                         // deselect all
269 |                         onSelectedForActionsChanged(new Set<string>());
270 |                     } else {
271 |                         // select all
272 |                         onSelectedForActionsChanged(
273 |                             new Set(displayedConversations.map((conversation) => conversation.id)),
274 |                         );
275 |                     }
276 |                     break;
277 |             }
278 |         },
279 |         [
280 |             localUserId,
281 |             onSelectedForActionsChanged,
282 |             displayedConversations,
283 |             selectedForActions.size,
284 |             hasUnreadMessages,
285 |             isPinned,
286 |         ],
287 |     );
288 | 
289 |     const bulkSelectForActionsButton = React.useMemo(
290 |         () => (
291 |             <Menu positioning="below-end">
292 |                 <MenuTrigger disableButtonEnhancement>
293 |                     {(triggerProps: MenuButtonProps) => (
294 |                         <SplitButton
295 |                             appearance="outline"
296 |                             size="small"
297 |                             menuButton={triggerProps}
298 |                             primaryActionButton={{
299 |                                 onClick: () => handleBulkSelectForActions(),
300 |                             }}
301 |                             icon={bulkSelectForActionsIcon}
302 |                         />
303 |                     )}
304 |                 </MenuTrigger>
305 |                 <MenuPopover>
306 |                     <MenuList>
307 |                         <MenuItem
308 |                             onClick={() => handleBulkSelectForActions('all')}
309 |                             disabled={selectedForActions.size === displayedConversations.length}
310 |                         >
311 |                             All
312 |                         </MenuItem>
313 |                         <MenuItem
314 |                             onClick={() => handleBulkSelectForActions('none')}
315 |                             disabled={selectedForActions.size === 0}
316 |                         >
317 |                             None
318 |                         </MenuItem>
319 |                         <MenuItem
320 |                             onClick={() => handleBulkSelectForActions('read')}
321 |                             disabled={!displayedConversations.some((conversation) => !hasUnreadMessages(conversation))}
322 |                         >
323 |                             Read
324 |                         </MenuItem>
325 |                         <MenuItem
326 |                             onClick={() => handleBulkSelectForActions('unread')}
327 |                             disabled={!displayedConversations.some(hasUnreadMessages)}
328 |                         >
329 |                             Unread
330 |                         </MenuItem>
331 |                         <MenuItem
332 |                             onClick={() => handleBulkSelectForActions('pinned')}
333 |                             disabled={!displayedConversations.some(isPinned)}
334 |                         >
335 |                             Pinned
336 |                         </MenuItem>
337 |                         <MenuItem
338 |                             onClick={() => handleBulkSelectForActions('unpinned')}
339 |                             disabled={!displayedConversations.some((conversation) => !isPinned(conversation))}
340 |                         >
341 |                             Unpinned
342 |                         </MenuItem>
343 |                         <MenuItem
344 |                             onClick={() => handleBulkSelectForActions('mine')}
345 |                             disabled={
346 |                                 !displayedConversations.some((conversation) => conversation.ownerId === localUserId)
347 |                             }
348 |                         >
349 |                             Mine
350 |                         </MenuItem>
351 |                         <MenuItem
352 |                             onClick={() => handleBulkSelectForActions('sharedWithMe')}
353 |                             disabled={
354 |                                 !displayedConversations.some((conversation) => conversation.ownerId !== localUserId)
355 |                             }
356 |                         >
357 |                             Shared with me
358 |                         </MenuItem>
359 |                     </MenuList>
360 |                 </MenuPopover>
361 |             </Menu>
362 |         ),
363 |         [
364 |             localUserId,
365 |             bulkSelectForActionsIcon,
366 |             displayedConversations,
367 |             handleBulkSelectForActions,
368 |             hasUnreadMessages,
369 |             isPinned,
370 |             selectedForActions.size,
371 |         ],
372 |     );
373 | 
374 |     const enableBulkActions = React.useMemo(
375 |         () =>
376 |             selectedForActions.size > 0
377 |                 ? {
378 |                       read: conversations?.some(
379 |                           (conversation) => selectedForActions.has(conversation.id) && hasUnreadMessages(conversation),
380 |                       ),
381 |                       unread: conversations?.some(
382 |                           (conversation) => selectedForActions.has(conversation.id) && !hasUnreadMessages(conversation),
383 |                       ),
384 |                       pin: conversations?.some(
385 |                           (conversation) => selectedForActions.has(conversation.id) && !isPinned(conversation),
386 |                       ),
387 |                       unpin: conversations?.some(
388 |                           (conversation) => selectedForActions.has(conversation.id) && isPinned(conversation),
389 |                       ),
390 |                       remove: true,
391 |                   }
392 |                 : {
393 |                       read: false,
394 |                       unread: false,
395 |                       pin: false,
396 |                       unpin: false,
397 |                       remove: false,
398 |                   },
399 |         [conversations, hasUnreadMessages, isPinned, selectedForActions],
400 |     );
401 | 
402 |     const getSelectedConversations = React.useCallback(() => {
403 |         return conversations?.filter((conversation) => selectedForActions.has(conversation.id)) ?? [];
404 |     }, [conversations, selectedForActions]);
405 | 
406 |     const handleMarkAllAsReadForSelected = React.useCallback(async () => {
407 |         await markAllAsRead(getSelectedConversations());
408 |         onSelectedForActionsChanged(new Set<string>());
409 |     }, [getSelectedConversations, markAllAsRead, onSelectedForActionsChanged]);
410 | 
411 |     const handleMarkAsUnreadForSelected = React.useCallback(async () => {
412 |         await markAllAsUnread(getSelectedConversations());
413 |         onSelectedForActionsChanged(new Set<string>());
414 |     }, [getSelectedConversations, markAllAsUnread, onSelectedForActionsChanged]);
415 | 
416 |     const handleRemoveForSelected = React.useCallback(async () => {
417 |         // set removeConversations to show remove dialog
418 |         setRemoveConversations(getSelectedConversations());
419 |         // don't clear selected conversations until after the user confirms the removal
420 |     }, [getSelectedConversations]);
421 | 
422 |     const handlePinForSelected = React.useCallback(async () => {
423 |         await setPinned(getSelectedConversations(), true);
424 |         onSelectedForActionsChanged(new Set<string>());
425 |     }, [getSelectedConversations, setPinned, onSelectedForActionsChanged]);
426 | 
427 |     const handleUnpinForSelected = React.useCallback(async () => {
428 |         await setPinned(getSelectedConversations(), false);
429 |         onSelectedForActionsChanged(new Set<string>());
430 |     }, [getSelectedConversations, setPinned, onSelectedForActionsChanged]);
431 | 
432 |     const handleRemoveConversations = React.useCallback(() => {
433 |         // reset removeConversations and clear selected conversations
434 |         setRemoveConversations(undefined);
435 |         onSelectedForActionsChanged(new Set<string>());
436 |     }, [onSelectedForActionsChanged]);
437 | 
438 |     const bulkSelectForActionsToolbar = React.useMemo(
439 |         () => (
440 |             <Overflow padding={90}>
441 |                 <Toolbar size="small">
442 |                     <TooltipWrapper
443 |                         content={
444 |                             !enableBulkActions.read
445 |                                 ? 'Select conversation(s) to enable'
446 |                                 : 'Mark selected conversations as read'
447 |                         }
448 |                     >
449 |                         <Button
450 |                             className={classes.toolbarTextButton}
451 |                             appearance="transparent"
452 |                             icon={<GlassesRegular />}
453 |                             disabled={!enableBulkActions.read}
454 |                             onClick={handleMarkAllAsReadForSelected}
455 |                         />
456 |                     </TooltipWrapper>
457 |                     <TooltipWrapper
458 |                         content={
459 |                             !enableBulkActions.unread
460 |                                 ? 'Select conversation(s) to enable'
461 |                                 : 'Mark selected conversations as unread'
462 |                         }
463 |                     >
464 |                         <Button
465 |                             appearance="transparent"
466 |                             icon={<GlassesOffRegular />}
467 |                             disabled={!enableBulkActions.unread}
468 |                             onClick={handleMarkAsUnreadForSelected}
469 |                         />
470 |                     </TooltipWrapper>
471 |                     <TooltipWrapper
472 |                         content={
473 |                             !enableBulkActions.remove
474 |                                 ? 'Select conversation(s) to enable'
475 |                                 : 'Remove selected conversations'
476 |                         }
477 |                     >
478 |                         <Button
479 |                             // hide this until implemented
480 |                             style={{ display: 'none' }}
481 |                             appearance="subtle"
482 |                             icon={<PlugDisconnectedRegular />}
483 |                             disabled={!enableBulkActions.remove}
484 |                             onClick={handleRemoveForSelected}
485 |                         />
486 |                     </TooltipWrapper>
487 |                     <TooltipWrapper
488 |                         content={
489 |                             !enableBulkActions.pin ? 'Select conversation(s) to enable' : 'Pin selected conversations'
490 |                         }
491 |                     >
492 |                         <Button
493 |                             appearance="subtle"
494 |                             icon={<PinRegular />}
495 |                             disabled={!enableBulkActions.pin}
496 |                             onClick={handlePinForSelected}
497 |                         />
498 |                     </TooltipWrapper>
499 |                     <TooltipWrapper
500 |                         content={
501 |                             !enableBulkActions.unpin
502 |                                 ? 'Select conversation(s) to enable'
503 |                                 : 'Unpin selected conversations'
504 |                         }
505 |                     >
506 |                         <Button
507 |                             appearance="subtle"
508 |                             icon={<PinOffRegular />}
509 |                             disabled={!enableBulkActions.unpin}
510 |                             onClick={handleUnpinForSelected}
511 |                         />
512 |                     </TooltipWrapper>
513 |                     <TooltipWrapper
514 |                         content={
515 |                             !enableBulkActions.remove
516 |                                 ? 'Select conversation(s) to enable'
517 |                                 : 'Remove selected conversations'
518 |                         }
519 |                     >
520 |                         <Button
521 |                             appearance="subtle"
522 |                             icon={<PlugDisconnectedRegular />}
523 |                             disabled={!enableBulkActions.remove}
524 |                             onClick={handleRemoveForSelected}
525 |                         />
526 |                     </TooltipWrapper>
527 |                 </Toolbar>
528 |             </Overflow>
529 |         ),
530 |         [
531 |             classes.toolbarTextButton,
532 |             enableBulkActions.pin,
533 |             enableBulkActions.read,
534 |             enableBulkActions.remove,
535 |             enableBulkActions.unpin,
536 |             enableBulkActions.unread,
537 |             handleMarkAllAsReadForSelected,
538 |             handleMarkAsUnreadForSelected,
539 |             handlePinForSelected,
540 |             handleRemoveForSelected,
541 |             handleUnpinForSelected,
542 |         ],
543 |     );
544 | 
545 |     return (
546 |         <div className={classes.root}>
547 |             {removeConversations && localUserId && (
548 |                 <ConversationRemoveDialog
549 |                     conversations={removeConversations}
550 |                     participantId={localUserId}
551 |                     onRemove={handleRemoveConversations}
552 |                     onCancel={() => setRemoveConversations(undefined)}
553 |                 />
554 |             )}
555 |             <div className={classes.header}>
556 |                 <Text weight="semibold">Conversations</Text>
557 |             </div>
558 |             <Input
559 |                 contentBefore={<FilterRegular />}
560 |                 contentAfter={
561 |                     filterString && (
562 |                         <Button
563 |                             icon={<DismissRegular />}
564 |                             appearance="transparent"
565 |                             onClick={() => setFilterString('')}
566 |                         />
567 |                     )
568 |                 }
569 |                 placeholder="Filter"
570 |                 value={filterString}
571 |                 onChange={(_event, data) => setFilterString(data.value)}
572 |             />
573 |             <div className={classes.displayOptions}>
574 |                 <Select
575 |                     size="small"
576 |                     defaultValue={sortByName ? 'Sort by name' : 'Sort by date'}
577 |                     onChange={(_event, data) => setSortByName(data.value === 'Sort by name')}
578 |                 >
579 |                     <option>Sort by name</option>
580 |                     <option>Sort by date</option>
581 |                 </Select>
582 |                 <div className={classes.displayOption}>
583 |                     <Label size="small">Show</Label>
584 |                     <Select size="small" defaultValue="All" onChange={(_event, data) => setDisplayFilter(data.value)}>
585 |                         <option>All</option>
586 |                         <option disabled={conversations?.every((conversation) => !hasUnreadMessages(conversation))}>
587 |                             Unread
588 |                         </option>
589 |                         <option disabled={conversations?.every((conversation) => !isPinned(conversation))}>
590 |                             Pinned
591 |                         </option>
592 |                         <option disabled={conversations?.every((conversation) => conversation.ownerId !== localUserId)}>
593 |                             Mine
594 |                         </option>
595 |                         <option disabled={conversations?.every((conversation) => conversation.ownerId === localUserId)}>
596 |                             Shared with me
597 |                         </option>
598 |                     </Select>
599 |                 </div>
600 |             </div>
601 |             <div className={classes.bulkActions}>
602 |                 {bulkSelectForActionsButton}
603 |                 <Label className={classes.bulkActionsLabel} size="small">
604 |                     Actions
605 |                 </Label>
606 |                 {bulkSelectForActionsToolbar}
607 |             </div>
608 |         </div>
609 |     );
610 | };
611 | 
```

--------------------------------------------------------------------------------
/assistants/knowledge-transfer-assistant/assistant/data.py:
--------------------------------------------------------------------------------

```python
  1 | """
  2 | Data models for knowledge transfer share entities (briefs, information requests, logs, etc.)
  3 | 
  4 | This module provides the core data structures for the knowledge transfer assistant,
  5 | without any artifact abstraction or unnecessary complexity.
  6 | """
  7 | 
  8 | import uuid
  9 | from datetime import datetime
 10 | from enum import Enum
 11 | from typing import Any, Dict, List, Optional
 12 | 
 13 | from pydantic import BaseModel, Field
 14 | 
 15 | 
 16 | class InspectorTab(str, Enum):
 17 |     """
 18 |     Available inspector panel tabs for the knowledge transfer assistant.
 19 | 
 20 |     These correspond to the state_id values used in the inspector state providers
 21 |     and for sending state events to update specific inspector panels.
 22 |     """
 23 | 
 24 |     BRIEF = "brief"  # Knowledge brief and knowledge transfer overview
 25 |     LEARNING = "learning"  # Learning objectives and outcomes
 26 |     SHARING = "sharing"  # Information requests and sharing status
 27 |     DEBUG = "debug"  # Debug information and knowledge transfer state
 28 | 
 29 | 
 30 | class RequestPriority(str, Enum):
 31 |     """
 32 |     Priority levels for information requests.
 33 | 
 34 |     Defines the urgency of a request from a team member to the Coordinator.
 35 |     Higher priority requests should be addressed more quickly by the Coordinator.
 36 |     MEDIUM is the default priority for most requests.
 37 |     """
 38 | 
 39 |     LOW = "low"  # Non-urgent request, can be addressed when convenient
 40 |     MEDIUM = "medium"  # Standard priority for most requests
 41 |     HIGH = "high"  # Urgent request requiring prompt attention
 42 |     CRITICAL = "critical"  # Highest priority, requires immediate attention from the Coordinator
 43 | 
 44 | 
 45 | class RequestStatus(str, Enum):
 46 |     """
 47 |     Status options for information requests.
 48 | 
 49 |     Represents the lifecycle of an information request from creation to resolution.
 50 |     Requests typically progress from NEW -> ACKNOWLEDGED -> IN_PROGRESS -> RESOLVED.
 51 |     DEFERRED indicates requests that will be addressed later.
 52 |     """
 53 | 
 54 |     NEW = "new"  # Request has been created but not yet acknowledged by the Coordinator
 55 |     ACKNOWLEDGED = "acknowledged"  # Coordinator has seen the request but hasn't started working on it
 56 |     IN_PROGRESS = "in_progress"  # Coordinator is actively working on the request
 57 |     RESOLVED = "resolved"  # Coordinator has provided a resolution to the request
 58 |     DEFERRED = "deferred"  # Request handling has been postponed to a later time
 59 | 
 60 | 
 61 | class BaseEntity(BaseModel):
 62 |     """
 63 |     Base class for all knowledge transfer entities.
 64 | 
 65 |     Provides common fields and behavior that all knowledge transfer-related data models inherit.
 66 |     This ensures consistency in how entities are created, versioned, and tracked.
 67 |     All derived classes will have proper timestamps and creator information.
 68 |     """
 69 | 
 70 |     version: int = 1
 71 |     created_at: datetime = Field(default_factory=datetime.utcnow)
 72 |     updated_at: datetime = Field(default_factory=datetime.utcnow)
 73 |     created_by: str  # User ID
 74 |     updated_by: str  # User ID
 75 |     conversation_id: str  # Source conversation ID
 76 | 
 77 | 
 78 | class LearningOutcomeAchievement(BaseModel):
 79 |     """
 80 |     Achievement record for a specific learning outcome by a team conversation.
 81 | 
 82 |     Each team conversation tracks its own achievements independently,
 83 |     allowing multiple team members to have separate progress tracking.
 84 |     """
 85 | 
 86 |     outcome_id: str  # ID of the learning outcome that was achieved
 87 |     achieved: bool = True  # Whether this outcome has been achieved
 88 |     achieved_at: datetime = Field(default_factory=datetime.utcnow)  # When the outcome was achieved
 89 | 
 90 | 
 91 | class TeamConversationInfo(BaseModel):
 92 |     """
 93 |     Information about a team conversation participating in knowledge transfer.
 94 | 
 95 |     Each team conversation represents one redeemer (team member) who has
 96 |     accessed the shared knowledge package. The conversation tracks the
 97 |     redeemer's identity and their individual achievement progress.
 98 |     """
 99 | 
100 |     conversation_id: str  # The conversation ID for this team member
101 |     redeemer_user_id: str  # User ID of the first non-assistant participant (the redeemer)
102 |     redeemer_name: str  # Display name of the redeemer
103 |     joined_at: datetime = Field(default_factory=datetime.utcnow)  # When this conversation joined the knowledge transfer
104 |     last_active_at: datetime = Field(default_factory=datetime.utcnow)  # Last activity timestamp
105 | 
106 |     # Each team conversation tracks its own achievements independently
107 |     outcome_achievements: List[LearningOutcomeAchievement] = Field(default_factory=list)
108 | 
109 | 
110 | class LearningOutcome(BaseModel):
111 |     """
112 |     A specific measurable learning outcome that defines knowledge transfer success.
113 | 
114 |     Learning outcomes are individual checkpoints that must be achieved
115 |     to accomplish a learning objective. Each outcome represents a concrete,
116 |     verifiable understanding or skill that can be marked as achieved.
117 | 
118 |     Achievement tracking is now handled per team conversation in the
119 |     TeamConversationInfo.outcome_achievements list, allowing multiple
120 |     team members to have independent progress tracking.
121 |     """
122 | 
123 |     id: str = Field(default_factory=lambda: str(uuid.uuid4()))  # Unique identifier for the outcome
124 |     description: str  # Clear, specific description of what needs to be understood or accomplished
125 | 
126 | 
127 | class LearningObjective(BaseModel):
128 |     """
129 |     A specific learning objective with associated learning outcomes.
130 | 
131 |     Learning objectives represent the major knowledge areas that need to be understood
132 |     for the knowledge transfer to be successful. Each objective consists of a name, description,
133 |     priority level, and a list of specific learning outcomes that define when
134 |     the objective can be considered achieved.
135 | 
136 |     Objectives are typically set by the Coordinator during knowledge organization and then tracked
137 |     by both the Coordinator and team members throughout the knowledge transfer.
138 |     """
139 | 
140 |     id: str = Field(default_factory=lambda: str(uuid.uuid4()))  # Unique identifier for the objective
141 |     name: str  # Short, clear name of the learning objective
142 |     description: str  # Detailed description of what should be learned
143 |     priority: int = 1  # Priority level (1 = highest priority, increasing numbers = lower priority)
144 |     learning_outcomes: List[LearningOutcome] = Field(default_factory=list)  # List of outcomes to achieve
145 | 
146 | 
147 | class KnowledgeBrief(BaseEntity):
148 |     """
149 |     A thorough, comprehensive documentation of the knowledge to be transferred,
150 |     containing all relevant information necessary for understanding and
151 |     learning.
152 | 
153 |     The brief is the primary document that defines the knowledge package. It
154 |     serves as the central reference for both the Coordinator and team members to
155 |     understand what needs to be learned and why, capturing the comprehensive
156 |     context of the knowledge being transferred.
157 | 
158 |     The brief focuses on capturing comprehensive knowledge that help learners
159 |     understand the scope, purpose, and content of the knowledge transfer.
160 | 
161 |     Created by the Coordinator during the ORGANIZING phase, the brief must be
162 |     completed before the knowledge can move to the READY_FOR_TRANSFER state.
163 |     Once team members begin learning, the brief can still be updated, but major
164 |     changes should be communicated to all participants.
165 |     """
166 | 
167 |     title: str  # Short, distinctive title for the knowledge package to transfer
168 |     content: str  # The brief content, including the knowledge's purpose, scope, and content
169 |     timeline: Optional[str] = None  # Expected timeline for learning (optional)
170 | 
171 | 
172 | class KnowledgeDigest(BaseEntity):
173 |     """
174 |     A dynamic knowledge digest that gets automatically updated as the coordinator organizes knowledge.
175 | 
176 |     The knowledge digest captures and maintains important knowledge context that emerges during
177 |     conversations. It is automatically updated after each assistant message by analyzing
178 |     the conversation history and extracting key information in FAQ format.
179 | 
180 |     Unlike a traditional knowledge base with separate sections, the digest is a single
181 |     consolidated view that shows the most relevant information for the knowledge transfer. It serves as
182 |     a dynamic, evolving source of truth that all team members can reference.
183 |     """
184 | 
185 |     content: str = ""  # Markdown content for the knowledge digest (FAQ format)
186 |     is_auto_generated: bool = True  # Whether the content was auto-generated or manually edited
187 | 
188 | 
189 | class InformationRequest(BaseEntity):
190 |     """
191 |     A specific information need or blocker submitted by team members
192 |     that requires Coordinator support to resolve.
193 | 
194 |     Information requests are the primary communication mechanism for team members
195 |     to request assistance, information, or resources from the Coordinator. They represent
196 |     questions, blockers, or needs that arise during knowledge transfer.
197 | 
198 |     The lifecycle of an information request typically follows:
199 |     1. Created by a team member (NEW status)
200 |     2. Seen by the Coordinator (ACKNOWLEDGED status)
201 |     3. Worked on by the Coordinator (IN_PROGRESS status)
202 |     4. Completed with a resolution (RESOLVED status)
203 | 
204 |     Requests can also be DEFERRED for later handling or CANCELLED if no longer relevant.
205 |     The request priority helps the Coordinator prioritize which requests to handle first.
206 |     """
207 | 
208 |     # Request identification
209 |     request_id: str = Field(default_factory=lambda: str(uuid.uuid4()))  # Unique ID for this request
210 | 
211 |     # Request details
212 |     title: str  # Short summary of the request
213 |     description: str  # Detailed explanation of what is needed
214 |     priority: RequestPriority = RequestPriority.MEDIUM  # Urgency level of the request
215 |     status: RequestStatus = RequestStatus.NEW  # Current status in the request lifecycle
216 | 
217 |     # Reference to the related learning objective(s) if applicable
218 |     related_objective_ids: List[str] = Field(default_factory=list)  # IDs of learning objectives this request relates to
219 | 
220 |     # Resolution information
221 |     resolution: Optional[str] = None  # The answer or solution provided by the Coordinator
222 |     resolved_at: Optional[datetime] = None  # When the request was resolved
223 |     resolved_by: Optional[str] = None  # User ID of the Coordinator who resolved this request
224 | 
225 |     # Updates and comments on this request
226 |     updates: List[Dict[str, Any]] = Field(default_factory=list)  # History of status updates and comments
227 | 
228 | 
229 | class LogEntryType(str, Enum):
230 |     """
231 |     Types of log entries in the knowledge transfer log.
232 | 
233 |     These entry types categorize all events that can occur during a knowledge transfer.
234 |     Log entries provide a chronological history of actions and events in the knowledge transfer,
235 |     allowing both Coordinators and team members to track progress and changes.
236 |     """
237 | 
238 |     # Brief-related events
239 |     BRIEFING_CREATED = "briefing_created"
240 |     BRIEFING_UPDATED = "briefing_updated"
241 | 
242 |     # Learning Objective-related events
243 |     LEARNING_OBJECTIVE_ADDED = "learning_objective_added"
244 |     LEARNING_OBJECTIVE_DELETED = "learning_objective_deleted"
245 |     LEARNING_OBJECTIVE_UPDATED = "learning_objective_updated"
246 | 
247 |     # Information request lifecycle events
248 |     REQUEST_CREATED = "request_created"
249 |     REQUEST_UPDATED = "request_updated"
250 |     REQUEST_DELETED = "request_deleted"
251 | 
252 |     # Project state and progress events
253 |     STATUS_CHANGED = "status_changed"
254 |     OUTCOME_ATTAINED = "outcome_attained"
255 |     REQUEST_RESOLVED = "request_resolved"
256 |     LEARNING_OBJECTIVE_ACCOMPLISHED = "learning_objective_accomplished"
257 | 
258 |     # Participant events
259 |     PARTICIPANT_JOINED = "participant_joined"
260 |     PARTICIPANT_LEFT = "participant_left"
261 | 
262 |     # Share lifecycle events
263 |     SHARE_STARTED = "share_started"
264 |     SHARE_COMPLETED = "share_completed"
265 |     SHARE_ABORTED = "share_aborted"
266 | 
267 |     # Miscellaneous events
268 |     SHARE_INFORMATION_UPDATE = "share_information_update"
269 |     FILE_SHARED = "file_shared"
270 |     FILE_DELETED = "file_deleted"
271 |     KNOWLEDGE_DIGEST_UPDATE = "knowledge_digest_update"
272 |     CUSTOM = "custom"
273 | 
274 |     # Backward compatibility for old log entries
275 |     KB_UPDATE = "kb_update"  # Legacy alias for KNOWLEDGE_DIGEST_UPDATE
276 |     GOAL_ADDED = "goal_added"  # Legacy alias for LEARNING_OBJECTIVE_ADDED
277 | 
278 | 
279 | class LogEntry(BaseModel):
280 |     """
281 |     Individual entry in the knowledge transfer log.
282 | 
283 |     Log entries record all significant events that occur during a knowledge transfer.
284 |     Each entry has a specific type, message, and associated metadata.
285 | 
286 |     The chronological sequence of log entries forms a complete audit trail
287 |     of the knowledge transfer's progress, actions taken, and events that occurred.
288 |     This provides accountability and helps with post-knowledge transfer review.
289 | 
290 |     Log entries are typically created automatically by the system when
291 |     certain actions are taken, but can also be manually added by participants.
292 |     """
293 | 
294 |     id: str = Field(default_factory=lambda: str(uuid.uuid4()))  # Unique identifier for this log entry
295 |     timestamp: datetime = Field(default_factory=datetime.utcnow)  # When this entry was created
296 |     entry_type: LogEntryType  # The category/type of this log entry
297 |     message: str  # Human-readable description of what happened
298 |     user_id: str  # ID of the user who performed the action or triggered the event
299 |     user_name: str  # Name of the user, for display purposes
300 | 
301 |     # Optional additional context for the entry
302 |     related_entity_id: Optional[str] = None  # ID of related entity (e.g., information request ID)
303 |     entity_type: Optional[str] = None  # Type of related entity (e.g., "information_request", "learning_objective")
304 |     metadata: Optional[Dict] = None  # Additional structured data about the event
305 | 
306 | 
307 | class KnowledgePackageLog(BaseModel):
308 |     """
309 |     A chronological record of all actions and interactions during the knowledge transfer,
310 |     including updates and progress reports.
311 | 
312 |     The knowledge transfer log serves as the comprehensive history of everything that
313 |     happened during a knowledge transfer. It contains a chronological list of log entries
314 |     describing actions, state changes, and significant events.
315 | 
316 |     The log is used for:
317 |     - Real-time monitoring of knowledge transfer activity
318 |     - Post-knowledge transfer review and analysis
319 |     - Accountability and documentation purposes
320 |     - Tracking the sequence of events leading to outcomes
321 | 
322 |     Both the Coordinator and team members can view the knowledge transfer log, providing transparency
323 |     into what has occurred during the knowledge transfer.
324 |     """
325 | 
326 |     entries: List[LogEntry] = Field(default_factory=list)  # Chronological list of log entries
327 | 
328 | 
329 | class KnowledgePackage(BaseModel):
330 |     """
331 |     A comprehensive representation of a knowledge package, including its brief, digest,
332 |     information requests, logs, and other related entities.
333 | 
334 |     This model encapsulates all the components that make up a knowledge transfer package,
335 |     providing a single point of access to all relevant information for Coordinators and Team members.
336 |     It serves as the main interface for interacting with the knowledge transfer data.
337 | 
338 |     All fields from the former KnowledgePackageInfo have been flattened into this model
339 |     for simpler data management.
340 |     """
341 | 
342 |     # Core package identification and state (formerly from KnowledgePackageInfo)
343 |     share_id: str  # Unique identifier for the knowledge package
344 |     coordinator_conversation_id: Optional[str] = None  # ID of the coordinator's conversation
345 |     shared_conversation_id: Optional[str] = None  # ID of the shareable template conversation for generating share URLs
346 |     share_url: Optional[str] = None  # Shareable URL for inviting team members
347 |     next_learning_actions: List[str] = Field(default_factory=list)  # List of next learning actions
348 |     transfer_lifecycle: Dict[str, Any] = Field(default_factory=dict)  # Transfer lifecycle metadata
349 |     archived: bool = False  # Whether this knowledge package has been archived
350 |     is_intended_to_accomplish_outcomes: bool = (
351 |         True  # Whether this package is intended for specific learning outcomes vs general exploration
352 |     )
353 |     knowledge_organized: bool = False  # Whether the coordinator has confirmed all necessary knowledge has been captured
354 | 
355 |     # Metadata fields (formerly from KnowledgePackageInfo)
356 |     version: int = 1  # Version counter for tracking changes
357 |     created_at: datetime = Field(default_factory=datetime.utcnow)
358 |     updated_at: datetime = Field(default_factory=datetime.utcnow)
359 |     updated_by: Optional[str] = None  # User ID who last updated the package
360 | 
361 |     # Package components
362 |     audience: Optional[str] = None  # Description of the intended audience and their existing knowledge level
363 |     brief: Optional[KnowledgeBrief]
364 |     learning_objectives: List[LearningObjective] = Field(default_factory=list)
365 |     takeaways: List[str] = Field(default_factory=list)  # Key takeaways from the knowledge package
366 |     preferred_communication_style: Optional[str] = None  # Preferred communication style for the audience
367 |     transfer_notes: Optional[str] = None  # Status message or notes about the knowledge transfer
368 | 
369 |     requests: List[InformationRequest] = Field(default_factory=list)
370 |     digest: Optional[KnowledgeDigest]
371 |     log: Optional[KnowledgePackageLog] = Field(default_factory=lambda: KnowledgePackageLog())
372 | 
373 |     # Team conversation tracking with embedded achievements
374 |     team_conversations: Dict[str, TeamConversationInfo] = Field(default_factory=dict)
375 | 
376 |     def is_ready_for_transfer(self) -> bool:
377 |         """
378 |         Determine if this knowledge package is ready for transfer to team members.
379 | 
380 |         A package is ready when it has:
381 |         - Knowledge organized and confirmed by coordinator
382 |         - A knowledge brief
383 |         - An audience definition
384 |         - Either:
385 |           - Learning objectives with outcomes (if is_intended_to_accomplish_outcomes is True), OR
386 |           - No learning objectives needed (if is_intended_to_accomplish_outcomes is False)
387 | 
388 |         Returns:
389 |             bool: True if ready for transfer, False otherwise
390 |         """
391 |         has_basic_requirements = self.knowledge_organized and self.brief is not None and self.audience is not None
392 | 
393 |         if not has_basic_requirements:
394 |             return False
395 | 
396 |         # If this package is intended for general exploration (no specific outcomes)
397 |         if not self.is_intended_to_accomplish_outcomes:
398 |             return True
399 | 
400 |         # If this package is intended for specific learning outcomes
401 |         return bool(self.learning_objectives) and any(bool(obj.learning_outcomes) for obj in self.learning_objectives)
402 | 
403 |     def is_actively_sharing(self) -> bool:
404 |         """
405 |         Determine if knowledge transfer is actively happening (team members have joined).
406 | 
407 |         A package is actively sharing when it's ready for transfer AND has team conversations.
408 |         This indicates that team members have actually redeemed share links and are engaging
409 |         with the knowledge.
410 | 
411 |         Returns:
412 |             bool: True if actively sharing, False otherwise
413 |         """
414 |         return self.is_ready_for_transfer() and len(self.team_conversations) > 0
415 | 
416 |     def get_stage_label(self, for_coordinator: bool = True) -> str:
417 |         """
418 |         Get a human-readable stage label based on current package state.
419 | 
420 |         Args:
421 |             for_coordinator: Whether to return coordinator-focused or team-focused labels
422 | 
423 |         Returns:
424 |             str: Stage label with emoji
425 |         """
426 |         if self.archived:
427 |             return "📦 Archived"
428 | 
429 |         if for_coordinator:
430 |             # Coordinator perspective
431 |             if not self.audience:
432 |                 return "🎯 Defining Audience"
433 |             elif not self.knowledge_organized:
434 |                 return "📋 Organizing Knowledge"
435 |             elif not self.brief:
436 |                 return "📝 Creating Brief"
437 |             elif self.is_intended_to_accomplish_outcomes and not self.learning_objectives:
438 |                 return "📚 Adding Objectives"
439 |             elif not self.is_ready_for_transfer():
440 |                 return "📋 Finalizing Setup"
441 |             elif self.is_intended_to_accomplish_outcomes and self._is_transfer_complete():
442 |                 return "✅ Transfer Complete"
443 |             elif self.is_actively_sharing():
444 |                 return "📤 Sharing in Progress"
445 |             else:
446 |                 return "🚀 Ready for Transfer"
447 |         else:
448 |             # Team perspective
449 |             if self.archived:
450 |                 return "📦 Archived"
451 |             elif not self.is_ready_for_transfer():
452 |                 return "⏳ Knowledge Being Organized"
453 |             elif not self.is_intended_to_accomplish_outcomes:
454 |                 return "🔍 Exploring Knowledge"
455 |             elif self.is_intended_to_accomplish_outcomes:
456 |                 return "🎯 Active Learning"
457 |             else:
458 |                 return "🎯 Active Learning"
459 | 
460 |     def get_achievements_for_conversation(self, conversation_id: str) -> List[LearningOutcomeAchievement]:
461 |         """
462 |         Get all achievements for a specific team conversation.
463 | 
464 |         Args:
465 |             conversation_id: The conversation ID to get achievements for
466 | 
467 |         Returns:
468 |             List of achievements for the conversation, empty list if conversation not found
469 |         """
470 |         team_conv = self.team_conversations.get(conversation_id)
471 |         return team_conv.outcome_achievements if team_conv else []
472 | 
473 |     def get_completion_for_conversation(self, conversation_id: str) -> tuple[int, int]:
474 |         """
475 |         Get (achieved_count, total_count) for a specific conversation.
476 | 
477 |         Args:
478 |             conversation_id: The conversation ID to get completion for
479 | 
480 |         Returns:
481 |             Tuple of (achieved_outcomes, total_outcomes) for this conversation
482 |         """
483 |         achievements = self.get_achievements_for_conversation(conversation_id)
484 |         achieved_outcome_ids = {a.outcome_id for a in achievements if a.achieved}
485 | 
486 |         total_outcomes = sum(len(obj.learning_outcomes) for obj in self.learning_objectives)
487 |         achieved_outcomes = len(achieved_outcome_ids)
488 | 
489 |         return achieved_outcomes, total_outcomes
490 | 
491 |     def is_outcome_achieved_by_conversation(self, outcome_id: str, conversation_id: str) -> bool:
492 |         """
493 |         Check if a specific outcome is achieved by a specific conversation.
494 | 
495 |         Args:
496 |             outcome_id: The learning outcome ID to check
497 |             conversation_id: The conversation ID to check
498 | 
499 |         Returns:
500 |             True if the outcome is achieved by this conversation
501 |         """
502 |         achievements = self.get_achievements_for_conversation(conversation_id)
503 |         return any(a.outcome_id == outcome_id and a.achieved for a in achievements)
504 | 
505 |     def get_overall_completion(self) -> tuple[int, int]:
506 |         """
507 |         Get overall completion across all team conversations.
508 | 
509 |         Returns:
510 |             Tuple of (unique_achieved_outcomes, total_outcomes) across all team conversations
511 |         """
512 |         all_achieved_outcomes = set()
513 |         for team_conv in self.team_conversations.values():
514 |             achieved_ids = {a.outcome_id for a in team_conv.outcome_achievements if a.achieved}
515 |             all_achieved_outcomes.update(achieved_ids)
516 | 
517 |         total_outcomes = sum(len(obj.learning_outcomes) for obj in self.learning_objectives)
518 |         return len(all_achieved_outcomes), total_outcomes
519 | 
520 |     def _is_transfer_complete(self) -> bool:
521 |         """
522 |         Check if knowledge transfer is complete (all outcomes achieved by at least one team member).
523 | 
524 |         Returns:
525 |             True if all learning outcomes have been achieved by at least one team conversation
526 |         """
527 |         if not self.is_intended_to_accomplish_outcomes:
528 |             return False
529 | 
530 |         achieved_outcomes, total_outcomes = self.get_overall_completion()
531 |         return total_outcomes > 0 and achieved_outcomes == total_outcomes
532 | 
533 |     def get_all_linked_conversations(self, exclude_current: Optional[str] = None) -> List[str]:
534 |         """
535 |         Get all conversations linked to this knowledge package.
536 | 
537 |         Args:
538 |             exclude_current: Conversation ID to exclude from results (typically current conversation)
539 | 
540 |         Returns:
541 |             List of conversation IDs (coordinator, shared template, and all team conversations)
542 |         """
543 |         conversations = []
544 | 
545 |         # Add coordinator conversation
546 |         if self.coordinator_conversation_id and self.coordinator_conversation_id != exclude_current:
547 |             conversations.append(self.coordinator_conversation_id)
548 | 
549 |         # Add shared template conversation (though usually excluded from notifications)
550 |         if self.shared_conversation_id and self.shared_conversation_id != exclude_current:
551 |             conversations.append(self.shared_conversation_id)
552 | 
553 |         # Add all team conversations
554 |         for conversation_id in self.team_conversations.keys():
555 |             if conversation_id != exclude_current:
556 |                 conversations.append(conversation_id)
557 | 
558 |         return conversations
559 | 
560 |     def get_notification_conversations(self, exclude_current: Optional[str] = None) -> List[str]:
561 |         """
562 |         Get conversations that should receive notifications (excludes shared template).
563 | 
564 |         Args:
565 |             exclude_current: Conversation ID to exclude from results
566 | 
567 |         Returns:
568 |             List of conversation IDs that should receive notifications
569 |         """
570 |         conversations = []
571 | 
572 |         # Add coordinator conversation
573 |         if self.coordinator_conversation_id and self.coordinator_conversation_id != exclude_current:
574 |             conversations.append(self.coordinator_conversation_id)
575 | 
576 |         # Add all team conversations (but NOT shared template)
577 |         for conversation_id in self.team_conversations.keys():
578 |             if conversation_id != exclude_current:
579 |                 conversations.append(conversation_id)
580 | 
581 |         return conversations
582 | 
```
Page 104/145FirstPrevNextLast