Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
0xacab.org/leap/tunnel-telemetry
A PoC implementation for a Open Tunnel Telemetry collector and client. See the [spec].
tunnel-telemetry
collector, OONI acts as a secondary collector.go install github.com/ainghazal/tunnel-telemetry/cmd/tt-server@latest
tt-server
This will run a test http
server in port :8080
.
You can enable autotls
to fetch LetsEncrypt certificates.
tt-server --autotls --hostname collector.example.org
tt-server --help
All the configuration flags can be passed as env variables:
AUTOTLS=true HOSTNAME=collector.example.org tt-server
Or as a yaml
configuration file:
cat /home/user/ttserver/config.yaml
autotls: true
hostname: collector.asdf.network
And then pass that config file to the tt-server
invocation:
tt-server --config /home/user/ttserver/config.yaml
The default configuration location is /etc/tunneltelemetry/config.yaml
; any flag or environment variable will take precedence over the options set in the config file.
autotls
: if true, it will configure LetsEncrypt certificates.autotls-cache-dir
: a dir to cache autotls material (default: "/var/www/.cache").collector-id
: if present, this unique identifier will be added to all reports as an extra annotation. This can be useful to later on query all reports submitted by a given collector.hostname
: the hostname to configure autotls
certs.listen
: the address to listen on (:8080
by default; 443
if autotls is used).A minimal report is a json containing only three mandatory fields:
report-type
: MUST be tunnel-telemetry
.time
: MUST be the initial timestamp for the observation contained in the report. The collector will not process reports sent from too far in the future or the past.endpoint
: MUST be the endpoint that the client attempted to connect to, in the format protocol://ip_address:port
.$ cat report.json
{
"report-type": "tunnel-telemetry",
"time": "2024-04-12T00:00:00Z",
"endpoint": "ss://1.1.1.1:443",
"config": {"prefix": "xx"}
}
$ curl -X POST \
-H 'Content-Type: application/json' \
-H 'X-Forwarded-For: 2.3.4.5' \
-d @report.json \
http://localhost:8080/report
A few optional fields are also understood:
config
: an arbitrary map[str]str
containing relevant configurations used in the connection. Sensitive information should not be sent here.duration_ms(int)
: a duration, in milliseconds. This is the delta between the initial time, time
, and the success or failure indicated by the report.failure
: in the form {"op": "operation.detail", "msg": "error message", "posix_error": "standard posix error"}
, or null
. A missing failure
field is understood as a successful connection.uuid
: the client can add an uuid
. If empty, one will be generated.Upon a successful processing, and possibly relaying the report, the collector returns a scrubbed report:
{
"report-type": "tunnel-telemetry",
"uuid": "fbf902ee-5d78-43cd-af39-b9b297a0d2f7",
"ooni-measurement-id": "20240422144155.458035_IT_tunneltelemetry_84954cf1a5baeb91",
"ooni-measurement-link": "https://explorer.ooni.org/m/20240422144155.458035_IT_tunneltelemetry_84954cf1a5baeb91",
"time": "2024-04-18T00:00:00Z",
"collector_id": "uenohphi7oqueiZohl2V",
"endpoint_port": 443,
"endpoint_asn": "AS13335",
"endpoint_cc": "AU",
"proto": "ss",
"config": {
"prefix": "xx"
},
"client_asn": "AS50304",
"client_cc": "NO",
"sampling_rate": 1
}
In this case, the collector was configured to relay reports to the OONI upstream collector, and it's adding an OONI Measurement Link where we can share the report in the public OONI Explorer.
For simplicity, it's assumed that the collector is not blocked, and that clients report to the collector using their public IP. It's likely that we'll have to reconsider this point, because from a privacy perspective perhaps it does not make much sense to abandon the tunnel to submit a report. This probably will lead us to separate discovery of IP and geolocation itself.
⚠️ For the time being, geolocation in the tunnel-telemetry
server only works when listening directly on a port exposed to the internet.
For working behind proxies, the right setting must be configured in the instantiation of the echo server (TBD).
FAQs
Unknown package
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.