Skip to content

feat: reject NIP-70 protected events#644

Merged
Anshumancanrock merged 9 commits into
cameri:mainfrom
Anshumancanrock:nip70-reject-protected-events
Jun 28, 2026
Merged

feat: reject NIP-70 protected events#644
Anshumancanrock merged 9 commits into
cameri:mainfrom
Anshumancanrock:nip70-reject-protected-events

Conversation

@Anshumancanrock

Copy link
Copy Markdown
Collaborator

Description

Adds rejection logic for NIP-70 protected events in EventMessageHandler.

  • Events with a ["-"] tag get rejected with auth-required: this event may only be published by its author (same message the spec uses in its example).
  • Kind-6 reposts that embed a protected event in their content are also rejected.
  • Placed the check after canAcceptEvent so content-length limits kick in before we JSON.parse repost content.

Related Issue

Part of NIP-70 support. Follows #643 which added the detection utility.

Motivation and Context

NIP-70 says relays MUST reject events with ["-"] by default. Without this, those events just get stored and spread like any other event, which breaks the whole point of the tag. The repost check also covers the case where someone sticks a protected event inside a kind-6 repost body to get around the outer tag check.

How Has This Been Tested?

10 unit tests added to event-message-handler.spec.ts covering:

  • Direct protected tag rejection
  • Events with no tags / unrelated tags (no false positives)
  • Kind-6 repost with embedded protected event
  • Kind-6 repost with clean embedded event
  • Empty content, invalid JSON content (graceful handling)
  • Non-repost kind with JSON content containing ["-"] (should pass through)
  • Precedence: a repost that is itself protected hits auth-required before the embed check
  • Malformed embedded tags (non-array tags field in parsed JSON)

Screenshots (if appropriate):

N/A

Types of changes

  • Non-functional change (docs, style, minor refactor)
  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)

Checklist:

  • My code follows the code style of this project.
  • My change requires a change to the documentation.
  • I have updated the documentation accordingly.
  • I have read the CONTRIBUTING document.
  • I have added tests to cover my code changes.
  • I added a changeset, or this is docs-only and I added an empty changeset.
  • All new and existing tests passed.

@changeset-bot

changeset-bot Bot commented Jun 15, 2026

Copy link
Copy Markdown

🦋 Changeset detected

Latest commit: eb1e9bc

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
nostream Minor

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

Copilot AI left a comment

Copy link
Copy Markdown

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 enforcement for NIP-70 “protected events” at the relay handler level by rejecting events tagged with ["-"] and rejecting kind-6 reposts whose embedded event includes a protected tag, with accompanying unit tests and a changeset.

Changes:

  • Add isProtectedEventBlocked() logic in EventMessageHandler and invoke it after canAcceptEvent.
  • Reject kind-6 reposts that embed protected events in their JSON content.
  • Add unit tests for direct protected tags, repost-embedded protected tags, and malformed/edge-case content; include a changeset entry.

Reviewed changes

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

File Description
src/handlers/event-message-handler.ts Adds protected-event/repost-embed rejection logic and wires it into message handling.
test/unit/handlers/event-message-handler.spec.ts Adds unit tests covering protected-tag and repost-embedding behavior plus edge cases.
.changeset/nip70-reject-protected-events.md Declares a minor release changeset for the new NIP-70 rejection behavior.

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

Comment thread src/handlers/event-message-handler.ts
Comment thread src/handlers/event-message-handler.ts Outdated
Comment thread src/handlers/event-message-handler.ts Outdated
@coveralls

coveralls commented Jun 19, 2026

Copy link
Copy Markdown
Collaborator

Coverage Status

coverage: 67.106% (+0.1%) from 66.984% — Anshumancanrock:nip70-reject-protected-events into cameri:main

@Anshumancanrock Anshumancanrock force-pushed the nip70-reject-protected-events branch 2 times, most recently from 04efecf to b68e8c8 Compare June 20, 2026 18:20
@Anshumancanrock Anshumancanrock force-pushed the nip70-reject-protected-events branch from b68e8c8 to 86fbcae Compare June 20, 2026 18:23
Comment thread src/handlers/event-message-handler.ts Outdated
Comment thread src/handlers/event-message-handler.ts Outdated
Anshumancanrock added a commit to Anshumancanrock/nostream that referenced this pull request Jun 28, 2026
Address maintainer review comments on PR cameri#644:

1. Validate embedded event before checking protected tag: parse with
   eventSchema, verify isEventIdValid() and isEventSignatureValid()
   so forged JSON with a '-' tag cannot trigger a false rejection.

2. Log a warning on parse/validation failure instead of silently
   swallowing the error, using the existing debug-based logger.

Also removes the now-unused EventTags import (isProtectedEvent()
handles the tag check internally) and updates tests to use
cryptographically valid embedded events via identifyEvent/signEvent.
@Anshumancanrock Anshumancanrock force-pushed the nip70-reject-protected-events branch from 2fd3301 to aefd8a7 Compare June 28, 2026 06:30
@Anshumancanrock Anshumancanrock force-pushed the nip70-reject-protected-events branch from aefd8a7 to 8b746ee Compare June 28, 2026 06:36
@Anshumancanrock Anshumancanrock requested a review from cameri June 28, 2026 07:52
@Anshumancanrock Anshumancanrock merged commit 2f6d773 into cameri:main Jun 28, 2026
18 checks passed
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.

4 participants