E2E edge onboarding with docker poller/agent #633
Closed
opened 2026-03-28 04:26:41 +00:00 by mfreeman451
·
10 comments
No Branch/Tag specified
staging
demo/prod-release
add-dashboard-srql-service-views
enhance-dashboard-creator-visual-builder
fix-release-1-2-78-ci-failures
refactor-agent-plugin-runtime
add-dashboard-creator
update/plugin-system
add-service-monitoring-foundation
fix/cli-auth-settings-navigation
fix/device-unknown-facet
fix-plugin-assignment-upgrades
fix/sweep-profile-mode-status
fix/armis-northbound-fixes
fix-proxmox-console-react-client-render
fix-openbao-signing-job-token-mount
fix-services-plugin-status-read-model
fix-stream-status-final-chunk
codex/fix-prod-armis-sync-icmp
fix-demo-cnpg-operator-networkpolicy
update/docs-cleanup
fix-armis-northbound-raw-token-auth
fix-armis-northbound-stuck-running
update-manual-device-hostname-readd
fix/observability-severity-card-links
renovate/debian_testing_slim-testing-slim
docs/kubernetes-ingestion-gateway
fix/flow-collector-external-network-policy
fix/armis-availability-and-stream-config
refactor-fast-fresh-db-bootstrap
fix/cnpg-not-found
fix/docker-update/cnpg
renovate/debian_bookworm_slim-bookworm-slim
add-socket-firewall-ci
add-ipv6-sweep-scanners
fix-armis-northbound
add-streamed-agent-config
fix/sweep-ip-family-routing
codex/fix-core-migration-hook-upgrade
renovate/arc_runner
renovate/actions_runner
codex/remote-access-desktop-rdp
updates/missing-fixes
fix/batched-sweep-targets
fix/agent-sysmon-memory-growth
fix/armis-northbound-single-run-and-timestamps
release/1.2.67
fix/wasm-plugin-service-status
fix/armis-names-string
codex/harden-remote-access-app-tcp-followup
codex/harden-remote-access-app-tcp
codex/harden-gateway-proxy-auth
codex/harden-remote-access-destroy-rbac
codex/harden-ssh-ca-remote-access
codex/harden-remote-access-broker-registry
codex/harden-remote-access-approval-policy
codex/harden-remote-access-file-transfer
codex/harden-remote-access-attach-ticket
fix-release-plugin-list-cleanup
codex/harden-grpc-logger-payloads
propose-interface-action-target-context
add-signed-northbound-action-callbacks
fix/reap-stale-self-scheduled-oban-jobs
fix/device-logs-tab-async
fix/device-metadata-summary
fix/northbound-launch-target-auth
fix/northbound-provider-atomic-read
proposal/add-sample-northbound-wasm-plugin
proposal/northbound-action-integrations
fix/ansible-run-job-device-launch
codex/fix-audit-events-shell-theme
codex/fix-sweep-tcp-availability
codex/fix-armis-names-string
fix/update-nats-2-14
fix/elixir-quality-release-blockers
fix/latest-release-device-ingest-ui-bugs
fix/release-1.2.61-ci-failures
fix/web-ng-precommit-format
fix/wasm-tinygo-go125
fix/agent-file-transfer-bazel-src
fix/release-key-stamp-root
fix/release-1.2.59-staging
main
fix/agent-accept-deprecated-remote-access-config
fix/device-results-count-facets
fix/bazelisk-installer-retries
fix/tinygo-host-toolchain-fetch
add-per-agent-availability
fix/forgejo-release-multipart-assets
fix/agent-config-stale-session
fix/mtr-hop-dns-resolution
fix/hostname-only-device-create
fix/otlp-log-metadata-sanitization
fix/sweep-icmp-legacy-mode-classification
add-nats-object-store-retention
fix/helm-serviceradar-state-pvc
harden/forgejo-ci-nonroot
codex/expand-remote-access-teleport-parity
fix/sweep-port-history-consistency
fix/remote-access-ssh-feature-flag
fix/devices-refresh-artifacts
fix/identity-ingestion-sweep-availability
spec/identity-cache-ingestion-correctness
fix/sweep-mapper-promotion-stale-cache
fix/sweep-provisional-duplicate-ip
fix/sweep-target-invalid-ip-order
fix/armis-large-sync-streaming
fix/docusaurus-blog-build-date
fix/armis-sync-compat-deep-dive
fix/awx-controller-credential-secret
fix/demo-release-source-branch
demo/release-v1.2.44-source-fix
codex/teleport-agent-routed-remote-access
feature/agent-config-dependency-catalog
proposal/agent-config-dependency-catalog
bugfix/armis-credentials-save-display
bugfix/armis-integration-credentials
fix/web-ng-precommit-formatting
bugfix/armis-secret-config-push
feature/close-controllers-to-pipelines
carverauto/extract-palisade
feature/migrate-dashboard-cli-to-plugs
feature/audit-history-page
feature/migrate-controllers-to-security-pipelines
fix/security-events-test-and-retention-worker
feature/add-platform-security-hardening
demo-rollout-proxmox-bazel-fix
bug/armis-sync-issues
add-virtualization-srql-queries
add-proxmox-ingestion-hardening-tests
add-ssh-private-key-credential-rules
redact-plugin-credential-material
add-credential-rules-settings-entry
add-credential-rules-settings-flows
require-network-credential-broker-grants
preview-credential-rule-target-scope
add-proxmox-credential-secret-preset
harden-credential-rules-live-tests
clarify-proxmox-plugin-credential-modes
docs-proxmox-credential-operations
fingerprint-proxmox-candidates
proxmox-resource-efficiency-dashboard
proxmox-console-security-docs
proxmox-focused-quality-validation
proxmox-metric-baseline-alerts
proxmox-device-scoped-logs
proxmox-defer-vector-log-forwarding
proxmox-console-session-tickets
proxmox-console-xterm-shell
proxmox-console-websocket-broker
proxmox-console-control-frames
proxmox-console-agent-session-manager
proxmox-console-plugin-pty-bridge
proxmox-console-assignment-materializer
proxmox-console-ssh-connector
proxmox-console-agent-local-broker
proxmox-console-device-actions
proxmox-console-stream-timeouts
proxmox-console-guest-mode-gating
proxmox-console-ci-race-fix
fix/falco-alert-routing-datasvc-channel
fix-agent-release-page-bugs
add-proxmox-device-details-summary
add-proxmox-virtualization-ingestor
add-virtualization-inventory-schema
add-proxmox-infrastructure-inventory
add-proxmox-plugin-live-smoke
add-proxmox-local-api-smoke
add-proxmox-credential-test-dispatch
add-proxmox-credential-test-plan
add-network-credential-rule-preview
add-proxmox-plugin-inventory-details
add-proxmox-credential-reconcile-worker
add-proxmox-credential-assignment-materializer
add-plugin-input-template-secret-refs
add-proxmox-plugin-policy-inputs
add-proxmox-wasm-plugin-scaffold
add-network-credential-rules-model
add-proxmox-plugin-credential-rules
fix/rperf-rustls-provider-demo
fix/dashboard-template-sdk-014
fix/tinygo-go126-release
fix/reqsign-provider-bazel-deps
fix/release-bazel-rust-crates
fix/core-coordinator-connection-leak
chore/security-updates
update/readme-versions-update
docs/readme-dashboard-sdk
chore/cli-0.1.5
fix/dashboard-cli-local-map-dev
fix/dashboard-cli-hmr-map-libraries
chore/bump-serviceradar-cli-0.1.2
fix/dashboard-cli-hmr-harness
fix/helm-contour-liveview-websocket
fix/helm-cnpg-pooler-defaults
updates/helm-fixes
update/fix-light-mode-analytics
ual/dashboard-sdk-dx
security/postgres-update
update-falco-alert-diagnostics
ual/react-dashboard-sdk
fix/cnpg-saturation-fk-and-bootstrap
ual/wifi-site-map
fix-coraza-log-db-writer
fix-log-viewer-syslog-processed
plan-fieldsurvey-spatial-selection
plan-envoy-coraza-waf
plan-alienvault-otx-integration
plan-fieldsurvey-sidekick-daemon
cleanup-openspec-archive-closed-proposals
bug-core-elx-ip-enrichment-reap
fix-release-libcap2-pin-v125
fix-camera-stream-gateway-route
add-core-elx-prometheus-metrics
add-serviceradar-observability-dashboards
add-pgbouncer-helm-cnpg
renovate/ghcr.io-actions-actions-runner
feat/cluster-agent-runtime-metadata-stability
feat/observability-shell-standardization
feat/observability-live-log-toggle
fix/mtr-bulk-queue-and-srql-targets
fix/mtr-profile-protocol-keyerror
fix/mtr-diagnostics-keyerror
add-demo-rollout-skills
fix-web-ng-test-support-dialyzer
fix-web-ng-dialyzer-findings
add-bulk-queued-mtr-diagnostics
fix-serviceradar-core-integration-failures
harden-agent-updater-exec-arguments
harden-agent-release-trust-boundaries
fix-compose-hermetic-nats-datasvc-bootstrap
fix/openbao-release-issues
elixir/formatting-updates
codex/demo-cnpg-signing-release-fixes
chore/lint-fixes
fix/bazel-alpine-bump-and-cosign-skip
update-event-alert-dedup-and-suppression
armis-northbound-events
armis-northbound-availability-updates
push-owvypksrmooo
codex/topology-endpoint-evidence-investigation
codex/topology-bootstrap-and-layout-simplification
codex/remove-ingress-nginx-edge
fix/forgejo-ci-snmp-cache-and-ubuntu24
bug/cnpg-mtls-failure
bug/log-collector
fix/forgejo-runner-labels
fix/cargo-lock-sync
remove-arc-runner-from-push-all
fix-push-all-cosign-preflight
fix-go-ci
add-versioned-openapi-publish
chore/forgejo-hardening
security/k8s-hardening
update/cluster-page-agents
updates/helm-security-updates
2406-feat-agent-fleet-management-secure-self-update-system
bug/k8s-helm-deployments
chore/k8s-arc-update
rust-fix
2371-analytics-stats-cards-should-abbreviate-numbers
chore/perl-cleanup
2942-featweb-ng-add-logs-tab-to-device-details-page
192-feat-tftp-server
mikemiles-dev/feature/netflow_collection
testing
dependabot/cargo/hostname-0.4.1
dependabot/cargo/redis-1.0.1
dependabot/cargo/bb8-0.9.0
dependabot/cargo/rcgen-0.14.6
dependabot/cargo/hyper-1.8.1
dependabot/cargo/hyper-util-0.1.19
dependabot/cargo/clap-4.5.51
dependabot/cargo/thiserror-2.0.17
dependabot/cargo/time-tz-2.0.0
dependabot/cargo/tonic-build-0.14.2
backup/main-pre-staging-sync-2026-04-02
dependabot/npm_and_yarn/docs/mdast-util-to-hast-13.2.1
815-feat-support-win32-for-agentpoller
gh-pages
v1.2.79
v1.2.78
v1.2.77
v1.2.76
v1.2.75
v1.2.74
v1.2.73
v1.2.72
v1.2.71
v1.2.70
v1.2.69
v1.2.68
v1.2.67
v1.2.66
v1.2.65
v1.2.64
v1.2.63
v1.2.62
v1.2.61
v1.2.60
v1.2.59
v1.2.58
v1.2.57
v1.2.54
v1.2.53
v1.2.52
v1.2.51
v1.2.50
v1.2.49
v1.2.48
v1.2.47
v1.2.46
v1.2.45
v1.2.44
v1.2.43
v1.2.42
v1.2.41
v1.2.40
v1.2.39
v1.2.38
sha-de6d1025d59f039188754b895ff7fe65db9b306b
sha-8006b6105635acf43060fab2613eab3bccb1efcf
v1.2.37
v1.2.36
v1.2.35
v1.2.34
v1.2.33
v1.2.32
v1.2.31
v1.2.30
v1.2.29
v1.2.28
v1.2.27
v1.2.26
v1.2.25
v1.2.24
v1.2.23
v1.2.22
v1.2.21
v1.2.20
v1.2.19
v1.2.18
v1.2.17
v1.2.16
v1.2.15
v1.2.14
v1.2.13
v1.2.12
v1.2.11
v1.2.6
v1.2.10
v1.2.9
v1.2.8
v1.2.7
v1.2.5
v1.2.4
v1.2.3
v1.2.2
v1.2.1
v1.2.0
v1.1.2
v1.1.0
v1.0.92
v1.0.91
v1.0.90
v1.0.89
v1.0.88
v1.0.87
v1.0.86
v1.0.85
v1.0.84
v1.0.83
v1.0.82
v1.0.81
v1.0.78
v1.0.77
v1.0.76
v1.0.70
v1.0.69
v1.0.68
v1.0.67
v1.0.66
v1.0.65
v1.0.64
v1.0.63
v1.0.62
v1.0.61
v1.0.60
v1.0.59
v1.0.58
1.0.57
v1.0.56
v1.0.55
v1.0.54-pre5
v1.0.53
v1.0.53-pre19
v1.0.53-pre18
v1.0.53-pre17
v1.0.53-pre15
1.0.53-pre10
1.0.53-pre9
1.0.53-pre8
1.0.53-pre7
1.0.53-pre6
1.0.53-pre5
1.0.53-pre4
1.0.53-pre3
1.0.53-pre2
1.0.53-pre1
1.0.52
1.0.51
1.0.50
1.0.49
1.0.49-pre5
1.0.49-pre4
1.0.49-pre3
1.0.49-pre2
1.0.48
1.0.48-rc2
1.0.48-rc1
1.0.48-pre8
1.0.48-pre7
1.0.48-pre6
1.0.48-pre5
1.0.48-pre4
1.0.48-pre3
1.0.48-pre2
1.0.48-pre1
1.0.47
1.0.47-pre8
1.0.47-pre7
1.0.47-pre6
1.0.47-pre5
1.0.47-pre4
1.0.47-pre3
1.0.47-pre2
1.0.47-pre1
1.0.46
1.0.46-pre9
1.0.46-pre8
1.0.46-pre7
1.0.46-pre6
1.0.46-pre5
1.0.46-pre4
1.0.46-pre3
1.0.46-pre2
1.0.46-pre1
1.0.45
1.0.44
1.0.44-pre12
1.0.44-pre11
1.0.44-pre10
1.0.44-pre9
1.0.44-pre8
1.0.44-pre7
1.0.44-pre6
1.0.44-pre5
1.0.44-pre4
1.0.44-pre3
1.0.44-pre2
1.0.44-pre1
1.0.43
1.0.42
1.0.41
1.0.41-pre1
1.0.40
1.0.40-pre11
1.0.40-pre10
1.0.40-pre9
1.0.40-pre8
1.0.40-pre7
1.0.40-pre6
1.0.40-pre5
1.0.40-pre4
1.0.40-pre3
1.0.40-pre2
1.0.40-pre1
1.0.39
1.0.38
1.0.37
1.0.36
1.0.36-pre5
1.0.36-pre4
1.0.36-pre3
1.0.36-pre2
1.0.35
1.0.35-pre3
1.0.35-pre2
1.0.35-pre
1.0.34-pre3
1.0.34-pre2
1.0.34-pre1
1.0.33
1.0.33-pre2
1.0.33-pre
1.0.32
1.0.31
1.0.30
1.0.29
1.0.28
1.0.27
1.0.26
1.0.25
1.0.24
1.0.23
1.0.22
1.0.21
1.0.20
1.0.19
1.0.18
1.0.17
1.0.16
1.0.15
1.0.14
1.0.13
1.0.11
1.0.10
1.0.9
1.0.8
1.0.7
1.0.6
1.0.5
1.0.4
1.0.3
1.0.2
1.0.1
1.0.0
Labels
Clear labels
1week
2weeks
Failed compliance check
IP cameras
NATS
NATS JetStream
Possible security concern
Review effort 1/5
Review effort 2/5
Review effort 3/5
Review effort 4/5
Review effort 5/5
UI
aardvark
accessibility
amd64
api
arm64
auth
back-end
bgp
blog
bug
Something isn't working
build
checkers
ci-cd
continuous integration-continuous deployments
cleanup
cnpg
cloud-native postgres
codex
core
core service
dependencies
Pull requests that update a dependency file
device-management
documentation
Improvements or additions to documentation
duplicate
This issue or pull request already exists
dusk
ebpf
enhancement
New feature or request
eta 1d
eta 1hr
eta 3d
eta 3hr
feature
fieldsurvey
github_actions
Pull requests that update GitHub Actions code
go
Pull requests that update Go code
good first issue
Good for newcomers
help wanted
Extra attention is needed
invalid
This doesn't seem right
javascript
Pull requests that update Javascript code
k8s
log-collector
mapper
mtr
multi traceroute
needs-triage
netflow
network-sweep
observability
oracle
Oracle Linux related issues
otel
opentelemetry logs, traces, metrics
plug-in
proton
timeplus proton streaming database
python
question
Further information is requested
reddit
redhat
research
rperf
rperf-checker
rust
Pull requests that update rust code
sdk
security
serviceradar-agent
serviceradar-agent-gateway
serviceradar-web
serviceradar-web-ng
siem
snmp
sysmon
topology
ubiquiti
wasm
wontfix
This will not be worked on
zen-engine
No labels
1week
2weeks
Failed compliance check
IP cameras
NATS
Possible security concern
Review effort 1/5
Review effort 2/5
Review effort 3/5
Review effort 4/5
Review effort 5/5
UI
aardvark
accessibility
amd64
api
arm64
auth
back-end
bgp
blog
bug
build
checkers
ci-cd
cleanup
cnpg
codex
core
dependencies
device-management
documentation
duplicate
dusk
ebpf
enhancement
eta 1d
eta 1hr
eta 3d
eta 3hr
feature
fieldsurvey
github_actions
go
good first issue
help wanted
invalid
javascript
k8s
log-collector
mapper
mtr
needs-triage
netflow
network-sweep
observability
oracle
otel
plug-in
proton
python
question
reddit
redhat
research
rperf
rperf-checker
rust
sdk
security
serviceradar-agent
serviceradar-agent-gateway
serviceradar-web
serviceradar-web-ng
siem
snmp
sysmon
topology
ubiquiti
wasm
wontfix
zen-engine
Milestone
Clear milestone
No items
No milestone
Projects
Clear projects
No items
No project
Assignees
Clear assignees
No assignees
1 participant
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".
No due date set.
Dependencies
No dependencies set.
Reference
carverauto/serviceradar#633
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Imported from GitHub.
Original GitHub issue: #1911
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911
Original created: 2025-10-30T23:36:36Z
Summary
Exercise the edge onboarding flow end-to-end by issuing packages from the demo namespace and bootstrapping docker-compose poller/agent workloads locally.
Details
demonamespace secrets to authenticate against/api/admin/edge-packages.serviceradar-coresurfaces both docker poller/agent entries in device inventory; investigate registry merge/clobber behavior when multiple services share the same IP.Resolves bd: serviceradar-56
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3470980300
Original created: 2025-10-31T01:44:22Z
Update: refreshed the demo-issued poller/agent packages and rebuilt the docker stack with the new edge-poller setup tweaks (POLLERS_POLLER_ID + kv disabled). The poller now registers with core as \ and gRPC health checks against the local agent succeed, but both packages are still stuck in \delivered. Core never flips to \activated\ because the agent is serving the poller SPIFFE ID so the TLS authorizer accepts it, while the package metadata still claims \spiffe://carverauto.dev/services/agent. Next step is to reconcile the SPIFFE IDs (either regenerate the agent package with the poller SVID or relax the client expectation) so activation events fire and device inventory can be revalidated.
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3470980549
Original created: 2025-10-31T01:44:33Z
Update: refreshed the demo-issued poller/agent packages and rebuilt the docker stack with the new edge-poller setup tweaks (POLLERS_POLLER_ID + KV disabled). The poller now registers with core as
docker-poller-e2e-01and gRPC health checks against the local agent succeed, but both packages are still stuck indelivered. Core never flips toactivatedbecause the agent is serving the poller SPIFFE ID so the TLS authorizer accepts it, while the package metadata still claimsspiffe://carverauto.dev/services/agent. Next step is to reconcile the SPIFFE IDs (either regenerate the agent package with the poller SVID or relax the client expectation) so activation events fire and device inventory can be revalidated.Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471074531
Original created: 2025-10-31T02:31:31Z
Dug into the "delivered" state on docker poller/agent packages (fc348035-9092-4903-aaa6-c3e9105ce719 and bce4363a-da28-43bd-afce-9aa68f365b04). Even though the poller is reporting to core, we never mark the packages as activated – the core service only persisted the issued/delivered states. Added an activation hook in core that runs during device registration so the first poller/agent heartbeat promotes the package to activated, captures the source IP, and emits an audit event. Also added unit coverage in pkg/core to exercise the new flow. Once we cut a fresh serviceradar-core build and roll it into demo we should see both packages flip to activated in the admin UI.
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471285022
Original created: 2025-10-31T04:19:28Z
0f61dd1e-bfc7-4448-8461-bb65e9f71509, agent5bd01c6d-91a2-4821-8154-bdce639ae894.edge-poller-restart.shusing the new artifacts. Poller successfully enrolls once upstream join token is refreshed.invalid server SPIFFE ID). Temporarily clearedKV_ADDRESS/KV_SPIFFE_IDto get the container to come up; agent now serves gRPC (serviceradar-agentbroadcasts ready state) but runs without KV linkage.transport: authentication handshake failed: unexpected ID "spiffe://carverauto.dev/services/poller"during/grpc.health.v1.Health/Check. Package metadata currently stamps the agent server SPIFFE ID asspiffe://carverauto.dev/ns/edge/docker-agent-e2e-01; need to reconcile what the agent actually expects versus what the poller presents.status:"delivered"; core never records activation. Device inventory still missing the docker agent entry.spiffe://carverauto.dev/services/pollercaller is accepted. Also need a follow-up pass to re-enable KV once the SPIFFE mismatch is sorted.Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471316742
Original created: 2025-10-31T04:39:48Z
Update: Edge package tooling now threads the nested SPIRE IDs all the way through. Fresh archives include NESTED_SPIRE_PARENT_ID/NESTED_SPIRE_DOWNSTREAM_SPIFFE_ID/NESTED_SPIRE_AGENT_SPIFFE_ID, the compose setup script rewrites poller-spire/env to match, and docker compose passes NESTED_SPIRE_AGENT_SPIFFE_ID into the poller entrypoint so it provisions the right workload entries. Once the demo packages are reissued we can rerun setup-edge-poller.sh, restore KV in edge-poller.env, bring the stack back up, and validate that both poller and agent packages reach and appear in device inventory.
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471316961
Original created: 2025-10-31T04:39:57Z
Update: Edge package tooling now threads the nested SPIRE IDs end-to-end. Fresh archives include NESTED_SPIRE_PARENT_ID/NESTED_SPIRE_DOWNSTREAM_SPIFFE_ID/NESTED_SPIRE_AGENT_SPIFFE_ID, the compose setup script rewrites poller-spire/env to match, and docker compose passes NESTED_SPIRE_AGENT_SPIFFE_ID into the poller entrypoint so it provisions the right workload entries. Next step: reissue the demo packages, rerun setup-edge-poller.sh with the new env, restore KV in edge-poller.env, bring the stack back up, and verify both poller and agent packages transition to activated and appear in device inventory.
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471461156
Original created: 2025-10-31T06:06:03Z
Edge onboarding compose stack is now running cleanly with the new packages. I revoked the previous artifacts and reissued poller ce492405-a4ed-404d-bece-7044a0bb7798 and agent 91bcd977-11da-4fc4-bf01-213d4c9a549b, adding dedicated unix:path selectors so the nested SPIRE server hands different SVIDs to the poller and agent processes. After downloading the archives and replaying docker/compose/edge-poller-restart.sh, the poller gRPC checks started passing (docker logs serviceradar-poller shows the agent service check completing successfully) and both packages report status:"activated" via /api/admin/edge-packages/*. Device inventory now surfaces default:172.19.0.2 with poller_id docker-poller-e2e-02, so the docker agent is visible in the UI. I left KV disabled in edge-poller.env for the moment: re-enabling it still crashes the agent with "invalid server SPIFFE ID" when it builds the KV client; we should follow up on that mismatch separately.
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3471868791
Original created: 2025-10-31T08:33:01Z
Status update (edge onboarding validation)
pkg/grpc/security.go; mixed-case server IDs (SPIFFE://…) now parse correctly.go test ./pkg/grpc/...passes.ce492405-a4ed-404d-bece-7044a0bb7798and agent91bcd977-11da-4fc4-bf01-213d4c9a549bpackages. Once the compose stack is stable both showstatus:"activated", and/api/deviceslistsdocker-poller-e2e-02plusdocker-agent-e2e-02.docker cp bin/serviceradar-agent …. That diverged from the GHCR image we deploy in demo and left the container restarting. We will not hand-copy binaries again.bazel build --config=remote //docker/images:agent_image_amd64thenbazel run --config=remote //docker/images:agent_image_amd64_push, followed bydocker/compose/edge-poller-restart.sh --env-file edge-poller.envso compose pulls the pushed digest.serviceradar-56as well):kubectl port-forward svc/serviceradar-core -n demo 18090:8090API_KEY=$(kubectl -n demo get secret serviceradar-secrets -o jsonpath='{.data.edge_api_key}' | base64 -d)ADMIN_PASS=$(kubectl -n demo get secret serviceradar-secrets -o jsonpath='{.data.admin_password}' | base64 -d)TOKEN=$(curl -s -X POST http://localhost:18090/auth/login -d '{"username":"admin","password":"'"$ADMIN_PASS"'"}' | jq -r .token)curl -s -X POST http://localhost:18090/api/admin/edge-packages -H "Authorization: Bearer $TOKEN" -H "X-Edge-Api-Key: $API_KEY" -H 'Content-Type: application/json' -d '{"label":"Docker E2E Poller 03","poller_id":"docker-poller-e2e-02"}'curl -s -X POST http://localhost:18090/api/admin/edge-packages -H ... -d '{"poller_id":"docker-poller-e2e-02","component_type":"agent","metadata":{"agent_spiffe_id":"spiffe://carverauto.dev/ns/edge/docker-agent-e2e-02"}}'curl -s -X POST http://localhost:18090/api/admin/edge-packages/$PACKAGE_ID/download -H ... -d '{"download_token":"..."}' --output edge-package.tar.gzdocker/compose/edge-poller-restart.sh --env-file edge-poller.envto bootstrap./api/admin/edge-packages/$AGENT_IDstays activated while KV sweeps run.Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3474787185
Original created: 2025-10-31T20:28:15Z
Additional Edge Onboarding Improvements
Following up on the initial E2E validation, we've made significant improvements to the edge onboarding process:
🎯 Completed Work
1. Organized Edge E2E Structure
/docker/compose/edge-e2e/directory structure2. Idempotent Setup Script
Created
docker/compose/edge-e2e/setup-edge-e2e.sh:./setup-edge-e2e.sh --package-id <uuid>3. Package Management Utility
Created
docker/compose/edge-e2e/manage-packages.sh:/api/admin/edge/packagesto/api/admin/edge-packages4. Critical Bug Fixes
SQL DELETE Syntax Error (pkg/db/pollers.go:195):
DELETE FROM table(pollers)toALTER TABLE pollers DELETELinting Errors:
RecordActivation()function to reduce cyclomatic complexity (31 → <15)findPackageForActivation(),updatePackageActivation(),recordActivationEvent()5. Comprehensive Documentation
Created three documentation files:
README.md- Quick reference and troubleshootingSETUP_GUIDE.md- Complete setup process with all configuration detailsFRICTION_POINTS.md- Detailed analysis of issues and proposed solutions🔍 Friction Points Identified
Critical (Fixed):
Critical (Needs Implementation):
known_pollersConfigMapMedium (Automated):
Low Priority:
📁 Files Created/Modified
docker/compose/edge-e2e/
├── setup-edge-e2e.sh ✅ NEW - Idempotent setup automation
├── manage-packages.sh ✅ NEW - Package management CLI
├── README.md ✅ NEW - Quick reference
├── SETUP_GUIDE.md ✅ NEW - Complete documentation
├── FRICTION_POINTS.md ✅ NEW - Detailed friction analysis
└── docker-compose.edge-e2e.yml ✅ MOVED - From project root
pkg/db/pollers.go ✅ FIXED - SQL DELETE syntax
pkg/core/edge_onboarding.go ✅ FIXED - Linting errors
🎯 Recommended Next Steps
allowed_poller_idto edge_packages table to eliminate manual ConfigMap updatesserviceradar-cli edgecommands for package management✅ What Works Now
The edge onboarding process is now well-organized, documented, and largely automated!
Imported GitHub comment.
Original author: @mfreeman451
Original URL: https://github.com/carverauto/serviceradar/issues/1911#issuecomment-3474876153
Original created: 2025-10-31T20:55:35Z
✅ E2E validation completed successfully.
Follow-up work to eliminate edge onboarding friction points is tracked in:
Closing this issue as the validation work is complete.