Skip to content

foodcoops/ansible-role-foodsoft

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Foodsoft

This role installs a multicoop Foodsoft instance at a Debian based system. It uses rbenv to install all necessary Ruby and Rails packages.

A MariaDB server needs to be installed separately.

All the Foodsoft components are started via Systemd services. Puma is used as an application server. Socket activation is enabled.

Variables

You can adapt the role to your needs via the following variables. Please note: If there's no default you have to set this variable by yourself (e.g. at your playbook).

Name Default Note
foodsoft_home /opt/foodsoft Path to install the Foodsoft instance
foodsoft_user _foodsoft System user that runs all services
foodsoft_user_home /var/lib/{{ foodsoft_user }} Home directory for the system user
foodsoft_db foodsoft Name of the Foodsoft database
foodsoft_db_user foodsoft Name of the Foodsoft database user
foodsoft_db_password Database password
foodsoft_environment_file /etc/foodsoft/foodsoft.conf Foodsoft configuration file used by systemd service
doodsoft_web_service foodsoft-web.service Name of the Foodsoft systemd web service
foodsoft_web_socket foodsoft-web.socket Name of the Foodsoft systemd web socket
foodsoft_secret_key_base autogenerated Foodsoft Rails secret key base
foodsoft_smtp_service foodsoft-smtp.service Name of the Foodsoft systemd SMTP service
foodsoft_resque_service foodsoft-resque.service Name of Foodsoft systemd Resque service
foodsoft_web_bind_ip 127.0.0.1 Listen address for the internal Foodsoft application server
foodsoft_web_port 3001 Listen port for the internal Foodsoft application server
foodsoft_redis_url redis://127.0.0.1:6379/1 URL to the Redis server, Uses the first Redis database
foodsoft_version master Foodsoft version to install
ruby_build_version master Ruby build version to install
ruby_path {{ foodsoft_user_home }}/.rbenv Path to Ruby binaries
mariadb_socket /run/mysqld/mysqld.sock MariaDB connection socket

Configuration of mail delivery

For outgoing mail delivery the Foodsoft needs to connect to an SMTP server.

Name Default Note
foodsoft_smtp_address 127.0.0.1 Address of the SMTP server
foodsoft_smtp_port 25 Port of the SMTP server
foodsoft_smtp_authentication false True if your SMTP server requires authentication
foodsoft_smtp_enable_starttls_auto false True if your SMTP server only accepts TLS connections
foodsoft_smtp_user_name SMTP user name
foodsoft_smtp_password SMTP password
foodsoft_smtp_domain Sender domain
foodsoft_smtp_openssl_verify_mode Set for certificate verification

Configuration for incomming mail processing

The Foodsoft provides an internal SMTP server that processes incomming mails.

Name Default Note
foodsoft_smtp_server_host 127.0.0.1 Listen address for the internal Foodsoft SMTP server
foodsoft_smtp_server_port 2526 Listen port for the internal Foodsoft SMTP server

Connect to Sharedlists database

It's possbile to access the Sharedlists database from within the Foodsoft. Just use the following variables to grant the Foodsoft database user SELECT access to the Sharedlists database.

Name Default Note
sharedlists.enabled True if you want to connect a Sharedlists database
sharedlists.database Name of the sharedlists database

Example Playbook

You can set all possible configuration settings from app_config.yml.SAMPLE via your playbook. Some notes:

  • There are no configuration defaults. You have to set everything you want to configure by yourself.
  • If you need to quote a configuration setting use double quotes.
  • You can add every existing key-value-pair to foodsoft_config and foodsoft_multi_coops_config. Only the nested configuration settings shown in the example are supported.
---
- name: Playbook to install a Foodsoft instance
  hosts:
    - << your_host >>
  roles:
    - role: foodsoft
      foodsoft_db_password: abcd1234
      foodsoft_config:
        default_locale: en
        homepage: https://foodcoops.net
        multi_coop_install: true
        default_scope: "'demo'"
      foodsoft_config_notification:
        sender_address: '"\"Foodsoft Error\" <noreply@example.org"'
        email_prefix: '"[Foodsoft]"'
      foodsoft_config_notification_error_recipients:
        - notifications-foodsoft@example.org
      foodsoft_config_notificatopn_feedback_recipients:
        - support@example.org
      foodsoft_config_contact:
        street: Grüne Straße 103
        zip_code: "10997"
        city: Berlin
        country: Deutschland
        email: foodsoft@foodcoop.test
        phone: '"030 123 45678"'
      foodsoft_config_shared_lists:
        adapter: mysql2
        host: localhost
        database: "{{ sharedlists.database }}"
        username: "{{ foodsoft_db_user }}"
        password: "{{ foodsoft_db_password }}"
        encoding: utf8
        socket: "{{ mariadb_socket }}"
      foodsoft_config_webstats_tracking_code: |
        <!-- Matomo -->
          <script>
            var _paq = window._paq = window._paq || [];
            ...
          </script>
        <!-- End Matomo Code -->
      foodsoft_multi_coops:
        - name: demo
          database: foodsoft_demo
          config:
            use_wiki: false
            use_messages: false
        - name: myfoodcoop
          database: myfoodcoop
          config:
            default_locale: de
            homepage: https://example.org
      sharedlists:
        enabled: true
        database: sharedlists

About

Ansible role to install and configure the Foodsoft

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages