diff options
| author | Alexandru DAMIAN <alexandru.damian@intel.com> | 2014-06-03 16:26:13 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-06-06 10:32:54 +0100 |
| commit | 89fe052949f7f6dbcca0ec69ff1a1c6735650f4b (patch) | |
| tree | 33c79a1b92b633a35d3e6b83e801dfdc023b3456 | |
| parent | 506b5bd729920d7bab694f28d674888d1b7398db (diff) | |
| download | poky-89fe052949f7f6dbcca0ec69ff1a1c6735650f4b.tar.gz | |
bitbake: toaster: read database settings from the environment
We add the capability to read the database settings for
Toaster from the environment. The DATABASE_URL is intepreted
and used to override the default settings.
This capability is essential for easy deployment of Toaster
in a managed hosted environment, and for creating
build environments with custom database settings.
(Bitbake rev: d16d19dafb83448fc214fce4fbdc2bcbf4bf9ce3)
Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | bitbake/lib/toaster/toastermain/settings.py | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/bitbake/lib/toaster/toastermain/settings.py b/bitbake/lib/toaster/toastermain/settings.py index 645f32746d..adaa56ca17 100644 --- a/bitbake/lib/toaster/toastermain/settings.py +++ b/bitbake/lib/toaster/toastermain/settings.py | |||
| @@ -41,6 +41,39 @@ DATABASES = { | |||
| 41 | } | 41 | } |
| 42 | } | 42 | } |
| 43 | 43 | ||
| 44 | # Reinterpret database settings if we have DATABASE_URL environment variable defined | ||
| 45 | import os, re | ||
| 46 | |||
| 47 | if 'DATABASE_URL' in os.environ: | ||
| 48 | dburl = os.environ['DATABASE_URL'] | ||
| 49 | if dburl.startswith('sqlite3://'): | ||
| 50 | result = re.match('sqlite3://(.*)', dburl) | ||
| 51 | if result is None: | ||
| 52 | raise Exception("ERROR: Could not read sqlite database url: %s" % dburl) | ||
| 53 | DATABASES['default'] = { | ||
| 54 | 'ENGINE': 'django.db.backends.sqlite3', | ||
| 55 | 'NAME': result.group(1), | ||
| 56 | 'USER': '', | ||
| 57 | 'PASSWORD': '', | ||
| 58 | 'HOST': '', | ||
| 59 | 'PORT': '', | ||
| 60 | } | ||
| 61 | elif dburl.startswith('mysql://'): | ||
| 62 | # URL must be in this form: mysql://user:pass@host:port/name | ||
| 63 | result = re.match(r"mysql://([^:]*):([^@]*)@([^:]*):(\d+)/([^/]*)", dburl) | ||
| 64 | if result is None: | ||
| 65 | raise Exception("ERROR: Could not read mysql database url: %s" % dburl) | ||
| 66 | DATABASES['default'] = { | ||
| 67 | 'ENGINE': 'django.db.backends.mysql', | ||
| 68 | 'NAME': result.group(5), | ||
| 69 | 'USER': result.group(1), | ||
| 70 | 'PASSWORD': result.group(2), | ||
| 71 | 'HOST': result.group(3), | ||
| 72 | 'PORT': result.group(4), | ||
| 73 | } | ||
| 74 | else: | ||
| 75 | raise Exception("FIXME: Please implement missing database url schema for url: %s" % dburl) | ||
| 76 | |||
| 44 | # Hosts/domain names that are valid for this site; required if DEBUG is False | 77 | # Hosts/domain names that are valid for this site; required if DEBUG is False |
| 45 | # See https://docs.djangoproject.com/en/1.5/ref/settings/#allowed-hosts | 78 | # See https://docs.djangoproject.com/en/1.5/ref/settings/#allowed-hosts |
| 46 | ALLOWED_HOSTS = [] | 79 | ALLOWED_HOSTS = [] |
| @@ -51,7 +84,7 @@ ALLOWED_HOSTS = [] | |||
| 51 | # In a Windows environment this must be set to your system time zone. | 84 | # In a Windows environment this must be set to your system time zone. |
| 52 | 85 | ||
| 53 | # Always use local computer's time zone, find | 86 | # Always use local computer's time zone, find |
| 54 | import os, hashlib | 87 | import hashlib |
| 55 | if 'TZ' in os.environ: | 88 | if 'TZ' in os.environ: |
| 56 | TIME_ZONE = os.environ['TZ'] | 89 | TIME_ZONE = os.environ['TZ'] |
| 57 | else: | 90 | else: |
