-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add the ability to distinguish unique installations to anonymous usage report #4077
Comments
For context, the Alloy project uses a UUID they call a "seed". This seed is saved on disk on the user system as a "seed file". cc @joanlopez |
The most challenging part I see here is to consider what you @oleiade included in the risks section, especially considering that this is an open-source project, which makes it harder to keep some secrets unrevealed. However, I'm not sure quite sure it does really worth, because as of now we're not doing anything to prevent fake data at the report level, and I see this just a subcase of that. Do you have any particular idea on how to solve this? |
@joanlopez I have a couple of ideas, but I don't necessarily think any of them are worth the hassle:
In general I don't really think any of those are worth it? Would you agree? |
Yeah, I agree, as I said before. Indeed, if we want to implement any sort of hashing checks, I'd probably suggest to do it for the whole payload, and not only for this concrete field, cause any part of the report could be altered. The problem is that there's probably not really safe and cheap/easy way to do so. Just for the id, it's true that for instance your first suggestion would probably work, and would be mostly safe, but still I have serious doubts about it really worthing it because of the aforementioned reasons. |
I agree. My preference would be for adopting the same UUID approach as Alloy, and address any issues as they occur incrementally 👍 |
Feature Description
Problem Definition
k6 currently collects anonymous usage information as part of its opt-out usage report (--no-usage-report). This report helps us understand k6 usage patterns to improve the tool and guide development decisions.
To better support the k6 development process, we would like to measure the number of active installations of k6 over time.
This requires the ability to track when a given installation of k6 (on a machine that has not opted out of the usage report) was last used. Since each usage report already includes a timestamp, the only additional functionality needed is a mechanism to distinguish one installation from another.
Considerations
The identifier introduced to enable this functionality would:
• Be anonymous.
• Be stored locally on the machine running k6.
• Be included in the usage report only if telemetry has not been opted out.
This identifier:
• Will not contain any personally identifiable information (PII) or system-specific data (e.g., username, hostname, IP address, etc.).
• Will comply with GDPR and other relevant privacy laws by being designed to avoid user identification and to remain strictly anonymous.
Risks
Why This Matters
Having a reliable measure of active installations will:
• Allow us to make more informed decisions about features and improvements.
• Help us better understand k6’s reach and growth while respecting user privacy.
Suggested Solution (optional)
Inspiration & References
ID generation
Proposed solution(s)
TODO
Already existing or connected issues / PRs (optional)
#4038
The text was updated successfully, but these errors were encountered: