odoo-18-docker-compose/run.sh
Minh Nguyen 0511e21c4c
Logrotate on etc/odoo-server.log (#13)
* logrotate

* chmod +x entrypoint.sh
2025-04-18 22:26:43 +07:00

51 lines
1.6 KiB
Bash

#!/bin/bash
DESTINATION=$1
PORT=$2
CHAT=$3
# Clone Odoo directory
git clone --depth=1 https://github.com/minhng92/odoo-18-docker-compose $DESTINATION
rm -rf $DESTINATION/.git
# Create PostgreSQL directory
mkdir -p $DESTINATION/postgresql
# Change ownership to current user and set restrictive permissions for security
sudo chown -R $USER:$USER $DESTINATION
sudo chmod -R 700 $DESTINATION # Only the user has access
# Check if running on macOS
if [[ "$OSTYPE" == "darwin"* ]]; then
echo "Running on macOS. Skipping inotify configuration."
else
# System configuration
if grep -qF "fs.inotify.max_user_watches" /etc/sysctl.conf; then
echo $(grep -F "fs.inotify.max_user_watches" /etc/sysctl.conf)
else
echo "fs.inotify.max_user_watches = 524288" | sudo tee -a /etc/sysctl.conf
fi
sudo sysctl -p
fi
# Set ports in docker-compose.yml
# Update docker-compose configuration
if [[ "$OSTYPE" == "darwin"* ]]; then
# macOS sed syntax
sed -i '' 's/10018/'$PORT'/g' $DESTINATION/docker-compose.yml
sed -i '' 's/20018/'$CHAT'/g' $DESTINATION/docker-compose.yml
else
# Linux sed syntax
sed -i 's/10018/'$PORT'/g' $DESTINATION/docker-compose.yml
sed -i 's/20018/'$CHAT'/g' $DESTINATION/docker-compose.yml
fi
# Set file and directory permissions after installation
find $DESTINATION -type f -exec chmod 644 {} \;
find $DESTINATION -type d -exec chmod 755 {} \;
chmod +x $DESTINATION/entrypoint.sh
# Run Odoo
docker-compose -f $DESTINATION/docker-compose.yml up -d
echo "Odoo started at http://localhost:$PORT | Master Password: minhng.info | Live chat port: $CHAT"