From f35ebec7c64f49b4dc12938e59bee98ed25c912d Mon Sep 17 00:00:00 2001
From: r3nor <67505421+r3nor@users.noreply.github.com>
Date: Thu, 18 Aug 2022 15:31:00 +0200
Subject: [PATCH] Readme redistribution and reorganisation (#485)
* redistribute and organize readme
* Fix typos
* Change developers to development
* Remove mobile app emoji
* Multiple changes
- Removed the .env example inbody to link to the .env.example file; this way it won't be needed to change the readme if the .env file changes and the readme gets shorter.
- Redistributed the steps:
- Inline instead of tables
- bullets in steps
- Fix wording
---
README.md | 255 ++++++++++++++++++++++--------------------------------
1 file changed, 103 insertions(+), 152 deletions(-)
diff --git a/README.md b/README.md
index 11289b4e05..c6d6c0bede 100644
--- a/README.md
+++ b/README.md
@@ -1,3 +1,9 @@
+
Immich
+ High performance self-hosted photo and video backup solution.
+
+
+
+
@@ -14,75 +20,66 @@
-
-
-
-
-
-
-
+
-# Immich
-
-**High performance self-hosted photo and video backup solution.**
-
-![](https://media.giphy.com/media/y8ZeaAigGmNvlSoKhU/giphy.gif)
-
-Loading ~4000 images/videos
-
-## Screenshots
-
-### Mobile
-
-
-
-
-
-
-
-
-
-
-### Web
-
-
-
-
-
-# Note
-
-**!! NOT READY FOR PRODUCTION! DO NOT USE TO STORE YOUR ASSETS !!**
-
-This project is under heavy development, there will be continuous functions, features and api changes.
+## Content
+- [Features](#features)
+- [Screenshots](#screenshots)
+- [Installation](#installation)
+- [Mobile App](#-mobile-app)
+- [Development](#development)
+- [Support](#support)
+- [Known Issues](#known-issues)
# Features
+> ⚠️ WARNING: **NOT READY FOR PRODUCTION! DO NOT USE TO STORE YOUR ASSETS**. This project is under heavy development, there will be continuous functions, features and api changes.
+
| | Mobile | Web |
-| - | - | - |
-| Upload and view videos and photos | Yes | Yes
-| Auto backup when the app is opened | Yes | N/A
-| Selective album(s) for backup | Yes | N/A
-| Download photos and videos to local device | Yes | Yes
-| Multi-user support | Yes | Yes
-| Album | Yes | Yes
-| Shared Albums | Yes | Yes
-| Quick navigation with draggable scrollbar | Yes | Yes
-| Support RAW (HEIC, HEIF, DNG, Apple ProRaw) | Yes | Yes
-| Metadata view (EXIF, map) | Yes | Yes
-| Search by metadata, objects and image tags | Yes | No
-| Administrative functions (user management) | N/A | Yes
+| - | - | - |
+| ☁️ Upload and view videos and photos | Yes | Yes
+| 🔄 Auto backup when the app is opened | Yes | N/A
+| ☑️ Selective album(s) for backup | Yes | N/A
+| ⬇️ Download photos and videos to local device | Yes | Yes
+| 👪 Multi-user support | Yes | Yes
+| 🖼️ Album | Yes | Yes
+| 🤝 Shared Albums | Yes | Yes
+| 🚀 Quick navigation with draggable scrollbar | Yes | Yes
+| 🗃️ Support RAW (HEIC, HEIF, DNG, Apple ProRaw) | Yes | Yes
+| 🧭 Metadata view (EXIF, map) | Yes | Yes
+| 🔎 Search by metadata, objects and image tags | Yes | No
+| ⚙️ Administrative functions (user management) | N/A | Yes
-# System Requirement
+
-**OS**: Preferred unix-based operating system (Ubuntu, Debian, MacOS...etc).
+# Screenshots
-**RAM**: At least 2GB, preferred 4GB.
+### Mobile
+| | | | | |
+| - | - | - | - | - |
+| Login with custom URL
| Backup Settings
| Backup selection
| Home Screen
| Curated search
|
+| Shared albums
| EXIF info
| Loading ~4000 images/videos
|
-**Core**: At least 2 cores, preferred 4 cores.
+### Web
+| Home Dashboard | Image view |
+| - | - |
+| | |
-# Technology Stack
+
+
+
+# Project Details
+## 💾 System Requirements
+
+- **OS**: Preferred unix-based operating system (Ubuntu, Debian, MacOS...etc).
+
+- **RAM**: At least 2GB, preferred 4GB.
+
+- **Core**: At least 2 cores, preferred 4 cores.
+
+## 🔩 Technology Stack
There are several services that compose Immich:
@@ -93,15 +90,18 @@ There are several services that compose Immich:
5. **Nginx** - Load balancing and optimized file uploading.
6. **TensorFlow** - Object Detection (COCO SSD) and Image Classification (ImageNet).
-# Installing
-## One-step installation - for evaluating only
+
+
+# Installation
+
+## Testing One-step installation (not recommended for production)
+
+> ⚠️ *This installation method is for evaluating Immich before futher customization to meet the users' needs.*
*Applicable system: Ubuntu, Debian, MacOS*
-*This installation method is for evaluating Immich before futher customization to meet the users' needs.*
-
-In the shell, from the directory of your choice, run the following command:
+- In the shell, from the directory of your choice, run the following command:
```bash
curl -o- https://raw.githubusercontent.com/immich-app/immich/main/install.sh | bash
@@ -114,116 +114,70 @@ The web application will be available at `http://:2283`, and
The directory which is used to store the backup file is `./immich-app/immich-data`.
-## Customize installation - for production usage
+
+
+## Custom installation (Recommended)
### Step 1 - Download necessary files
-Create a directory called `immich-app` and cd into it. Then
+- Create a directory called `immich-app` and cd into it.
-Get `docker-compose.yml`
+- Get `docker-compose.yml`
```bash
wget https://raw.githubusercontent.com/immich-app/immich/main/docker/docker-compose.yml
```
-Get `.env`
+- Get `.env`
```bash
wget -O .env https://raw.githubusercontent.com/immich-app/immich/main/docker/.env.example
```
-### Step 2 - Populate .env file with customed information
+### Step 2 - Populate .env file with custom information
-* Populate customised database information if necessary.
+See the example .env
file
+
+* Populate custom database information if necessary.
* Populate `UPLOAD_LOCATION` as prefered location for storing backup assets.
-* Populate a secret value for `JWT_SECRET`
-* [Optional] Populate Mapbox value.
-
-**Example**
-
-```bash
-###################################################################################
-# Database
-###################################################################################
-DB_USERNAME=postgres
-DB_PASSWORD=postgres
-DB_DATABASE_NAME=immich
-
-###################################################################################
-# Upload File Config
-###################################################################################
-UPLOAD_LOCATION=
-
-###################################################################################
-# JWT SECRET
-###################################################################################
-JWT_SECRET=randomstringthatissolongandpowerfulthatnoonecanguess
-
-###################################################################################
-# MAPBOX
-####################################################################################
-# ENABLE_MAPBOX is either true of false -> if true, you have to provide MAPBOX_KEY
-ENABLE_MAPBOX=false
-MAPBOX_KEY=
-```
+* Populate a secret value for `JWT_SECRET`, you can use this command: `openssl rand -base64 128`
+* [Optional] Populate Mapbox value to use reverse geocoding.
### Step 3 - Start the containers
-Run `docker-compose up` or `docker compose up` (based on your docker's version)
+- Run `docker-compose up` or `docker compose up` (based on your docker's version)
### Step 4 - Register admin user
-Navigate to the web at `http://:2283` and follow the prompts to register admin user.
-
-
+- Navigate to the web at `http://:2283` and follow the prompts to register admin user.
+
-
+
-Additional accounts on the server can be created by the admin account.
-
-
-
-
+- You can add and manage users from the administration page.
+
+
+
### Step 5 - Access the mobile app
-Login the mobile app with the server endpoint URL at `http://:2283/api`
-
-
+- Login the mobile app with the server endpoint URL at `http://:2283/api`
+
-
+
-## Mobile app
+
-## F-Droid
-You can get the app on F-droid by clicking the image below.
+# Mobile app
-[](https://f-droid.org/packages/app.alextran.immich)
+| F-Droid | Google Play | iOS |
+| - | - | - |
+| |
|
|
+
+> *The App version might be lagging behind the latest release due to the review process.*
-## Android
-
-#### Get the app on Google Play Store [here](https://play.google.com/store/apps/details?id=app.alextran.immich)
-
-*The App version might be lagging behind the latest release due to the review process.*
-
-
-
-
-
-## iOS
-
-#### Get the app on Apple AppStore [here](https://apps.apple.com/us/app/immich/id1613945652):
-
-*The App version might be lagging behind the latest release due to the review process.*
-
-
-
-
-
-
+
# Development
@@ -244,31 +198,28 @@ npm run api:generate # Run from server directory
```
You can find the generated client SDK in the [`web/src/api`](web/src/api) for Typescript SDK and [`mobile/openapi`](mobile/openapi) for Dart SDK.
+
+
+
# Support
-If you like the app, find it helpful, and want to support me to offset the cost of publishing to AppStores, you can sponsor the project with [**one time**](https://github.com/sponsors/alextran1502?frequency=one-time&sponsor=alextran1502) or monthly donation from [**Github Sponsor**](https://github.com/sponsors/alextran1502)
+If you like the app, find it helpful, and want to support me to offset the cost of publishing to AppStores, you can sponsor the project with [**one time**](https://github.com/sponsors/alextran1502?frequency=one-time&sponsor=alextran1502) or monthly donation from [**Github Sponsor**](https://github.com/sponsors/alextran1502).
You can also donate using crypto currency with the following addresses:
-
-
-1FvEp6P6NM8EZEkpGUFAN2LqJ1gxusNxZX
-
+ Bitcoin: 1FvEp6P6NM8EZEkpGUFAN2LqJ1gxusNxZX
-
-
-
-
-addr1qyy567vqhqrr3p7vpszr5p264gw89sqcwts2z8wqy4yek87cdmy79zazyjp7tmwhkluhk3krvslkzfvg0h43tytp3f5q49nycc
-
-
+ Cardano: addr1qyy567vqhqrr3p7vpszr5p264gw89sqcwts2z8wqy4yek87cdmy79zazyjp7tmwhkluhk3krvslkzfvg0h43tytp3f5q49nycc
This is also a meaningful way to give me motivation and encouragement to continue working on the app.
Cheers! 🎉
-# Known Issue
+
+
+
+# Known Issues
## TensorFlow Build Issue