Umami is a simple, fast, privacy-focused alternative to Google Analytics.
Go to file
Hugo Müller-Downing 34d82166e4 Trim Docker image size
* Only copy production node dependencies into image
* Use multi-stage build to make use of node dependency cache
* Use non-root user
2020-09-22 22:30:37 +10:00
.github Convert buttons to links. 2020-09-15 19:16:05 -07:00
assets New icons for theme button. 2020-09-20 15:42:01 -07:00
components Responsive CSS updates. 2020-09-21 21:34:55 -07:00
hooks Updated color selection. Added loading to fetch hook. 2020-09-20 11:28:38 -07:00
lang Merge pull request #201 from bilguun0203/master 2020-09-22 03:06:08 -07:00
lib Updated languages. 2020-09-21 11:26:13 -07:00
pages Refactor tracker. 2020-09-18 13:40:46 -07:00
prisma Enable public website sharing. 2020-08-15 01:17:15 -07:00
public Add tracker build to main build. 2020-08-22 22:03:39 -07:00
redux Dark mode. 2020-09-20 01:33:39 -07:00
scripts Clear out the build directory before compiling lang. 2020-09-19 09:12:44 -07:00
sql MySQL query optimization. Added loading component. 2020-08-27 23:45:37 -07:00
styles Responsive CSS updates. 2020-09-21 21:34:55 -07:00
tracker Renamed methods in tracker. 2020-09-18 15:26:45 -07:00
.dockerignore for better local building performance 2020-08-23 14:07:01 +12:00
.eslintrc.json Updated pages and referrer filters to merge urls. 2020-08-22 19:05:07 -07:00
.gitignore Refactor tracker. 2020-09-18 13:40:46 -07:00
.prettierignore
.prettierrc.json
.stylelintrc.json
docker-compose.yml Use GitHub Container Registry for Docker images 2020-09-06 15:48:46 +10:00
Dockerfile Trim Docker image size 2020-09-22 22:30:37 +10:00
jsconfig.json
LICENSE Added license. 2020-08-17 00:05:57 -07:00
next.config.js Added version to footer. CSS and locale fixes. 2020-09-09 16:12:29 -07:00
package.json Bump version. 2020-09-22 03:07:07 -07:00
postcss.config.js
README.md Added page not found string. 2020-09-12 09:59:19 -07:00
rollup.tracker.config.js Refactor tracker. 2020-09-18 13:40:46 -07:00
yarn.lock Updated packages. 2020-09-21 21:39:29 -07:00

umami

Umami is a simple, fast, website analytics alternative to Google Analytics.

Getting started

A detailed getting started guide can be found at https://umami.is/docs/

Installing from source

Requirements

  • A server with Node.js 10.13 or newer
  • A database (MySQL or Postgresql)

Get the source code and install packages

git clone https://github.com/mikecao/umami.git
cd umami
npm install

Create database tables

Umami supports MySQL and Postgresql. Create a database for your Umami installation and install the tables with the included scripts.

For MySQL:

mysql -u username -p databasename < sql/schema.mysql.sql

For Postgresql:

psql -h hostname -U username -d databasename -f sql/schema.postgresql.sql

This will also create a login account with username admin and password umami.

Configure umami

Create an .env file with the following

DATABASE_URL=(connection url)
HASH_SALT=(any random string)

The connection url is in the following format:

postgresql://username:mypassword@localhost:5432/mydb

mysql://username:mypassword@localhost:3306/mydb

The HASH_SALT is used to generate unique values for your installation.

Build the application

npm run build

Start the application

npm start

By default this will launch the application on http://localhost:3000. You will need to either proxy requests from your web server or change the port to serve the application directly.

Installing with Docker

To build the umami container and start up a Postgres database, run:

docker-compose up

Alternatively, to pull just the Umami Docker image with PostgreSQL support:

docker pull ghcr.io/mikecao/umami:postgresql-latest

Or with MySQL support:

docker pull ghcr.io/mikecao/umami:mysql-latest

Getting updates

To get the latest features, simply do a pull, install any new dependencies, and rebuild:

git pull
npm install
npm run build

License

MIT