2018-12-03 22:38:25 +01:00
# PiGallery2
2017-06-03 22:35:47 +02:00
[![npm version ](https://badge.fury.io/js/pigallery2.svg )](https://badge.fury.io/js/pigallery2)
2017-07-03 19:17:49 +02:00
[![Build Status ](https://travis-ci.org/bpatrik/pigallery2.svg?branch=master )](https://travis-ci.org/bpatrik/pigallery2)
2016-05-02 10:07:42 +02:00
[![Heroku ](https://heroku-badge.herokuapp.com/?app=pigallery2&style=flat )](https://pigallery2.herokuapp.com)
2018-12-06 13:50:55 +01:00
[![Docker Build Status ](https://img.shields.io/docker/build/bpatrik/pigallery2.svg )](https://hub.docker.com/r/bpatrik/pigallery2/)
2018-11-30 15:36:42 +01:00
[![dependencies Status ](https://david-dm.org/bpatrik/pigallery2/status.svg )](https://david-dm.org/bpatrik/pigallery2)
[![devDependencies Status ](https://david-dm.org/bpatrik/pigallery2/dev-status.svg )](https://david-dm.org/bpatrik/pigallery2?type=dev)
2016-03-12 14:21:25 +01:00
2018-12-06 13:50:55 +01:00
2018-12-03 22:38:25 +01:00
Homepage: http://bpatrik.github.io/pigallery2/
2017-03-22 19:38:39 +01:00
This is a directory-first photo gallery website, optimised for running on low resource servers (especially on raspberry pi)
2016-03-14 13:30:15 +01:00
2017-06-04 15:25:22 +02:00
## Live Demo
2019-01-02 21:22:03 +01:00
Live Demo @ heroku: https://pigallery2.herokuapp.com/
2018-12-02 22:30:49 +01:00
- the demo page **first load** might take up **30s** : the time while the free webservice boots up
2017-03-22 19:38:39 +01:00
2018-05-15 20:01:11 -04:00
## Table of contents
2018-12-22 00:29:05 +01:00
1. [Getting started ](#1-getting-started-on-raspberry-pi )
2. [Translate the page to your own language ](#2-translate-the-page-to-your-own-language )
3. [Feature list ](#3-feature-list )
2019-02-25 11:50:27 +01:00
4. [Suggest/endorse new features ](#4-suggestendorse-new-features )
2019-02-25 11:41:56 +01:00
5. [Known errors ](#5-known-errors )
6. [Credits ](#6-credits )
2016-03-14 13:30:15 +01:00
2017-03-22 19:38:39 +01:00
2018-05-15 20:01:11 -04:00
2018-12-06 09:52:04 +01:00
## 1. Getting started (on Raspberry Pi)
### 1.1 Direct Install
### 1.1.0 [Install NodeJs](https://nodejs.org/en/download/)
2017-06-04 15:25:22 +02:00
Download and extract
```bash
2018-12-02 22:15:39 +01:00
curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash -
sudo apt-get install -y nodejs
2017-06-04 15:25:22 +02:00
```
2018-12-02 22:15:39 +01:00
2018-12-06 09:52:04 +01:00
Full node install on raspberry pi description: https://www.w3schools.com/nodejs/nodejs_raspberrypi.asp
2017-06-04 15:25:22 +02:00
2018-12-06 13:50:55 +01:00
### 1.1.1 Install PiGallery2
#### 1.1.1-a Install from release
2017-07-12 18:35:23 +02:00
2017-06-04 15:25:22 +02:00
```bash
cd ~
2019-01-26 22:44:37 -05:00
wget https://github.com/bpatrik/pigallery2/releases/download/1.5.6/pigallery2.zip
2019-01-26 15:00:01 -05:00
unzip pigallery2.zip -d pigallery2
2018-05-15 20:01:11 -04:00
cd pigallery2
2017-07-12 18:35:23 +02:00
npm install
```
2018-12-06 13:50:55 +01:00
#### 1.1.1-b Install from source
2017-07-12 18:35:23 +02:00
```bash
cd ~
wget https://github.com/bpatrik/pigallery2/archive/master.zip
unzip master.zip
2018-05-15 20:01:11 -04:00
cd pigallery2-master # enter the unzipped directory
2017-06-04 15:25:22 +02:00
npm install
```
2018-12-05 21:55:11 +01:00
**Note**: if you run `npm run build-release` , it creates a clean, minified, production ready version from the app in the `release` folder, that is ready to deploy.
2017-07-12 18:35:23 +02:00
2018-12-06 13:50:55 +01:00
#### 1.1.2 Run PiGallery2
2017-06-04 15:25:22 +02:00
```bash
npm start
```
2018-12-05 21:55:11 +01:00
To configure it, run `PiGallery2` first to create `config.json` file, then edit it and restart.
The app has a nice UI for settings, you may use that too.
2017-07-25 23:39:50 +02:00
Default user: `admin` pass: `admin`
2017-06-04 15:25:22 +02:00
2018-12-06 09:52:04 +01:00
### 1.2 Run with Docker
If you have `docker` and don't want to install all the dependencies, use this:
2018-12-05 23:16:14 +01:00
```bash
docker run \
-p 80:80 \
-e NODE_ENV=production \
-v < path to your config file folder > /config.json:/pigallery2-release/config.json \
2019-01-17 09:33:09 +01:00
-v < path to your db file folder > /sqlite.db:/pigallery2-release/sqlite.db \
2018-12-05 23:16:14 +01:00
-v < path to your images folder > :/pigallery2-release/demo/images \
2018-12-06 09:52:04 +01:00
-v < path to your temp folder > :/pigallery2-release/demo/TEMP \
2019-01-18 00:27:13 +01:00
bpatrik/pigallery2:1.5.6-stretch
2018-12-05 23:16:14 +01:00
```
2019-01-17 16:28:50 +01:00
Make sure that a file at `<path to your config file folder>/config.json` and `sqlite.db` files exists before running it.
You do not need the `<path to your db file folder>/sqlite.db` line if you don't use the sqlite database.
2018-12-05 23:16:14 +01:00
After the container is up and running, you go to `http://localhost` and log in with user: `admin` pass: `admin` and set up the page in the settings.
2018-12-10 22:54:05 +01:00
**All docker builds**: https://hub.docker.com/r/bpatrik/pigallery2/tags/
2018-12-06 09:52:04 +01:00
**Note**: You dont need to do the installation steps if you are using docker.
2018-12-05 23:16:14 +01:00
2018-12-06 13:50:55 +01:00
### 1.3 Advanced configuration
You can set up the app the following ways:
* Using the UI
* Manually editing the `config.json`
* Through switches
* Like: `node backend/index.js --Server-port=3000 --Client-authenticationRequired=false`
* You can check the generated `config.json` for the config hierarchy
* Through environmental variable
* like set env. variable `Server-port` to `3000`
### 1.4 Useful links/tips:
2018-05-15 20:01:11 -04:00
#### using nginx
2018-12-06 13:50:55 +01:00
It is recommended to use a reverse proxy like nginx before node
2017-07-29 23:39:06 +02:00
https://stackoverflow.com/questions/5009324/node-js-nginx-what-now
2017-10-19 12:08:07 -04:00
2018-05-15 20:01:11 -04:00
#### making https
2018-12-06 13:50:55 +01:00
With cerbot & nginx it is simple to set up secure connection. You have no excuse not doing so.
2017-07-29 23:39:06 +02:00
https://certbot.eff.org/
2018-05-15 20:01:11 -04:00
#### node install error:
2017-10-19 12:08:07 -04:00
If you get error during module installation, make sure you have everything to build node modules from source
```bash
apt-get install build-essential libkrb5-dev gcc g++
```
2018-12-06 09:52:04 +01:00
## 2. Translate the page to your own language
2018-12-22 00:29:05 +01:00
1. [Install Pigallery2 ](#111-b-install-from-source ) from source (with the release it won't work)
2018-05-15 20:01:11 -04:00
2. add your language e.g: fr
```bash
npm run add-translation -- --fr
```
it creates a new `messages.fr.xls` file at `frontend/translate` folder,
it will already contain dummy translation with google translate.
3. 'fix' the dummy translation
4. test if it works:
build and start the app
```bash
npm install
npm start
```
2018-12-22 00:20:03 +01:00
5. (optional) create a pull request at github to add your translation to the project.
2018-12-22 00:29:05 +01:00
**Note**: you can also build your own release with as described in [1.1.1-b Install from source ](#111-b-install-from-source );
2018-05-15 20:01:11 -04:00
2018-12-06 09:52:04 +01:00
## 3. Feature list
2017-06-04 15:25:22 +02:00
2019-01-12 18:08:34 +01:00
* supported formats:
* images: **jpg, jpeg, jpe, webp, png, gif, svg**
* videos: **mp4, ogg, ogv, webm**
2017-03-22 19:38:39 +01:00
* **Rendering directories as it is**
* Listing subdirectories recursively
* Listing photos in a nice grid layout
* supporting most common image formats
* showing **tag/keywords, locations, GPS coordinates** for photos
* rendering photos on demand (on scroll)
2017-03-22 19:41:32 +01:00
* **On the fly thumbnail generation** in several sizes
2017-03-22 19:38:39 +01:00
* prioritizes thumbnail generation (generating thumbnail first for the visible photos)
* saving generated thumbnails to TEMP folder for reuse
2018-12-05 21:55:11 +01:00
* supporting multi-core CPUs
2017-06-11 23:33:47 +02:00
* supporting hardware acceleration ([sharp ](https://github.com/lovell/sharp ) and [gm ](https://github.com/aheckmann/gm ) as optional and JS-based [Jimp ](https://github.com/oliver-moran/jimp ) as fallback)
2018-12-12 21:03:06 +01:00
* Custom lightbox for full screen photo and video viewing
2017-07-09 12:03:17 +02:00
* keyboard support for navigation
2017-03-22 19:38:39 +01:00
* showing low-res thumbnail while full image loads
2017-07-09 22:00:42 +02:00
* Information panel for showing **Exif info**
2017-07-11 22:23:07 +02:00
* Automatic playing
2017-07-17 18:30:16 +02:00
* gesture support (swipe left, right, up)
2018-12-12 21:03:06 +01:00
* shortcut support
2017-03-22 19:41:32 +01:00
* Client side caching (directories and search results)
2018-12-12 21:03:06 +01:00
* Rendering **photos** with GPS coordinates **on open street maps**
* .gpx file support: rendering paths to map
* supports [OSM ](https://www.openstreetmap.org ) and [Mapbox ](https://www.mapbox.com ) by default, but you can add any provider that has a tile url
2017-03-22 19:41:32 +01:00
* **Two modes: SQL database and no-database mode**
* both modes supports
* user management
* password protection can be disabled/enabled
2017-03-22 19:38:39 +01:00
* database mode supports:
* faster directory listing
* searching
* instant search, auto complete
2017-07-09 12:03:17 +02:00
* sharing
2017-03-22 19:38:39 +01:00
* setting link expiration time
2019-07-21 17:00:07 +02:00
* Faces (persons) support
* reads Adobe's XMP Face region metadata. (It is defined by the Metadata Working Group (MWG).)
* shows face bounding box over images
2018-03-29 20:30:23 -04:00
* internalization / translation support
2018-12-12 21:03:06 +01:00
* currently supported languages: eng, hun
2017-07-29 23:39:06 +02:00
* Nice design
2017-03-22 19:38:39 +01:00
* responsive design (phone, tablet desktop support)
2017-07-29 23:39:06 +02:00
* Setup page
2018-11-02 10:51:36 +01:00
* Random photo url
* You can generate an url that returns a random photo from your gallery. You can use this feature to develop 3rd party applications, like: changing desktop background
2018-11-22 19:12:10 +01:00
* video support
2018-11-25 15:22:07 +01:00
* fully supports *.mp4 files and partially (might have errors with safari and IE) supports * .ogg, *.ogv, * .webm files
* uses ffmpeg and ffprobe to generate video thumbnails
2018-12-06 09:52:04 +01:00
* Dockerized
2017-07-09 12:03:17 +02:00
* **Markdown based blogging support** - `future plan`
2017-03-22 19:41:32 +01:00
* you can write some note in the blog.md for every directory
2017-03-22 19:38:39 +01:00
* bug free :) - `In progress`
2019-02-25 11:41:56 +01:00
2019-02-25 11:49:37 +01:00
## 4. Suggest/endorse new features
You are welcome to suggest new features to the application via [github issues ](https://github.com/bpatrik/pigallery2/issues ).
2019-02-25 11:41:56 +01:00
I cannot garantie any dealine with the development of a new feature. (I usually fix bugs within week/weeks.)
I will give a higher priority to a feature that has more 'likes' (i.e.: `+1` -s or thumbs ups) on it.
2018-03-29 20:30:23 -04:00
2019-02-25 11:41:56 +01:00
## 5. Known errors
2018-11-02 10:51:36 +01:00
* EXIF orientation tag:
* There is no nice way to handle EXIF orientation tag properly.
The page handles these photos, but might cause same error in the user experience (e.g.: the pages loads those photos slower. See issue [#11 ](https://github.com/bpatrik/pigallery2/issues/11 ))
2018-12-02 20:57:16 +01:00
* Video support on weak servers (like raspberry pi) with low upload rate
* video playback may use up too much resources and the server might not response for a while. A solution might be to down scale / convert the video files to lower bitrate.
2019-02-25 11:41:56 +01:00
## 6. Credits
2018-05-15 20:01:11 -04:00
Crossbrowser testing sponsored by [Browser Stack ](https://www.browserstack.com )
[<img src="https://camo.githubusercontent.com/a7b268f2785656ab3ca7b1cbb1633ee5affceb8f/68747470733a2f2f64677a6f7139623561736a67312e636c6f756466726f6e742e6e65742f70726f64756374696f6e2f696d616765732f6c61796f75742f6c6f676f2d6865616465722e706e67" alt="Browser Stack" height="31px" style="background: cornflowerblue;"> ](https://www.browserstack.com )
2018-03-29 20:30:23 -04:00