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: |