Skip to content

Conversation

mikekistler
Copy link
Contributor

This PR adds docs and sample to describe how to access the HttpContext for a request from a tool call handler.

Copy link
Contributor

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR adds comprehensive documentation and sample code demonstrating how to access HttpContext from MCP tool call handlers when using the HTTP transport. The documentation includes explanations of using IHttpContextAccessor, code snippets, and working examples.

Key changes:

  • Adds new HttpContext concept documentation with examples
  • Creates sample project showing HttpContext access patterns in tool handlers
  • Updates project files to disable assembly info generation across samples

Reviewed Changes

Copilot reviewed 17 out of 17 changed files in this pull request and generated 2 comments.

Show a summary per file
File Description
docs/concepts/toc.yml Adds HTTP Context section to documentation table of contents
docs/concepts/httpcontext/httpcontext.md Main documentation explaining HttpContext access patterns
docs/concepts/httpcontext/samples/ Complete sample project demonstrating HttpContext usage
Multiple .csproj files Adds assembly info generation settings to maintain consistency
ModelContextProtocol.slnx Includes new HttpContext sample project in solution

Tip: Customize your code reviews with copilot-instructions.md. Create the file or learn how to get started.

{
private readonly IHttpContextAccessor _httpContextAccessor;

public ContextTools(IHttpContextAccessor httpContextAccessor)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider expressing this as a primary constructor for brevity.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This would allow unifying the two snippets into one for a self-contained tool definition.


[McpServerTool(UseStructuredContent = true)]
[Description("Retrieves the request information from the current HTTP context and returns it as structured content.")]
public object GetRequestInfo()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we delete the tools not being used by the documentation?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants