Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/milesmcc/shynet
Modern, privacy-friendly, and detailed web analytics that works without cookies or JS.
https://github.com/milesmcc/shynet
a17t analytics django docker kubernetes monitoring noscript privacy python security self-hosted web-analytics
Last synced: about 20 hours ago
JSON representation
Modern, privacy-friendly, and detailed web analytics that works without cookies or JS.
- Host: GitHub
- URL: https://github.com/milesmcc/shynet
- Owner: milesmcc
- License: apache-2.0
- Created: 2020-04-09T17:51:58.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-07-06T00:46:29.000Z (5 months ago)
- Last Synced: 2024-12-11T13:07:29.017Z (about 20 hours ago)
- Topics: a17t, analytics, django, docker, kubernetes, monitoring, noscript, privacy, python, security, self-hosted, web-analytics
- Language: Python
- Homepage:
- Size: 34 MB
- Stars: 2,941
- Watchers: 27
- Forks: 193
- Open Issues: 56
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-foss-alternatives - Shynet - Modern, privacy-friendly, and detailed web analytics that works without cookies or JS. [๐, Apache License 2.0]. (Web / Web analytics (Google Analytics alternatives))
- awesome-selfhosted-product - Shynet - A no cookies web analytics tool for personal projects and small to medium size websites. `Apache-2.0` `Python/Docker` (Analytics Tools / Web Traffic Analytics)
- Awesome-Private-Browsing - Shynet - friendly, and detailed web analytics that works without cookies or JS. (Web Analytics / TLS Fingerprinting)
- open-production-web-projects - Shynet - Modern, privacy-friendly, and cookie-free web analytics. (Python / Django)
- awesome-privacy - Shynet - friendly, and detailed web analytics that works without cookies or JS. (Website analytics / Metadata removal)
- awesome-privacy - Shynet - Modern, privacy-friendly, and detailed web analytics that works without cookies or JS. (Analytics)
- fucking-awesome-privacy - Shynet - Modern, privacy-friendly, and detailed web analytics that works without cookies or JS. (Analytics)
- awesome-homelab - Shynet - friendly, and detailed web analytics that works without cookies or JS. | (Apps / X)
README
Modern, privacy-friendly, and cookie-free web analytics.
Getting started ยป
Screenshots โข Features โข Office Hours
## Motivation
There are a _lot_ of web analytics tools. Unfortunately, most of them come with the following caveats:
* They require handing all of your visitors' info to a third-party company
* They use cookies to track visitors across sessions, so you need to have those annoying cookie notices
* They collect so much personal data that even the NSA is jealous
* They are closed source and/or expensive, often with limited data portability
* They are hard to useShynet has **none** of these caveats. You host it yourself, so the data is _yours_. It works without cookies, so you don't need any intrusive cookie notices. It collects just enough data to be useful, but not enough to be creepy. It's open source and _intended_ to be self-hosted. And you may even find the interface easy to use.
> **Shynet** is a portmanteau of "Skynet" and "shy." The idea is that it gives you loads of useful information (Skynet) while also respecting your visitors' privacy (shy).
## Screenshots
_Note: These screenshots have been edited to hide sensitive data. The "real" Shynet has a lot more pages and information available, but hopefully this gives you an idea of the general look and feel of the tool._
![Shynet's homepage](images/homepage.png)
_Shynet's homepage, where you can see all of your services at a glance._![A service page](images/service.png)
_A real service page, where you can see higher-level details about a site._Not shown: management view, session view, full service view. (You'll need to install Shynet for yourself to see those!)
> **Shynet is built using [a17t](https://github.com/milesmcc/a17t),** an atomic design library. Customization and extension is simple; [learn more about a17t](https://github.com/milesmcc/a17t).
## Features
#### Architecture
* **Runs on a single machine** โ Because it's so small, Shynet can easily run as a single docker container on a single small VPS
* **...or across a giant Kubernetes cluster** โ For higher traffic installations, Shynet can be deployed with as many parallelized ingress nodes as needed, with Redis caching and separate backend workers for database IO
* **Built using Django** โ Shynet is built using Django, so deploying, updating, and migrating can be done without headaches
* **Multiple users and sites** โ A single Shynet instance can support multiple users, each tracking multiple different sites#### Tracking
* **JavaScript not required** โ It will fallback to using a 1x1 transparent tracking pixel if JavaScript isn't available
* **Lightweight** โ The [tracking script](/shynet/analytics/templates/analytics/scripts/page.js) weighs less than a kilobyte (and doesn't look like your typical tracking script)
* **Generally not blocked** โ Because you host Shynet yourself, it tends not to be on ad block lists
* **Primary-key integration** โ You can easily associate visitors in Shynet with their user accounts on your site (if that's something you want)#### Metrics
Here's the information Shynet can give you about your visitors:
* **Hits** โ how many pages on your site were opened/viewed
* **Sessions** โ how many times your site was visited (essentially a collection of hits)
* **Page load time** โ how long the pages on your site look to load
* **Bounce rate** โ the percentage of visitors who left after just one page
* **Duration** โ how long visitors stayed on the site
* **Referrers** โ the links visitors followed to get to your site
* **Locations** โ the relative popularity of all the pages on your site
* **Operating system** โ your visitors' OS (from user agent)
* **Browser** โ your visitors' browser (from user agent)
* **Geographic location & network** โ general location of your visitors (from IP)
* **Device type** โ whether your visitors are using a desktop, tablet, or phone (from user agent)#### Workflow
* **Collaboration built-in** โ Administrators can easily share services with other users, as well
* **Accounts (or not)** โ Shynet has a fully featured account management workflow (powered by [Django Allauth](https://github.com/pennersr/django-allauth/))## Recommendations
Shynet isn't for everyone. It's great for personal projects and small to medium size websites, but hasn't been tested with ultra-high traffic sites. It also requires a fair amount of technical know-how to deploy and maintain, so if you need a one-click solution, you're best served with other tools.
## Concepts
Shynet is pretty simple, but there are a few key terms you need to know in order to use it effectively:
**Services** are the properties on the web you'd like to track. These generally correspond to websites or single top-level domains. Shynet generates one tracking embed per service.
**Hits** are a single page-load on one of your services.
**Sessions** are a collection of hits (or just one) that are made by the same browser in a short period of time.
## Installation
You can find instructions on getting started and usage in the [Usage Guide](GUIDE.md#installation). Out of the box, we support deploying via a simple Docker container, docker-compose, Heroku, or Kubernetes (see [kubernetes](/kubernetes)).
## FAQ
**Does Shynet respond to Do Not Track (DNT) signals?** Yes. While there isn't any standardized way to handle DNT requests, Shynet allows you to specify whether you want to collect any data from users with DNT enabled on a per-service basis. (By default, Shynet will _not_ collect any data from users who specify DNT.)
**Is this GDPR compliant?** It depends on how you use it. If you're worried about GDPR, you should talk to a lawyer about your particular data collection practices. I'm not a lawyer. (And this isn't legal advice.)
## Troubleshooting
Having trouble with Shynet? Check out the [troubleshooting guide](GUIDE.md#troubleshooting), or [create an issue](https://github.com/milesmcc/shynet/issues/new) if you think you found a bug in Shynet itself (or have a feature suggestion).
## Roadmap
To see the upcoming planned features, check out the repository's [roadmap project](https://github.com/milesmcc/shynet/projects/1). Upcoming features include data aggregation through rollups, anomaly detection, detailed data exports, two-factor authentication, and a data deletion tool.
## In the Wild
These sites use Shynet to monitor usage without violating visitors' privacy: [PolitiTweet](https://polititweet.org), [Miles' personal site](https://miles.land), [a17t](https://a17t.miles.land), [Lensant](https://lensant.com), [WhoAreMyRepresentatives.org](https://whoaremyrepresentatives.org), and more. (Want to add your site to this list? Send a PR.)
## Contributing
Are you interested in contributing to Shynet? Just send a pull request! Maybe once the project matures there will be more detailed contribution guidelines, but for now just send the code this way and we'll make sure it meets our standards together. Just know that by contributing, you agree to share all of your contributions under the same license as the project (see [LICENSE](LICENSE)). And always be sure to follow the [Code of Conduct](https://github.com/milesmcc/shynet/blob/master/CODE_OF_CONDUCT.md).
## License
Shynet is made available under the [Apache License, version 2.0](LICENSE).
---
Shynet was created by [Miles McCain](https://miles.land) ([@MilesMcCain](https://twitter.com/MilesMcCain)) at the [Recurse Center](https://recurse.com) using [a17t](https://a17t.miles.land).