How to install Odoo on a Raspberry Pi

For those that may be interested, here are the steps to get the OpenEMS Odoo add-on working on a Raspberry Pi 4 running Bookworm. If there is a better place to post this, please let me know.

This may work for other Linux-based installations but I have not tested. This is the on-premise installation of Odoo, version 16. In my case, I installed it on the same Pi that is running the OpenEMS Backend. I am also running the OpenEMS UI on this Backend server. I am running OpenEMS Edge on a separate Raspberry Pi 5.

The first few steps originated from Odoo Install. Check that link for details/reasons for each command. From the Raspberry Pi run the following commands using remote SSH or from Terminal on the Pi:

sudo apt update -y && sudo apt upgrade -y
sudo apt install postgresql -y
wget -O - https://nightly.odoo.com/odoo.key | sudo gpg --dearmor -o /usr/share/keyrings/odoo-archive-keyring.gpg
echo 'deb [signed-by=/usr/share/keyrings/odoo-archive-keyring.gpg] https://nightly.odoo.com/16.0/nightly/deb/ ./' | sudo tee /etc/apt/sources.list.d/odoo.list
sudo apt update -y
sudo apt install odoo -y

You should now be able to access the Odoo login page from a browser at http://{ip address}:8069. You can use http://localhost:8069 if you don’t know the IP address. You should be able to get the IP address using this command on the Pi:

ifconfig

From there, you will be asked to set various authentication credentials such as Master Password and Database Name. Be sure to store or write them down as they are critical later on.

  • Enter your new credentials and selections
  • Click Create Database

You should now see the Odoo login page:

  • Enter your previously set credentials
  • Click Log in

From the Apps screen, go ahead and Activate an app such as the CRM app. For some reason, this is necessary in order to have additional options enabled that we will need later. Once you refresh the page, you should now see that there are more options but we’ll come back to this in a bit.

Once the page refreshes, you should now see that there are more options:

  • Click the icon at the top left of the screen and then select Settings
  • Scroll all the way down and click on “Activate the developer mode”

Go back to Terminal and create custom add-on directory and download the OpenEMS Odoo-openems repository using git or some other method:

cd /etc/odoo
sudo mkdir custom_addons
cd
sudo mkdir Development
cd Development
git clone https://github.com/OpenEMS/odoo-openems.git
cd odoo-openems
sudo cp -r openems/ /etc/odoo/custom_addons/

Add the new addons path to your Odoo config:

sudo nano /etc/odoo/odoo.conf

Add or change the item “addons_path” to show and save the file:

addons_path = /etc/odoo/custom_addons

Retart Odoo:

sudo systemctl restart odoo.service

There are a couple of modules that are needed in order to use the odoo-openems add-on so we you should go ahead and install them now. Using the same technique as above for adding odoo-openems to the /etc/odoo/custom_addons folder, add these prerequisites. Be sure to pick the most recent version closest to your Odoo version:

Go back to Odoo in the browser and refresh the page.

  • Click the icon at the top left, again, and select Apps
  • Click “Update Apps List” at the top of the page. This will restart Odoo.

In the App search box, type in and Activate the following modules, after clearing any filters, in this order:

  • partner_firstname
  • web_m2x_options
  • openems

After activation, you can click on the icon at the top left and you should see an OpenEMS option in the menu. Click it. From here you may be able to create new Devices but I have had varying levels of success. Specifically, the Name field is sometimes not accessible and I believe the field is required. I would assume that the name you enter here would be something like “edge0”. There is also a field named API-Key that should be populated with a unique key that can later be referenced from the OpenEMS Edge Apache Felix Configuration where you activate a Controller Api Backend entry for communication with the Backend.

From Odoo, you can also create new users and associate them with Edge devices.

Now, go to your OpenEMS Backend Apache Felix configuration manager:

  • Set and save the Metadata.Odoo configuration using the credentials used at the beginning of this process
  • Delete or disable any other Metadata configs

Next, open your OpenEMS UI, which is running on your Backend server, and log in using one of the user credentials you created in Odoo.

That’s it.

As mentioned above, I have had some difficulties with associating Edge devices with Users in Odoo and therefore do not see the devices listed when I log in through the OpenEMS UI. But, it’s a start.

I hope this helps.

6 Likes

Hi @acabrera ,

Thank you very much for your detailed guideline! It worked fine on my debian bullseye.

Odoo / postgresql are up and running. I´ve changed a few things in the configuration to get a bit more “grip” on the database. The user odoo was origionally configured without password - which is OK for local environment.

Set password in psql:

ALTER ROLE odoo WITH PASSWORD 'yesApassword';

Change DB-Listener to all clients - not only localhost in
/etc/postgresql/13/main/postgresql.conf

listen_addresses = '*'

disable network-restrictions in
/etc/postgresql/13/main/pg_hba.conf

# IPv4 local connections:
host    all             all             0.0.0.0/0               md5

Change /etc/odoo/odoo.conf

[options]
db_host = localhost
db_port = 5432
db_user = odoo
db_password = yesApassword
db_name = odoodb
default_productivity_apps = True
admin_passwd = youDoNotNeedToKnow
addons_path = /etc/odoo/custom_addons

By the way: my initial choice to name the database “odooDB” was a bad idea. I advise using only lowercase letters.

The openEMS app in Odoo is running, but I got stuck saving devices because the field “name” is marked as read-only and required at the same time. Have you made any progress in the meantime?

This whole backend thing in connection with Odoo can be quite frustrating, right? :face_with_peeking_eye:

regards
klinki

1 Like

Hello, @klinki. I’m glad you made it this far.

I moved on to a different way of authenticating users so I did not figure out the issue with the read-only devices issue. It was strange that sometimes different fields were marked as read-only and sometimes not. I’m sure there is a good reason for it but I just could not spend any more time on it.

I hope you can get further than I did. Good luck to you.

1 Like

Hey klinki,

lets hop on a quick call next week - i can help you out :wink:

1 Like

@ acabrera. I found one consistent way for managing edges from Odoo. To link Admin users to edges using Odoo:

  1. From Settings, navigate to Users & Companies, Users

  2. Double click on the OpenEMS user you want to configure

  3. Under Access Rights Tab, Go to OTHER, OpenEMS, Select “Manager” from drop down

  4. Under OpenEMS Tab, Set Global Role to Admin

  5. Under OpenEMS Tab, Add Role raws for each edge

Now, when you navigate to OpenEMS App, OpenEMS Edge, Devices, all edges are shown with generated keys and ready for additional configuration.

3 Likes

Excellent! Thanks for the info.