Jimbru is an Privacy Oriented web analytics Server which is built with FastAPI and Deta Base as DB.
Jimbru is heavily inspired by Shynet which is also an Analytics server built with Django.
Not for Production Level use. It's hacky to the core. I made it for a Personal Use and doesn't have any fancy features.
- Lightweight
- Privacy Oriented
- Easily Deployable (on deta.sh)
- 6 lines of JS code gets the current URL, referrer and load time.
- Charts with Frappe Charts ๐
- Jinja2 Templating and Tailwind CSS for Frontend
- Cookie based Authentication
- User OS and device from
user-agent
header - user location and network from user ip header
- Caching
- Bounce rate
- Session Time
- Unique Hits
Before deploying you need to get some Credentials
-
Signup for an account in https://deta.sh
-
Create a new Project
-
Get the Project Key and save it in the
.env
file as below -
Install the Deta cli. This is for deploying to Deta.
-
Create a
.env
file inside theapp/routes
directory with the following keysTITLE=<title of the site> DOMAIN=<domain of the deployed server> PKEY=<Deta Project Key> PNAME=<Deta Base DB Name> SECRET_JWT=<Secret for JWT. Get than withโ import os; print(os.urandom(24).hex())> USERNAME=<username for authenticating> PASSWORD=<password for authenticating>
The
PNAME
can be anything.
- Fork/Clone this Repository
- You can run the code locally by installing the dependencies inside the
app
directory and runninguvicorn main:app --reload
inside theapp
directory. - Inside the
app
directory you can create a new Micro with$ deta new
. This will create a new Micro. You will get the domian from the output of the command. Save that domain in theDOMAIN
key in the.env
file, without a trailing/
. - Run
$ deta update -e routes/.env
to update the environment variables in the micro. - Run
$ deta deploy
inside the app directory and the code will be deployed. - Profit
Add a <script>
tag for the site
<script src="https://<DOMAIN>/a.js" type="text/javascript"></script>
- Caching
- Better Auth
- Session Time
MIT