0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 15:39:50 -05:00
penpot/docs/05-Management-Guide.md
2020-04-13 11:49:26 +02:00

2.7 KiB

Management Guide

TODO

Frontend configuration parameters

Only available at build time!

  • -e UXBOX_PUBLIC_URL=... (defaults to http://localhost:6060)
  • -e UXBOX_DEMO_WARNING=... (defaults to true)
  • -e UXBOX_THEME=... (defaults to light, accepts dark to enable UXBOX dark theme)

Backend configuration parameters

Backend accepts a bunch of configuration parameters (detailed abowe), that can be passed in different ways. The preferred one is using environment variables.

This is a probably incomplete list of available options (with respective defaults):

  • UXBOX_HTTP_SERVER_PORT=6060
  • UXBOX_HTTP_SERVER_CORS=http://localhost:3449
  • UXBOX_DATABASE_USERNAME= (not defined, used from uri)
  • UXBOX_DATABASE_PASSWORD= (not defined, used from uri)
  • UXBOX_DATABASE_URI=postgresql://127.0.0.1/uxbox
  • UXBOX_MEDIA_DIRECTORY=resources/public/media
  • UXBOX_MEDIA_URI=http://localhost:6060/media/
  • UXBOX_ASSETS_DIRECTORY=resources/public/static
  • UXBOX_ASSETS_URI=ehttp://localhost:6060/static/
  • UXBOX_EMAIL_REPLY_TO=no-reply@nodomain.com
  • UXBOX_EMAIL_FROM=no-reply@nodomain.com
  • UXBOX_SMTP_HOST= (default undefined)
  • UXBOX_SMTP_PORT= (defaults undefined)
  • UXBOX_SMTP_USER= (defaults undefined)
  • UXBOX_SMTP_PASSWORD= (defaults undefined)
  • UXBOX_SMTP_SSL= (defaults to false)
  • UXBOX_SMTP_TLS= (defaults to false)
  • UXBOX_SMTP_ENABLED=false
  • UXBOX_REGISTRATION_ENABLED=true
  • UXBOX_REGISTRATION_DOMAIN_WHITELIST="" (comma-separated domains, defaults to "" which means that all domains are allowed)
  • UXBOX_DEBUG_HUMANIZE_TRANSIT=true

REPL

The production environment by default starts a server REPL where you can connect and perform diagnosis operations. For this you will need netcat or telnet installed in the server.

$ rlwrap netcat localhost 5555
user=>

Collections import

This is the way we can preload default collections of images and icons to the running platform.

First of that, you need to have a configuration file (edn format) like this:

{:icons
 [{:name "Generic Icons 1"
   :path "./icons/my-icons-collection/"
   :regex #"^.*_48px\.svg$"}
  ]
 :images
 [{:name "Generic Images 1"
   :path "./images/my-images-collection/"
   :regex #"^.*\.(png|jpg|webp)$"}]}

You can found a real example in sample_media/config.edn (that also has all the material design icon collections).

Then, you need to execute:

clojure -Adev -m uxbox.media-loader ../path/to/config.edn

If you have a REPL access to the running process, you can execute it from there:

(require 'uxbox.media-loader)
@(uxbox.media-loader/run "/path/to/config.edn")