Skip to content

fix(apps): log inbound activities at info, warn on missing Authorization#568

Draft
corinagum wants to merge 3 commits into
mainfrom
cg/silent-401
Draft

fix(apps): log inbound activities at info, warn on missing Authorization#568
corinagum wants to merge 3 commits into
mainfrom
cg/silent-401

Conversation

@corinagum
Copy link
Copy Markdown
Collaborator

@corinagum corinagum commented May 8, 2026

Summary

Cross-SDK: equivalent fix filed for teams.py (microsoft/teams.py#425).

Test plan

  • npx turbo build --filter=@microsoft/teams.apps
  • npx jest in packages/apps (257/257 pass)
  • npx eslint src/http/http-server.ts (clean)
  • Reviewer eyeball: confirm log message wording

Copilot AI review requested due to automatic review settings May 8, 2026 21:02
…zation header

Inbound activities only logged at debug, and the missing-Authorization-header
path returned 401 with no log line at all. At default info level this made it
impossible to tell "request never arrived" from "request arrived and was
silently 401'd by the SDK." Adds an info-level entry log on every inbound and
a warn log when rejecting for a missing Authorization header.

Refs #564.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Copy link
Copy Markdown
Contributor

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 improves diagnostics in @microsoft/teams.apps HTTP ingress by adding higher-visibility logs around inbound activity handling and the “missing Authorization header” rejection path, reducing cases where a silent 401 makes it hard to determine whether requests reached the SDK.

Changes:

  • Log every inbound activity at info level in HttpServer.handleRequest (type + id).
  • Log a warn when rejecting an inbound activity due to a missing Authorization header in authorize.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread packages/apps/src/http/http-server.ts Outdated
…ype/id

Addresses Copilot review feedback on #568:
- Activity type/id come from the untrusted request body before auth runs.
  Strip control characters and cap length before interpolating into log
  lines so an attacker cannot forge multi-line log entries.
- Include type/id on the missing-Authorization-header warn, so users running
  at WARN level can correlate the rejection with a specific activity without
  needing the preceding info entry.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
@corinagum corinagum marked this pull request as draft May 8, 2026 21:45
Per review feedback: the info-level entry log on every inbound activity is
redundant with the existing debug log at the same site, and operators who
want diagnostic visibility into "did the request reach the SDK" can already
get it by flipping the logger to debug. The genuinely new diagnostic value
is the warn on the missing-Authorization-header path, which is silent at
every log level today; that stays.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
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