[PR #4648] [client] Fix netstack upstream dns and add wasm debug methods #4345

Open
opened 2025-11-20 08:08:12 -05:00 by saavagebueno · 0 comments
Owner

Original Pull Request: https://github.com/netbirdio/netbird/pull/4648

State: open
Merged: No


Describe your changes

  • Make upstream dns handler use netstack (js only)
  • Make dns interceptor use netstack to reach the dns forwarder of routing peers
  • Refactor status methods: ParseToJSON()JSON(), ParseToYAML()YAML(), ParseGeneralSummary()GeneralSummary(), ParseToFullDetailSummary()FullDetailSummary()
  • Move toProtoFullStatus()FullStatus.ToProto() method
  • Include events in FullStatus (remove GetEvents RPC)
  • Add embed client methods: Status(), GetLatestSyncResponse(), SetLogLevel()
  • Add netbird js client debug methods:
    • ping(hostname)
    • pingTCP(hostname, port)
    • status()
    • statusDetail()
    • statusSummary()
    • setLogLevel(level)
    • getSyncResponse()
  • Fix embed client Start() to track connect instead of cancel for state checking
  • Fix embed client Stop() to cancel context and clean up properly
  • Skip STUN/TURN probes on JS/WASM platform

Stack

Checklist

  • Is it a bug fix
  • Is a typo/documentation fix
  • Is a feature enhancement
  • It is a refactor
  • Created tests that fail without the change (if possible)

By submitting this pull request, you confirm that you have read and agree to the terms of the Contributor License Agreement.

Documentation

Select exactly one:

  • I added/updated documentation for this change
  • Documentation is not needed for this change (explain why)

Docs PR URL (required if "docs added" is checked)

Paste the PR link from https://github.com/netbirdio/docs here:

https://github.com/netbirdio/docs/pull/__

**Original Pull Request:** https://github.com/netbirdio/netbird/pull/4648 **State:** open **Merged:** No --- ## Describe your changes - Make upstream dns handler use netstack (`js` only) - Make dns interceptor use netstack to reach the dns forwarder of routing peers - Refactor status methods: `ParseToJSON()` → `JSON()`, `ParseToYAML()` → `YAML()`, `ParseGeneralSummary()` → `GeneralSummary()`, `ParseToFullDetailSummary()` → `FullDetailSummary()` - Move `toProtoFullStatus()` → `FullStatus.ToProto()` method - Include events in `FullStatus` (remove `GetEvents` RPC) - Add embed client methods: `Status()`, `GetLatestSyncResponse()`, `SetLogLevel()` - Add netbird js client debug methods: - `ping(hostname)` - `pingTCP(hostname, port)` - `status()` - `statusDetail()` - `statusSummary()` - `setLogLevel(level)` - `getSyncResponse()` - Fix embed client `Start()` to track `connect` instead of `cancel` for state checking - Fix embed client `Stop()` to cancel context and clean up properly - Skip STUN/TURN probes on JS/WASM platform ## Issue ticket number and link ## Stack <!-- branch-stack --> ### Checklist - [x] Is it a bug fix - [ ] Is a typo/documentation fix - [x] Is a feature enhancement - [x] It is a refactor - [ ] Created tests that fail without the change (if possible) > By submitting this pull request, you confirm that you have read and agree to the terms of the [Contributor License Agreement](https://github.com/netbirdio/netbird/blob/main/CONTRIBUTOR_LICENSE_AGREEMENT.md). ## Documentation Select exactly one: - [ ] I added/updated documentation for this change - [x] Documentation is **not needed** for this change (explain why) ### Docs PR URL (required if "docs added" is checked) Paste the PR link from https://github.com/netbirdio/docs here: https://github.com/netbirdio/docs/pull/__
saavagebueno added the pull-request label 2025-11-20 08:08:12 -05:00
Sign in to join this conversation.
1 Participants
Notifications
Due Date
No due date set.
Dependencies

No dependencies set.

Reference: SVI/netbird#4345