102 lines
10 KiB
JSON
102 lines
10 KiB
JSON
{
|
||
"0": {
|
||
"id": "0",
|
||
"title": "",
|
||
"content": "404 Page not found :( The requested page could not be found.",
|
||
"url": "https://gancio.org/404.html",
|
||
"relUrl": "/404.html"
|
||
},
|
||
"1": {
|
||
"id": "1",
|
||
"title": "Admin",
|
||
"content": "Admin Basics Add user Enable registration Confirm registration Confirm event Basics Add user Enable registration Confirm registration Confirm event",
|
||
"url": "https://gancio.org/admin",
|
||
"relUrl": "/admin"
|
||
},
|
||
"2": {
|
||
"id": "2",
|
||
"title": "Classic",
|
||
"content": "Install Install Node.js and postgreSQL curl -sL https://deb.nodesource.com/setup_12.x | bash - apt-get install -y nodejs postgresql source Install Gancio npm install --global gancio Create a database (optional as you can use sqlite, but recommended) sudo -u postgres psql postgres=# create database gancio; postgres=# create user gancio with encrypted password 'gancio'; postgres=# grant all privileges on database gancio to gancio; Create a user to run gancio from adduser gancio su gancio Test & launch interactive setup gancio --help gancio setup --config config.json Start gancio --help gancio start --config config.json Point your web browser to http://localhost:13120 or where you selected during setup. Setup nginx as a proxy Deploy in production If you don’t use the docker way, in production you should use something like pm2: sudo npm install --global pm2 pm2 gancio start --config config.json",
|
||
"url": "https://gancio.org/install/classic",
|
||
"relUrl": "/install/classic"
|
||
},
|
||
"3": {
|
||
"id": "3",
|
||
"title": "Configuration",
|
||
"content": "Configuration Main gancio configuration is done with a configuration file. This shoud be a .json or a .js file and could be specified using the --config flag. eg. gancio start --config ./config.json eg. pm2 start gancio start -- --config ~/config.json Title Description BaseURL Server Database Upload path SMTP Admin Favicon User locale Secret Default settings Title The title will be in rss feed, in html head and in emails: "title": "Gancio" Description "description": "a shared agenda for local communities" BaseURL URL where your site will be accessible (include http or https): "baseurl": "https://gancio.cisti.org" Server This probably support unix socket too :D "server": { "host": "localhost", "port": 13120 } Database "db": { "dialect": "sqlite", "storage": "/tmp/db.sqlite" } Upload path Where to save images "upload_path": "./uploads" SMTP Admin Favicon You could specify another favicon. This is also used as logo (top-left corner): "favicon": "./favicon.ico" User locale Probably you want to modify some text for your specific community, that’s why we thought the user_locale configuration: you can specify your version of each string of gancio making a directory with your locales inside. For example, let’s say you want to modify the text inside the /about page: mkdir /opt/gancio/user_locale put something like this in /opt/gancio/user_locale/en.js to override the about in english: export default { about: 'A new about' } and then point the user_locale configuration to that directory: "user_locale": "/opt/gancio/user_locale" Watch here for a list of strings you can override. :warning: Note that a restart is needed when you change user_locale’s content. Secret Default settings { "title": "Gancio", "description": "A shared agenda for local communities", "baseurl": "http://localhost:13120", "server": { "host": "0.0.0.0", "port": 13120 }, "db": { "dialect": "sqlite", "storage": "/tmp/db.sqlite" }, "upload_path": "./", "favicon": "../dist/favicon.ico", "smtp": { "auth": { "user": "", "pass": "" }, "secure": true, "host": "" }, "admin": "", "secret": "notsosecret" }",
|
||
"url": "https://gancio.org/config",
|
||
"relUrl": "/config"
|
||
},
|
||
"4": {
|
||
"id": "4",
|
||
"title": "Contribute",
|
||
"content": "Contribute If you want to contribute, take a look at the issues Code Translate Design Documentation Share Code Translate Design Documentation Share",
|
||
"url": "https://gancio.org/contribute",
|
||
"relUrl": "/contribute"
|
||
},
|
||
"5": {
|
||
"id": "5",
|
||
"title": "Hacking",
|
||
"content": "Development Stack Gancio is built with following technologies: Nuxt.js Vue.js Express Node.js Sequelize Element.ui Testing on your own machine Download source git clone https://git.lattuga.net/cisti/gancio Install dependencies yarn Hacking yarn dev",
|
||
"url": "https://gancio.org/dev",
|
||
"relUrl": "/dev"
|
||
},
|
||
"6": {
|
||
"id": "6",
|
||
"title": "Docker",
|
||
"content": "Install with docker You do not need to clone the full repo as we distribute gancio via npm. Dockerfile and docker-compose.yml are the only needed files. Create a directory where everything related to gancio is stored (db, images, config) mkdir /opt/gancio cd /opt/gancio :information_source: you can choose a different directory of course Download docker-compose.yml and Dockerfile wget https://git.lattuga.net/cisti/gancio/raw/docker/docker/Dockerfile wget https://git.lattuga.net/cisti/gancio/raw/docker/docker/docker-compose.yml Create an empty configuration file touch config.json After first setup, you can modify this file and restart the container on your needs. Build docker image and launch interactive setup in one step docker-compose run --rm gancio gancio setup Run your container docker-compose up -d Setup nginx as a proxy Point your web browser to http://localhost:13120 or where you specified during setup and enjoy :tada:",
|
||
"url": "https://gancio.org/install/docker",
|
||
"relUrl": "/install/docker"
|
||
},
|
||
"7": {
|
||
"id": "7",
|
||
"title": "Home",
|
||
"content": "Gancio A shared agenda for local communities. Get started now Demo Source About the project Gancio is made with :heart: by hacklab underscore License Gancio is distributed by an AGPL-3.0 Licence.",
|
||
"url": "https://gancio.org/",
|
||
"relUrl": "/"
|
||
},
|
||
"8": {
|
||
"id": "8",
|
||
"title": "Install",
|
||
"content": "Install Classic install Using docker Nginx as a proxy Hacking & contribute",
|
||
"url": "https://gancio.org/install",
|
||
"relUrl": "/install"
|
||
},
|
||
"9": {
|
||
"id": "9",
|
||
"title": "Instances",
|
||
"content": "Instances gancio.cisti.org (Torino, Italy) lapunta.org (Firenze, Italy)",
|
||
"url": "https://gancio.org/instances",
|
||
"relUrl": "/instances"
|
||
},
|
||
"10": {
|
||
"id": "10",
|
||
"title": "Migration",
|
||
"content": "Migration If you need to modify the db’s structure while hacking, it’s super easy, just change server/api/models/. If you then decide that your changes are good for production, a sequelize migration is needed: Create a migration: ./node_modules/.bin/sequelize migration:generate --name your_migration",
|
||
"url": "https://gancio.org/dev/migration",
|
||
"relUrl": "/dev/migration"
|
||
},
|
||
"11": {
|
||
"id": "11",
|
||
"title": "Nginx",
|
||
"content": "Nginx proxy configuration This is the default nginx configuration for gancio, please modify at least the server_name and ssl_certificate’s path. Note that this does not include a cache configuration and that gancio does not use a cache control at all, if you can help with this task you’re welcome. server { listen 80; listen [::]:80; server_name gancio.cisti.org; root /var/www/letsencrypt; location /.well-known/acme-challenge/ { allow all; } location / { return 301 https://$host$request_uri; } } server { listen 443 ssl http2; listen [::]:443 ssl http2; server_name gancio.cisti.org; ssl_protocols TLSv1.2; ssl_ciphers HIGH:!MEDIUM:!LOW:!aNULL:!NULL:!SHA; ssl_prefer_server_ciphers on; ssl_session_cache shared:SSL:10m; # Uncomment these lines once you acquire a certificate: # ssl_certificate /etc/letsencrypt/live/gancio.cisti.org/fullchain.pem; # ssl_certificate_key /etc/letsencrypt/live/gancio.cisti.org/privkey.pem; keepalive_timeout 70; sendfile on; client_max_body_size 80m; gzip on; gzip_disable "msie6"; gzip_vary on; gzip_proxied any; gzip_comp_level 6; gzip_buffers 16 8k; gzip_http_version 1.1; gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; add_header Strict-Transport-Security "max-age=31536000"; location / { try_files $uri @proxy; } location @proxy { proxy_set_header Host $host; proxy_set_header X-Forwarded-Proto https; proxy_set_header Proxy ""; proxy_pass_header Server; proxy_pass http://127.0.0.1:13120; proxy_buffering on; proxy_redirect off; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $connection_upgrade; tcp_nodelay on; } }",
|
||
"url": "https://gancio.org/install/nginx",
|
||
"relUrl": "/install/nginx"
|
||
},
|
||
"12": {
|
||
"id": "12",
|
||
"title": "Project Structure",
|
||
"content": "Structure API / backend Source code inside server/api/. index.js is basically a routing table pointing each PATH with specified HTTP VERB to a method of a controller. jwt is used to authenticate api request. Express is based on middleware, passing each request to a chain of methods. If you come from a PHP background, note that the main difference with Node.js is that the server process is always running and able to manage multiple requests and tasks together (asyncronically) while each php process is tied to a single request. Sequelize is used as ORM. Take a look in /server/api/models. Client / frontend Nuxt.js is used here! Nuxt is basically Vue plus SSR (Server Side Rendering). Client routing in nuxt is automatic (if you don’t need something special), just put your page inside pages and that’s it!",
|
||
"url": "https://gancio.org/dev/structure",
|
||
"relUrl": "/dev/structure"
|
||
},
|
||
"13": {
|
||
"id": "13",
|
||
"title": "Usage",
|
||
"content": "Usage Add event Normal Multidate Recurrent",
|
||
"url": "https://gancio.org/usage",
|
||
"relUrl": "/usage"
|
||
}
|
||
|
||
}
|