From: Tony Mack Date: Fri, 26 Dec 2014 00:17:54 +0000 (-0500) Subject: adding initial migrations X-Git-Url: http://git.onelab.eu/?p=plstackapi.git;a=commitdiff_plain;h=2d98ec104de17b6b5328ec22003df5661af81437 adding initial migrations --- diff --git a/opencloud.spec b/opencloud.spec index 412a3f3..ed9e864 100644 --- a/opencloud.spec +++ b/opencloud.spec @@ -53,6 +53,7 @@ pip-python install python-keystoneclient pip-python install python-novaclient pip-python install python-neutronclient pip-python install python-glanceclient +pip-python install python-ceilometerclient easy_install django_evolution diff --git a/planetstack/cassandra/migrations/0001_initial.py b/planetstack/cassandra/migrations/0001_initial.py new file mode 100644 index 0000000..1eefdd8 --- /dev/null +++ b/planetstack/cassandra/migrations/0001_initial.py @@ -0,0 +1,26 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='CassandraService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ('clusterSize', models.PositiveIntegerField(default=1)), + ('replicationFactor', models.PositiveIntegerField(default=1)), + ], + options={ + 'verbose_name': 'Cassandra Service', + }, + bases=('core.service', models.Model), + ), + ] diff --git a/planetstack/core/migrations/0001_initial.py b/planetstack/core/migrations/0001_initial.py new file mode 100644 index 0000000..9612815 --- /dev/null +++ b/planetstack/core/migrations/0001_initial.py @@ -0,0 +1,1303 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations +import timezones.fields +import core.models.sliver +import core.models.network +import geoposition.fields +import encrypted_fields.fields +import core.models.serviceclass +import django.utils.timezone +from django.conf import settings + + +class Migration(migrations.Migration): + + dependencies = [ + ('contenttypes', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='User', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('password', models.CharField(max_length=128, verbose_name='password')), + ('last_login', models.DateTimeField(default=django.utils.timezone.now, verbose_name='last login')), + ('email', models.EmailField(unique=True, max_length=255, verbose_name=b'email address', db_index=True)), + ('username', models.CharField(default=b'Something', max_length=255)), + ('firstname', models.CharField(help_text=b"person's given name", max_length=200)), + ('lastname', models.CharField(help_text=b"person's surname", max_length=200)), + ('phone', models.CharField(help_text=b'phone number contact', max_length=100, null=True, blank=True)), + ('user_url', models.URLField(null=True, blank=True)), + ('public_key', models.TextField(help_text=b'Public key string', max_length=1024, null=True, blank=True)), + ('is_active', models.BooleanField(default=True)), + ('is_admin', models.BooleanField(default=True)), + ('is_staff', models.BooleanField(default=True)), + ('is_readonly', models.BooleanField(default=False)), + ('created', models.DateTimeField(auto_now_add=True)), + ('updated', models.DateTimeField(auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('timezone', timezones.fields.TimeZoneField(default=b'America/New_York', max_length=100, choices=[(b'Pacific/Midway', b'(GMT-1100) Pacific/Midway'), (b'Pacific/Niue', b'(GMT-1100) Pacific/Niue'), (b'Pacific/Pago_Pago', b'(GMT-1100) Pacific/Pago_Pago'), (b'America/Adak', b'(GMT-1000) America/Adak'), (b'Pacific/Honolulu', b'(GMT-1000) Pacific/Honolulu'), (b'Pacific/Johnston', b'(GMT-1000) Pacific/Johnston'), (b'Pacific/Rarotonga', b'(GMT-1000) Pacific/Rarotonga'), (b'Pacific/Tahiti', b'(GMT-1000) Pacific/Tahiti'), (b'US/Hawaii', b'(GMT-1000) US/Hawaii'), (b'Pacific/Marquesas', b'(GMT-0930) Pacific/Marquesas'), (b'America/Anchorage', b'(GMT-0900) America/Anchorage'), (b'America/Juneau', b'(GMT-0900) America/Juneau'), (b'America/Nome', b'(GMT-0900) America/Nome'), (b'America/Sitka', b'(GMT-0900) America/Sitka'), (b'America/Yakutat', b'(GMT-0900) America/Yakutat'), (b'Pacific/Gambier', b'(GMT-0900) Pacific/Gambier'), (b'US/Alaska', b'(GMT-0900) US/Alaska'), (b'America/Dawson', b'(GMT-0800) America/Dawson'), (b'America/Los_Angeles', b'(GMT-0800) America/Los_Angeles'), (b'America/Metlakatla', b'(GMT-0800) America/Metlakatla'), (b'America/Santa_Isabel', b'(GMT-0800) America/Santa_Isabel'), (b'America/Tijuana', b'(GMT-0800) America/Tijuana'), (b'America/Vancouver', b'(GMT-0800) America/Vancouver'), (b'America/Whitehorse', b'(GMT-0800) America/Whitehorse'), (b'Canada/Pacific', b'(GMT-0800) Canada/Pacific'), (b'Pacific/Pitcairn', b'(GMT-0800) Pacific/Pitcairn'), (b'US/Pacific', b'(GMT-0800) US/Pacific'), (b'America/Boise', b'(GMT-0700) America/Boise'), (b'America/Cambridge_Bay', b'(GMT-0700) America/Cambridge_Bay'), (b'America/Chihuahua', b'(GMT-0700) America/Chihuahua'), (b'America/Creston', b'(GMT-0700) America/Creston'), (b'America/Dawson_Creek', b'(GMT-0700) America/Dawson_Creek'), (b'America/Denver', b'(GMT-0700) America/Denver'), (b'America/Edmonton', b'(GMT-0700) America/Edmonton'), (b'America/Hermosillo', b'(GMT-0700) America/Hermosillo'), (b'America/Inuvik', b'(GMT-0700) America/Inuvik'), (b'America/Mazatlan', b'(GMT-0700) America/Mazatlan'), (b'America/Ojinaga', b'(GMT-0700) America/Ojinaga'), (b'America/Phoenix', b'(GMT-0700) America/Phoenix'), (b'America/Yellowknife', b'(GMT-0700) America/Yellowknife'), (b'Canada/Mountain', b'(GMT-0700) Canada/Mountain'), (b'US/Arizona', b'(GMT-0700) US/Arizona'), (b'US/Mountain', b'(GMT-0700) US/Mountain'), (b'America/Bahia_Banderas', b'(GMT-0600) America/Bahia_Banderas'), (b'America/Belize', b'(GMT-0600) America/Belize'), (b'America/Cancun', b'(GMT-0600) America/Cancun'), (b'America/Chicago', b'(GMT-0600) America/Chicago'), (b'America/Costa_Rica', b'(GMT-0600) America/Costa_Rica'), (b'America/El_Salvador', b'(GMT-0600) America/El_Salvador'), (b'America/Guatemala', b'(GMT-0600) America/Guatemala'), (b'America/Indiana/Knox', b'(GMT-0600) America/Indiana/Knox'), (b'America/Indiana/Tell_City', b'(GMT-0600) America/Indiana/Tell_City'), (b'America/Managua', b'(GMT-0600) America/Managua'), (b'America/Matamoros', b'(GMT-0600) America/Matamoros'), (b'America/Menominee', b'(GMT-0600) America/Menominee'), (b'America/Merida', b'(GMT-0600) America/Merida'), (b'America/Mexico_City', b'(GMT-0600) America/Mexico_City'), (b'America/Monterrey', b'(GMT-0600) America/Monterrey'), (b'America/North_Dakota/Beulah', b'(GMT-0600) America/North_Dakota/Beulah'), (b'America/North_Dakota/Center', b'(GMT-0600) America/North_Dakota/Center'), (b'America/North_Dakota/New_Salem', b'(GMT-0600) America/North_Dakota/New_Salem'), (b'America/Rainy_River', b'(GMT-0600) America/Rainy_River'), (b'America/Rankin_Inlet', b'(GMT-0600) America/Rankin_Inlet'), (b'America/Regina', b'(GMT-0600) America/Regina'), (b'America/Resolute', b'(GMT-0600) America/Resolute'), (b'America/Swift_Current', b'(GMT-0600) America/Swift_Current'), (b'America/Tegucigalpa', b'(GMT-0600) America/Tegucigalpa'), (b'America/Winnipeg', b'(GMT-0600) America/Winnipeg'), (b'Canada/Central', b'(GMT-0600) Canada/Central'), (b'Pacific/Galapagos', b'(GMT-0600) Pacific/Galapagos'), (b'US/Central', b'(GMT-0600) US/Central'), (b'America/Atikokan', b'(GMT-0500) America/Atikokan'), (b'America/Bogota', b'(GMT-0500) America/Bogota'), (b'America/Cayman', b'(GMT-0500) America/Cayman'), (b'America/Detroit', b'(GMT-0500) America/Detroit'), (b'America/Eirunepe', b'(GMT-0500) America/Eirunepe'), (b'America/Guayaquil', b'(GMT-0500) America/Guayaquil'), (b'America/Havana', b'(GMT-0500) America/Havana'), (b'America/Indiana/Indianapolis', b'(GMT-0500) America/Indiana/Indianapolis'), (b'America/Indiana/Marengo', b'(GMT-0500) America/Indiana/Marengo'), (b'America/Indiana/Petersburg', b'(GMT-0500) America/Indiana/Petersburg'), (b'America/Indiana/Vevay', b'(GMT-0500) America/Indiana/Vevay'), (b'America/Indiana/Vincennes', b'(GMT-0500) America/Indiana/Vincennes'), (b'America/Indiana/Winamac', b'(GMT-0500) America/Indiana/Winamac'), (b'America/Iqaluit', b'(GMT-0500) America/Iqaluit'), (b'America/Jamaica', b'(GMT-0500) America/Jamaica'), (b'America/Kentucky/Louisville', b'(GMT-0500) America/Kentucky/Louisville'), (b'America/Kentucky/Monticello', b'(GMT-0500) America/Kentucky/Monticello'), (b'America/Lima', b'(GMT-0500) America/Lima'), (b'America/Montreal', b'(GMT-0500) America/Montreal'), (b'America/Nassau', b'(GMT-0500) America/Nassau'), (b'America/New_York', b'(GMT-0500) America/New_York'), (b'America/Nipigon', b'(GMT-0500) America/Nipigon'), (b'America/Panama', b'(GMT-0500) America/Panama'), (b'America/Pangnirtung', b'(GMT-0500) America/Pangnirtung'), (b'America/Port-au-Prince', b'(GMT-0500) America/Port-au-Prince'), (b'America/Rio_Branco', b'(GMT-0500) America/Rio_Branco'), (b'America/Thunder_Bay', b'(GMT-0500) America/Thunder_Bay'), (b'America/Toronto', b'(GMT-0500) America/Toronto'), (b'Canada/Eastern', b'(GMT-0500) Canada/Eastern'), (b'Pacific/Easter', b'(GMT-0500) Pacific/Easter'), (b'US/Eastern', b'(GMT-0500) US/Eastern'), (b'America/Caracas', b'(GMT-0430) America/Caracas'), (b'America/Anguilla', b'(GMT-0400) America/Anguilla'), (b'America/Antigua', b'(GMT-0400) America/Antigua'), (b'America/Aruba', b'(GMT-0400) America/Aruba'), (b'America/Barbados', b'(GMT-0400) America/Barbados'), (b'America/Blanc-Sablon', b'(GMT-0400) America/Blanc-Sablon'), (b'America/Boa_Vista', b'(GMT-0400) America/Boa_Vista'), (b'America/Curacao', b'(GMT-0400) America/Curacao'), (b'America/Dominica', b'(GMT-0400) America/Dominica'), (b'America/Glace_Bay', b'(GMT-0400) America/Glace_Bay'), (b'America/Goose_Bay', b'(GMT-0400) America/Goose_Bay'), (b'America/Grand_Turk', b'(GMT-0400) America/Grand_Turk'), (b'America/Grenada', b'(GMT-0400) America/Grenada'), (b'America/Guadeloupe', b'(GMT-0400) America/Guadeloupe'), (b'America/Guyana', b'(GMT-0400) America/Guyana'), (b'America/Halifax', b'(GMT-0400) America/Halifax'), (b'America/Kralendijk', b'(GMT-0400) America/Kralendijk'), (b'America/La_Paz', b'(GMT-0400) America/La_Paz'), (b'America/Lower_Princes', b'(GMT-0400) America/Lower_Princes'), (b'America/Manaus', b'(GMT-0400) America/Manaus'), (b'America/Marigot', b'(GMT-0400) America/Marigot'), (b'America/Martinique', b'(GMT-0400) America/Martinique'), (b'America/Moncton', b'(GMT-0400) America/Moncton'), (b'America/Montserrat', b'(GMT-0400) America/Montserrat'), (b'America/Port_of_Spain', b'(GMT-0400) America/Port_of_Spain'), (b'America/Porto_Velho', b'(GMT-0400) America/Porto_Velho'), (b'America/Puerto_Rico', b'(GMT-0400) America/Puerto_Rico'), (b'America/Santo_Domingo', b'(GMT-0400) America/Santo_Domingo'), (b'America/St_Barthelemy', b'(GMT-0400) America/St_Barthelemy'), (b'America/St_Kitts', b'(GMT-0400) America/St_Kitts'), (b'America/St_Lucia', b'(GMT-0400) America/St_Lucia'), (b'America/St_Thomas', b'(GMT-0400) America/St_Thomas'), (b'America/St_Vincent', b'(GMT-0400) America/St_Vincent'), (b'America/Thule', b'(GMT-0400) America/Thule'), (b'America/Tortola', b'(GMT-0400) America/Tortola'), (b'Atlantic/Bermuda', b'(GMT-0400) Atlantic/Bermuda'), (b'Canada/Atlantic', b'(GMT-0400) Canada/Atlantic'), (b'America/St_Johns', b'(GMT-0330) America/St_Johns'), (b'Canada/Newfoundland', b'(GMT-0330) Canada/Newfoundland'), (b'America/Araguaina', b'(GMT-0300) America/Araguaina'), (b'America/Argentina/Buenos_Aires', b'(GMT-0300) America/Argentina/Buenos_Aires'), (b'America/Argentina/Catamarca', b'(GMT-0300) America/Argentina/Catamarca'), (b'America/Argentina/Cordoba', b'(GMT-0300) America/Argentina/Cordoba'), (b'America/Argentina/Jujuy', b'(GMT-0300) America/Argentina/Jujuy'), (b'America/Argentina/La_Rioja', b'(GMT-0300) America/Argentina/La_Rioja'), (b'America/Argentina/Mendoza', b'(GMT-0300) America/Argentina/Mendoza'), (b'America/Argentina/Rio_Gallegos', b'(GMT-0300) America/Argentina/Rio_Gallegos'), (b'America/Argentina/Salta', b'(GMT-0300) America/Argentina/Salta'), (b'America/Argentina/San_Juan', b'(GMT-0300) America/Argentina/San_Juan'), (b'America/Argentina/San_Luis', b'(GMT-0300) America/Argentina/San_Luis'), (b'America/Argentina/Tucuman', b'(GMT-0300) America/Argentina/Tucuman'), (b'America/Argentina/Ushuaia', b'(GMT-0300) America/Argentina/Ushuaia'), (b'America/Asuncion', b'(GMT-0300) America/Asuncion'), (b'America/Bahia', b'(GMT-0300) America/Bahia'), (b'America/Belem', b'(GMT-0300) America/Belem'), (b'America/Campo_Grande', b'(GMT-0300) America/Campo_Grande'), (b'America/Cayenne', b'(GMT-0300) America/Cayenne'), (b'America/Cuiaba', b'(GMT-0300) America/Cuiaba'), (b'America/Fortaleza', b'(GMT-0300) America/Fortaleza'), (b'America/Godthab', b'(GMT-0300) America/Godthab'), (b'America/Maceio', b'(GMT-0300) America/Maceio'), (b'America/Miquelon', b'(GMT-0300) America/Miquelon'), (b'America/Paramaribo', b'(GMT-0300) America/Paramaribo'), (b'America/Recife', b'(GMT-0300) America/Recife'), (b'America/Santarem', b'(GMT-0300) America/Santarem'), (b'America/Santiago', b'(GMT-0300) America/Santiago'), (b'Antarctica/Palmer', b'(GMT-0300) Antarctica/Palmer'), (b'Antarctica/Rothera', b'(GMT-0300) Antarctica/Rothera'), (b'Atlantic/Stanley', b'(GMT-0300) Atlantic/Stanley'), (b'America/Montevideo', b'(GMT-0200) America/Montevideo'), (b'America/Noronha', b'(GMT-0200) America/Noronha'), (b'America/Sao_Paulo', b'(GMT-0200) America/Sao_Paulo'), (b'Atlantic/South_Georgia', b'(GMT-0200) Atlantic/South_Georgia'), (b'America/Scoresbysund', b'(GMT-0100) America/Scoresbysund'), (b'Atlantic/Azores', b'(GMT-0100) Atlantic/Azores'), (b'Atlantic/Cape_Verde', b'(GMT-0100) Atlantic/Cape_Verde'), (b'Africa/Abidjan', b'(GMT+0000) Africa/Abidjan'), (b'Africa/Accra', b'(GMT+0000) Africa/Accra'), (b'Africa/Bamako', b'(GMT+0000) Africa/Bamako'), (b'Africa/Banjul', b'(GMT+0000) Africa/Banjul'), (b'Africa/Bissau', b'(GMT+0000) Africa/Bissau'), (b'Africa/Casablanca', b'(GMT+0000) Africa/Casablanca'), (b'Africa/Conakry', b'(GMT+0000) Africa/Conakry'), (b'Africa/Dakar', b'(GMT+0000) Africa/Dakar'), (b'Africa/El_Aaiun', b'(GMT+0000) Africa/El_Aaiun'), (b'Africa/Freetown', b'(GMT+0000) Africa/Freetown'), (b'Africa/Lome', b'(GMT+0000) Africa/Lome'), (b'Africa/Monrovia', b'(GMT+0000) Africa/Monrovia'), (b'Africa/Nouakchott', b'(GMT+0000) Africa/Nouakchott'), (b'Africa/Ouagadougou', b'(GMT+0000) Africa/Ouagadougou'), (b'Africa/Sao_Tome', b'(GMT+0000) Africa/Sao_Tome'), (b'America/Danmarkshavn', b'(GMT+0000) America/Danmarkshavn'), (b'Antarctica/Troll', b'(GMT+0000) Antarctica/Troll'), (b'Atlantic/Canary', b'(GMT+0000) Atlantic/Canary'), (b'Atlantic/Faroe', b'(GMT+0000) Atlantic/Faroe'), (b'Atlantic/Madeira', b'(GMT+0000) Atlantic/Madeira'), (b'Atlantic/Reykjavik', b'(GMT+0000) Atlantic/Reykjavik'), (b'Atlantic/St_Helena', b'(GMT+0000) Atlantic/St_Helena'), (b'Europe/Dublin', b'(GMT+0000) Europe/Dublin'), (b'Europe/Guernsey', b'(GMT+0000) Europe/Guernsey'), (b'Europe/Isle_of_Man', b'(GMT+0000) Europe/Isle_of_Man'), (b'Europe/Jersey', b'(GMT+0000) Europe/Jersey'), (b'Europe/Lisbon', b'(GMT+0000) Europe/Lisbon'), (b'Europe/London', b'(GMT+0000) Europe/London'), (b'GMT', b'(GMT+0000) GMT'), (b'UTC', b'(GMT+0000) UTC'), (b'Africa/Algiers', b'(GMT+0100) Africa/Algiers'), (b'Africa/Bangui', b'(GMT+0100) Africa/Bangui'), (b'Africa/Brazzaville', b'(GMT+0100) Africa/Brazzaville'), (b'Africa/Ceuta', b'(GMT+0100) Africa/Ceuta'), (b'Africa/Douala', b'(GMT+0100) Africa/Douala'), (b'Africa/Kinshasa', b'(GMT+0100) Africa/Kinshasa'), (b'Africa/Lagos', b'(GMT+0100) Africa/Lagos'), (b'Africa/Libreville', b'(GMT+0100) Africa/Libreville'), (b'Africa/Luanda', b'(GMT+0100) Africa/Luanda'), (b'Africa/Malabo', b'(GMT+0100) Africa/Malabo'), (b'Africa/Ndjamena', b'(GMT+0100) Africa/Ndjamena'), (b'Africa/Niamey', b'(GMT+0100) Africa/Niamey'), (b'Africa/Porto-Novo', b'(GMT+0100) Africa/Porto-Novo'), (b'Africa/Tunis', b'(GMT+0100) Africa/Tunis'), (b'Arctic/Longyearbyen', b'(GMT+0100) Arctic/Longyearbyen'), (b'Europe/Amsterdam', b'(GMT+0100) Europe/Amsterdam'), (b'Europe/Andorra', b'(GMT+0100) Europe/Andorra'), (b'Europe/Belgrade', b'(GMT+0100) Europe/Belgrade'), (b'Europe/Berlin', b'(GMT+0100) Europe/Berlin'), (b'Europe/Bratislava', b'(GMT+0100) Europe/Bratislava'), (b'Europe/Brussels', b'(GMT+0100) Europe/Brussels'), (b'Europe/Budapest', b'(GMT+0100) Europe/Budapest'), (b'Europe/Busingen', b'(GMT+0100) Europe/Busingen'), (b'Europe/Copenhagen', b'(GMT+0100) Europe/Copenhagen'), (b'Europe/Gibraltar', b'(GMT+0100) Europe/Gibraltar'), (b'Europe/Ljubljana', b'(GMT+0100) Europe/Ljubljana'), (b'Europe/Luxembourg', b'(GMT+0100) Europe/Luxembourg'), (b'Europe/Madrid', b'(GMT+0100) Europe/Madrid'), (b'Europe/Malta', b'(GMT+0100) Europe/Malta'), (b'Europe/Monaco', b'(GMT+0100) Europe/Monaco'), (b'Europe/Oslo', b'(GMT+0100) Europe/Oslo'), (b'Europe/Paris', b'(GMT+0100) Europe/Paris'), (b'Europe/Podgorica', b'(GMT+0100) Europe/Podgorica'), (b'Europe/Prague', b'(GMT+0100) Europe/Prague'), (b'Europe/Rome', b'(GMT+0100) Europe/Rome'), (b'Europe/San_Marino', b'(GMT+0100) Europe/San_Marino'), (b'Europe/Sarajevo', b'(GMT+0100) Europe/Sarajevo'), (b'Europe/Skopje', b'(GMT+0100) Europe/Skopje'), (b'Europe/Stockholm', b'(GMT+0100) Europe/Stockholm'), (b'Europe/Tirane', b'(GMT+0100) Europe/Tirane'), (b'Europe/Vaduz', b'(GMT+0100) Europe/Vaduz'), (b'Europe/Vatican', b'(GMT+0100) Europe/Vatican'), (b'Europe/Vienna', b'(GMT+0100) Europe/Vienna'), (b'Europe/Warsaw', b'(GMT+0100) Europe/Warsaw'), (b'Europe/Zagreb', b'(GMT+0100) Europe/Zagreb'), (b'Europe/Zurich', b'(GMT+0100) Europe/Zurich'), (b'Africa/Blantyre', b'(GMT+0200) Africa/Blantyre'), (b'Africa/Bujumbura', b'(GMT+0200) Africa/Bujumbura'), (b'Africa/Cairo', b'(GMT+0200) Africa/Cairo'), (b'Africa/Gaborone', b'(GMT+0200) Africa/Gaborone'), (b'Africa/Harare', b'(GMT+0200) Africa/Harare'), (b'Africa/Johannesburg', b'(GMT+0200) Africa/Johannesburg'), (b'Africa/Kigali', b'(GMT+0200) Africa/Kigali'), (b'Africa/Lubumbashi', b'(GMT+0200) Africa/Lubumbashi'), (b'Africa/Lusaka', b'(GMT+0200) Africa/Lusaka'), (b'Africa/Maputo', b'(GMT+0200) Africa/Maputo'), (b'Africa/Maseru', b'(GMT+0200) Africa/Maseru'), (b'Africa/Mbabane', b'(GMT+0200) Africa/Mbabane'), (b'Africa/Tripoli', b'(GMT+0200) Africa/Tripoli'), (b'Africa/Windhoek', b'(GMT+0200) Africa/Windhoek'), (b'Asia/Amman', b'(GMT+0200) Asia/Amman'), (b'Asia/Beirut', b'(GMT+0200) Asia/Beirut'), (b'Asia/Damascus', b'(GMT+0200) Asia/Damascus'), (b'Asia/Gaza', b'(GMT+0200) Asia/Gaza'), (b'Asia/Hebron', b'(GMT+0200) Asia/Hebron'), (b'Asia/Jerusalem', b'(GMT+0200) Asia/Jerusalem'), (b'Asia/Nicosia', b'(GMT+0200) Asia/Nicosia'), (b'Europe/Athens', b'(GMT+0200) Europe/Athens'), (b'Europe/Bucharest', b'(GMT+0200) Europe/Bucharest'), (b'Europe/Chisinau', b'(GMT+0200) Europe/Chisinau'), (b'Europe/Helsinki', b'(GMT+0200) Europe/Helsinki'), (b'Europe/Istanbul', b'(GMT+0200) Europe/Istanbul'), (b'Europe/Kaliningrad', b'(GMT+0200) Europe/Kaliningrad'), (b'Europe/Kiev', b'(GMT+0200) Europe/Kiev'), (b'Europe/Mariehamn', b'(GMT+0200) Europe/Mariehamn'), (b'Europe/Riga', b'(GMT+0200) Europe/Riga'), (b'Europe/Sofia', b'(GMT+0200) Europe/Sofia'), (b'Europe/Tallinn', b'(GMT+0200) Europe/Tallinn'), (b'Europe/Uzhgorod', b'(GMT+0200) Europe/Uzhgorod'), (b'Europe/Vilnius', b'(GMT+0200) Europe/Vilnius'), (b'Europe/Zaporozhye', b'(GMT+0200) Europe/Zaporozhye'), (b'Africa/Addis_Ababa', b'(GMT+0300) Africa/Addis_Ababa'), (b'Africa/Asmara', b'(GMT+0300) Africa/Asmara'), (b'Africa/Dar_es_Salaam', b'(GMT+0300) Africa/Dar_es_Salaam'), (b'Africa/Djibouti', b'(GMT+0300) Africa/Djibouti'), (b'Africa/Juba', b'(GMT+0300) Africa/Juba'), (b'Africa/Kampala', b'(GMT+0300) Africa/Kampala'), (b'Africa/Khartoum', b'(GMT+0300) Africa/Khartoum'), (b'Africa/Mogadishu', b'(GMT+0300) Africa/Mogadishu'), (b'Africa/Nairobi', b'(GMT+0300) Africa/Nairobi'), (b'Antarctica/Syowa', b'(GMT+0300) Antarctica/Syowa'), (b'Asia/Aden', b'(GMT+0300) Asia/Aden'), (b'Asia/Baghdad', b'(GMT+0300) Asia/Baghdad'), (b'Asia/Bahrain', b'(GMT+0300) Asia/Bahrain'), (b'Asia/Kuwait', b'(GMT+0300) Asia/Kuwait'), (b'Asia/Qatar', b'(GMT+0300) Asia/Qatar'), (b'Asia/Riyadh', b'(GMT+0300) Asia/Riyadh'), (b'Europe/Minsk', b'(GMT+0300) Europe/Minsk'), (b'Europe/Moscow', b'(GMT+0300) Europe/Moscow'), (b'Europe/Simferopol', b'(GMT+0300) Europe/Simferopol'), (b'Europe/Volgograd', b'(GMT+0300) Europe/Volgograd'), (b'Indian/Antananarivo', b'(GMT+0300) Indian/Antananarivo'), (b'Indian/Comoro', b'(GMT+0300) Indian/Comoro'), (b'Indian/Mayotte', b'(GMT+0300) Indian/Mayotte'), (b'Asia/Tehran', b'(GMT+0330) Asia/Tehran'), (b'Asia/Baku', b'(GMT+0400) Asia/Baku'), (b'Asia/Dubai', b'(GMT+0400) Asia/Dubai'), (b'Asia/Muscat', b'(GMT+0400) Asia/Muscat'), (b'Asia/Tbilisi', b'(GMT+0400) Asia/Tbilisi'), (b'Asia/Yerevan', b'(GMT+0400) Asia/Yerevan'), (b'Europe/Samara', b'(GMT+0400) Europe/Samara'), (b'Indian/Mahe', b'(GMT+0400) Indian/Mahe'), (b'Indian/Mauritius', b'(GMT+0400) Indian/Mauritius'), (b'Indian/Reunion', b'(GMT+0400) Indian/Reunion'), (b'Asia/Kabul', b'(GMT+0430) Asia/Kabul'), (b'Antarctica/Mawson', b'(GMT+0500) Antarctica/Mawson'), (b'Asia/Aqtau', b'(GMT+0500) Asia/Aqtau'), (b'Asia/Aqtobe', b'(GMT+0500) Asia/Aqtobe'), (b'Asia/Ashgabat', b'(GMT+0500) Asia/Ashgabat'), (b'Asia/Dushanbe', b'(GMT+0500) Asia/Dushanbe'), (b'Asia/Karachi', b'(GMT+0500) Asia/Karachi'), (b'Asia/Oral', b'(GMT+0500) Asia/Oral'), (b'Asia/Samarkand', b'(GMT+0500) Asia/Samarkand'), (b'Asia/Tashkent', b'(GMT+0500) Asia/Tashkent'), (b'Asia/Yekaterinburg', b'(GMT+0500) Asia/Yekaterinburg'), (b'Indian/Kerguelen', b'(GMT+0500) Indian/Kerguelen'), (b'Indian/Maldives', b'(GMT+0500) Indian/Maldives'), (b'Asia/Colombo', b'(GMT+0530) Asia/Colombo'), (b'Asia/Kolkata', b'(GMT+0530) Asia/Kolkata'), (b'Asia/Kathmandu', b'(GMT+0545) Asia/Kathmandu'), (b'Antarctica/Vostok', b'(GMT+0600) Antarctica/Vostok'), (b'Asia/Almaty', b'(GMT+0600) Asia/Almaty'), (b'Asia/Bishkek', b'(GMT+0600) Asia/Bishkek'), (b'Asia/Dhaka', b'(GMT+0600) Asia/Dhaka'), (b'Asia/Novosibirsk', b'(GMT+0600) Asia/Novosibirsk'), (b'Asia/Omsk', b'(GMT+0600) Asia/Omsk'), (b'Asia/Qyzylorda', b'(GMT+0600) Asia/Qyzylorda'), (b'Asia/Thimphu', b'(GMT+0600) Asia/Thimphu'), (b'Asia/Urumqi', b'(GMT+0600) Asia/Urumqi'), (b'Indian/Chagos', b'(GMT+0600) Indian/Chagos'), (b'Asia/Rangoon', b'(GMT+0630) Asia/Rangoon'), (b'Indian/Cocos', b'(GMT+0630) Indian/Cocos'), (b'Antarctica/Davis', b'(GMT+0700) Antarctica/Davis'), (b'Asia/Bangkok', b'(GMT+0700) Asia/Bangkok'), (b'Asia/Ho_Chi_Minh', b'(GMT+0700) Asia/Ho_Chi_Minh'), (b'Asia/Hovd', b'(GMT+0700) Asia/Hovd'), (b'Asia/Jakarta', b'(GMT+0700) Asia/Jakarta'), (b'Asia/Krasnoyarsk', b'(GMT+0700) Asia/Krasnoyarsk'), (b'Asia/Novokuznetsk', b'(GMT+0700) Asia/Novokuznetsk'), (b'Asia/Phnom_Penh', b'(GMT+0700) Asia/Phnom_Penh'), (b'Asia/Pontianak', b'(GMT+0700) Asia/Pontianak'), (b'Asia/Vientiane', b'(GMT+0700) Asia/Vientiane'), (b'Indian/Christmas', b'(GMT+0700) Indian/Christmas'), (b'Antarctica/Casey', b'(GMT+0800) Antarctica/Casey'), (b'Asia/Brunei', b'(GMT+0800) Asia/Brunei'), (b'Asia/Chita', b'(GMT+0800) Asia/Chita'), (b'Asia/Choibalsan', b'(GMT+0800) Asia/Choibalsan'), (b'Asia/Hong_Kong', b'(GMT+0800) Asia/Hong_Kong'), (b'Asia/Irkutsk', b'(GMT+0800) Asia/Irkutsk'), (b'Asia/Kuala_Lumpur', b'(GMT+0800) Asia/Kuala_Lumpur'), (b'Asia/Kuching', b'(GMT+0800) Asia/Kuching'), (b'Asia/Macau', b'(GMT+0800) Asia/Macau'), (b'Asia/Makassar', b'(GMT+0800) Asia/Makassar'), (b'Asia/Manila', b'(GMT+0800) Asia/Manila'), (b'Asia/Shanghai', b'(GMT+0800) Asia/Shanghai'), (b'Asia/Singapore', b'(GMT+0800) Asia/Singapore'), (b'Asia/Taipei', b'(GMT+0800) Asia/Taipei'), (b'Asia/Ulaanbaatar', b'(GMT+0800) Asia/Ulaanbaatar'), (b'Australia/Perth', b'(GMT+0800) Australia/Perth'), (b'Australia/Eucla', b'(GMT+0845) Australia/Eucla'), (b'Asia/Dili', b'(GMT+0900) Asia/Dili'), (b'Asia/Jayapura', b'(GMT+0900) Asia/Jayapura'), (b'Asia/Khandyga', b'(GMT+0900) Asia/Khandyga'), (b'Asia/Pyongyang', b'(GMT+0900) Asia/Pyongyang'), (b'Asia/Seoul', b'(GMT+0900) Asia/Seoul'), (b'Asia/Tokyo', b'(GMT+0900) Asia/Tokyo'), (b'Asia/Yakutsk', b'(GMT+0900) Asia/Yakutsk'), (b'Pacific/Palau', b'(GMT+0900) Pacific/Palau'), (b'Australia/Darwin', b'(GMT+0930) Australia/Darwin'), (b'Antarctica/DumontDUrville', b'(GMT+1000) Antarctica/DumontDUrville'), (b'Asia/Magadan', b'(GMT+1000) Asia/Magadan'), (b'Asia/Sakhalin', b'(GMT+1000) Asia/Sakhalin'), (b'Asia/Ust-Nera', b'(GMT+1000) Asia/Ust-Nera'), (b'Asia/Vladivostok', b'(GMT+1000) Asia/Vladivostok'), (b'Australia/Brisbane', b'(GMT+1000) Australia/Brisbane'), (b'Australia/Lindeman', b'(GMT+1000) Australia/Lindeman'), (b'Pacific/Chuuk', b'(GMT+1000) Pacific/Chuuk'), (b'Pacific/Guam', b'(GMT+1000) Pacific/Guam'), (b'Pacific/Port_Moresby', b'(GMT+1000) Pacific/Port_Moresby'), (b'Pacific/Saipan', b'(GMT+1000) Pacific/Saipan'), (b'Australia/Adelaide', b'(GMT+1030) Australia/Adelaide'), (b'Australia/Broken_Hill', b'(GMT+1030) Australia/Broken_Hill'), (b'Antarctica/Macquarie', b'(GMT+1100) Antarctica/Macquarie'), (b'Asia/Srednekolymsk', b'(GMT+1100) Asia/Srednekolymsk'), (b'Australia/Currie', b'(GMT+1100) Australia/Currie'), (b'Australia/Hobart', b'(GMT+1100) Australia/Hobart'), (b'Australia/Lord_Howe', b'(GMT+1100) Australia/Lord_Howe'), (b'Australia/Melbourne', b'(GMT+1100) Australia/Melbourne'), (b'Australia/Sydney', b'(GMT+1100) Australia/Sydney'), (b'Pacific/Efate', b'(GMT+1100) Pacific/Efate'), (b'Pacific/Guadalcanal', b'(GMT+1100) Pacific/Guadalcanal'), (b'Pacific/Kosrae', b'(GMT+1100) Pacific/Kosrae'), (b'Pacific/Noumea', b'(GMT+1100) Pacific/Noumea'), (b'Pacific/Pohnpei', b'(GMT+1100) Pacific/Pohnpei'), (b'Pacific/Norfolk', b'(GMT+1130) Pacific/Norfolk'), (b'Asia/Anadyr', b'(GMT+1200) Asia/Anadyr'), (b'Asia/Kamchatka', b'(GMT+1200) Asia/Kamchatka'), (b'Pacific/Funafuti', b'(GMT+1200) Pacific/Funafuti'), (b'Pacific/Kwajalein', b'(GMT+1200) Pacific/Kwajalein'), (b'Pacific/Majuro', b'(GMT+1200) Pacific/Majuro'), (b'Pacific/Nauru', b'(GMT+1200) Pacific/Nauru'), (b'Pacific/Tarawa', b'(GMT+1200) Pacific/Tarawa'), (b'Pacific/Wake', b'(GMT+1200) Pacific/Wake'), (b'Pacific/Wallis', b'(GMT+1200) Pacific/Wallis'), (b'Antarctica/McMurdo', b'(GMT+1300) Antarctica/McMurdo'), (b'Pacific/Auckland', b'(GMT+1300) Pacific/Auckland'), (b'Pacific/Enderbury', b'(GMT+1300) Pacific/Enderbury'), (b'Pacific/Fakaofo', b'(GMT+1300) Pacific/Fakaofo'), (b'Pacific/Fiji', b'(GMT+1300) Pacific/Fiji'), (b'Pacific/Tongatapu', b'(GMT+1300) Pacific/Tongatapu'), (b'Pacific/Chatham', b'(GMT+1345) Pacific/Chatham'), (b'Pacific/Apia', b'(GMT+1400) Pacific/Apia'), (b'Pacific/Kiritimati', b'(GMT+1400) Pacific/Kiritimati')])), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Account', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Charge', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('kind', models.CharField(default=b'besteffort', max_length=30, choices=[(b'besteffort', b'besteffort'), (b'reservation', b'reservation'), (b'monthlyfee', b'monthlyfee')])), + ('state', models.CharField(default=b'pending', max_length=30, choices=[(b'pending', b'pending'), (b'invoiced', b'invoiced')])), + ('date', models.DateTimeField()), + ('amount', models.FloatField(default=0.0)), + ('coreHours', models.FloatField(default=0.0)), + ('account', models.ForeignKey(related_name=b'charges', to='core.Account')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Controller', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name of the Controller', unique=True, max_length=200)), + ('version', models.CharField(help_text=b'Controller version', unique=True, max_length=200)), + ('backend_type', models.CharField(help_text=b'Type of compute controller, e.g. EC2, OpenStack, or OpenStack version', max_length=200, null=True, blank=True)), + ('auth_url', models.CharField(help_text=b'Auth url for the compute controller', max_length=200, null=True, blank=True)), + ('admin_user', models.CharField(help_text=b'Username of an admin user at this controller', max_length=200, null=True, blank=True)), + ('admin_password', models.CharField(help_text=b'Password of theadmin user at this controller', max_length=200, null=True, blank=True)), + ('admin_tenant', models.CharField(help_text=b'Name of the tenant the admin user belongs to', max_length=200, null=True, blank=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerCredential', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The credential type, e.g. ec2', max_length=128)), + ('key_id', models.CharField(help_text=b'The backend id of this credential', max_length=1024)), + ('enc_value', encrypted_fields.fields.EncryptedCharField(help_text=b'The key value of this credential', max_length=1024)), + ('controller', models.ForeignKey(related_name=b'controllercredentials', to='core.Controller', help_text=b'The User this credential is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerDashboardView', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('url', models.CharField(help_text=b'URL of Dashboard', max_length=1024)), + ('controller', models.ForeignKey(related_name=b'controllerdashboardviews', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerImages', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('glance_image_id', models.CharField(help_text=b'Glance image id', max_length=200, null=True, blank=True)), + ('controller', models.ForeignKey(related_name=b'controllerimages', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerNetworks', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('net_id', models.CharField(help_text=b'Quantum network', max_length=256, null=True, blank=True)), + ('router_id', models.CharField(help_text=b'Quantum router id', max_length=256, null=True, blank=True)), + ('subnet_id', models.CharField(help_text=b'Quantum subnet id', max_length=256, null=True, blank=True)), + ('subnet', models.CharField(max_length=32, blank=True)), + ('controller', models.ForeignKey(related_name=b'controllernetworks', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerPrivilege', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('controller', models.ForeignKey(related_name=b'controllerprivileges', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerRole', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role', models.CharField(unique=True, max_length=30, choices=[(b'admin', b'Admin')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerSiteDeployments', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('tenant_id', models.CharField(help_text=b'Keystone tenant id', max_length=200, null=True, blank=True)), + ('controller', models.ForeignKey(related_name=b'controllersitedeployments', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerSlices', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('tenant_id', models.CharField(help_text=b'Keystone tenant id', max_length=200, null=True, blank=True)), + ('controller', models.ForeignKey(related_name=b'controllerslices', to='core.Controller')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ControllerUsers', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('kuser_id', models.CharField(help_text=b'Keystone user id', max_length=200, null=True, blank=True)), + ('controller', models.ForeignKey(related_name=b'controllersusers', to='core.Controller')), + ('user', models.ForeignKey(related_name=b'controllerusers', to=settings.AUTH_USER_MODEL)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='DashboardView', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name of the View', unique=True, max_length=200)), + ('url', models.CharField(help_text=b'URL of Dashboard', max_length=1024)), + ('controllers', models.ManyToManyField(related_name=b'dashboardviews', through='core.ControllerDashboardView', to='core.Controller', blank=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Deployment', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name of the Deployment', unique=True, max_length=200)), + ('accessControl', models.TextField(default=b'allow all', help_text=b'Access control list that specifies which sites/users may use nodes in this deployment', max_length=200)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='DeploymentPrivilege', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('deployment', models.ForeignKey(related_name=b'deploymentprivileges', to='core.Deployment')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='DeploymentRole', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role', models.CharField(unique=True, max_length=30, choices=[(b'admin', b'Admin')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Flavor', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'name of this flavor, as displayed to users', max_length=32)), + ('description', models.CharField(max_length=1024, null=True, blank=True)), + ('flavor', models.CharField(help_text=b'flavor string used to configure deployments', max_length=32)), + ('order', models.IntegerField(default=0, help_text=b'used to order flavors when displayed in a list')), + ('default', models.BooleanField(default=False, help_text=b'make this a default flavor to use when creating new instances')), + ('deployments', models.ManyToManyField(related_name=b'flavors', to='core.Deployment', blank=True)), + ], + options={ + 'ordering': ('order', 'name'), + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Image', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(unique=True, max_length=256)), + ('disk_format', models.CharField(max_length=256)), + ('container_format', models.CharField(max_length=256)), + ('path', models.CharField(help_text=b'Path to image on local disk', max_length=256, null=True, blank=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ImageDeployments', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('deployment', models.ForeignKey(related_name=b'imagedeployments', to='core.Deployment')), + ('image', models.ForeignKey(related_name=b'imagedeployments', to='core.Image')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Invoice', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('date', models.DateTimeField()), + ('account', models.ForeignKey(related_name=b'invoices', to='core.Account')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Network', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=32)), + ('subnet', models.CharField(max_length=32, blank=True)), + ('ports', models.CharField(blank=True, max_length=1024, null=True, validators=[core.models.network.ValidateNatList])), + ('labels', models.CharField(max_length=1024, null=True, blank=True)), + ('guaranteedBandwidth', models.IntegerField(default=0)), + ('permitAllSlices', models.BooleanField(default=False)), + ('topologyParameters', models.TextField(null=True, blank=True)), + ('controllerUrl', models.CharField(max_length=1024, null=True, blank=True)), + ('controllerParameters', models.TextField(null=True, blank=True)), + ('network_id', models.CharField(help_text=b'Quantum network', max_length=256, null=True, blank=True)), + ('router_id', models.CharField(help_text=b'Quantum router id', max_length=256, null=True, blank=True)), + ('subnet_id', models.CharField(help_text=b'Quantum subnet id', max_length=256, null=True, blank=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='NetworkParameter', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('value', models.CharField(help_text=b'The value of this parameter', max_length=1024)), + ('object_id', models.PositiveIntegerField()), + ('content_type', models.ForeignKey(to='contenttypes.ContentType')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='NetworkParameterType', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The name of this parameter', max_length=128)), + ('description', models.CharField(max_length=1024)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='NetworkSlice', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('network', models.ForeignKey(related_name=b'networkslices', to='core.Network')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='NetworkSliver', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('ip', models.GenericIPAddressField(help_text=b'Sliver ip address', null=True, blank=True)), + ('port_id', models.CharField(help_text=b'Quantum port id', max_length=256, null=True, blank=True)), + ('network', models.ForeignKey(related_name=b'networkslivers', to='core.Network')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='NetworkTemplate', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=32)), + ('description', models.CharField(max_length=1024, null=True, blank=True)), + ('guaranteedBandwidth', models.IntegerField(default=0)), + ('visibility', models.CharField(default=b'private', max_length=30, choices=[(b'public', b'public'), (b'private', b'private')])), + ('translation', models.CharField(default=b'none', max_length=30, choices=[(b'none', b'none'), (b'NAT', b'NAT')])), + ('sharedNetworkName', models.CharField(max_length=30, null=True, blank=True)), + ('sharedNetworkId', models.CharField(help_text=b'Quantum network', max_length=256, null=True, blank=True)), + ('topologyKind', models.CharField(default=b'BigSwitch', max_length=30, choices=[(b'bigswitch', b'BigSwitch'), (b'physical', b'Physical'), (b'custom', b'Custom')])), + ('controllerKind', models.CharField(default=None, max_length=30, null=True, blank=True, choices=[(None, b'None'), (b'onos', b'ONOS'), (b'custom', b'Custom')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Node', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name of the Node', unique=True, max_length=200)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Payment', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('amount', models.FloatField(default=0.0)), + ('date', models.DateTimeField(default=django.utils.timezone.now)), + ('account', models.ForeignKey(related_name=b'payments', to='core.Account')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='PlanetStack', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('description', models.CharField(default=b'PlanetStack', help_text=b'Used for scoping of roles at the PlanetStack Application level', unique=True, max_length=200)), + ], + options={ + 'verbose_name_plural': 'PlanetStack', + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='PlanetStackPrivilege', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('planetstack', models.ForeignKey(related_name=b'planetstackprivileges', default=1, to='core.PlanetStack')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='PlanetStackRole', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role', models.CharField(unique=True, max_length=30, choices=[(b'admin', b'Admin')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Project', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name of Project', unique=True, max_length=200)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Reservation', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('startTime', models.DateTimeField()), + ('duration', models.IntegerField(default=1)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ReservedResource', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('quantity', models.IntegerField(default=1)), + ('reservationSet', models.ForeignKey(related_name=b'reservedresources', to='core.Reservation')), + ], + options={ + 'abstract': False, + 'verbose_name_plural': 'Reserved Resources', + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Role', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role_type', models.CharField(max_length=80, verbose_name=b'Name')), + ('role', models.CharField(max_length=80, null=True, verbose_name=b'Keystone role id', blank=True)), + ('description', models.CharField(max_length=120, verbose_name=b'Description')), + ('content_type', models.ForeignKey(verbose_name=b'Role Scope', to='contenttypes.ContentType')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Router', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=32)), + ('networks', models.ManyToManyField(related_name=b'routers', to='core.Network', blank=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Service', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('description', models.TextField(help_text=b'Description of Service', max_length=254, null=True, blank=True)), + ('enabled', models.BooleanField(default=True)), + ('name', models.CharField(help_text=b'Service Name', max_length=30)), + ('versionNumber', models.CharField(help_text=b'Version of Service Definition', max_length=30)), + ('published', models.BooleanField(default=True)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ServiceAttribute', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'Attribute Name', max_length=128)), + ('value', models.CharField(help_text=b'Attribute Value', max_length=1024)), + ('service', models.ForeignKey(related_name=b'serviceattributes', to='core.Service', help_text=b'The Service this attribute is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ServiceClass', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=32)), + ('description', models.CharField(max_length=255)), + ('commitment', models.IntegerField(default=365)), + ('membershipFee', models.IntegerField(default=0)), + ('membershipFeeMonths', models.IntegerField(default=12)), + ('upgradeRequiresApproval', models.BooleanField(default=False)), + ('upgradeFrom', models.ManyToManyField(related_name='upgradeFrom_rel_+', null=True, to='core.ServiceClass', blank=True)), + ], + options={ + 'abstract': False, + 'verbose_name_plural': 'Service classes', + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ServiceResource', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=32)), + ('maxUnitsDeployment', models.IntegerField(default=1)), + ('maxUnitsNode', models.IntegerField(default=1)), + ('maxDuration', models.IntegerField(default=1)), + ('bucketInRate', models.IntegerField(default=0)), + ('bucketMaxSize', models.IntegerField(default=0)), + ('cost', models.IntegerField(default=0)), + ('calendarReservable', models.BooleanField(default=True)), + ('serviceClass', models.ForeignKey(related_name=b'serviceresources', to='core.ServiceClass')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Site', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Name for this Site', max_length=200)), + ('site_url', models.URLField(help_text=b"Site's Home URL Page", max_length=512, null=True, blank=True)), + ('enabled', models.BooleanField(default=True, help_text=b'Status for this Site')), + ('location', geoposition.fields.GeopositionField(max_length=42)), + ('longitude', models.FloatField(null=True, blank=True)), + ('latitude', models.FloatField(null=True, blank=True)), + ('login_base', models.CharField(help_text=b'Prefix for Slices associated with this Site', unique=True, max_length=50)), + ('is_public', models.BooleanField(default=True, help_text=b'Indicates the visibility of this site to other members')), + ('abbreviated_name', models.CharField(max_length=80)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SiteCredential', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The credential type, e.g. ec2', max_length=128)), + ('key_id', models.CharField(help_text=b'The backend id of this credential', max_length=1024)), + ('enc_value', encrypted_fields.fields.EncryptedCharField(help_text=b'The key value of this credential', max_length=1024)), + ('site', models.ForeignKey(related_name=b'sitecredentials', to='core.Site', help_text=b'The User this credential is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SiteDeployments', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('availability_zone', models.CharField(help_text=b'OpenStack availability zone', max_length=200, null=True, blank=True)), + ('controller', models.ForeignKey(related_name=b'sitedeployments', blank=True, to='core.Controller', null=True)), + ('deployment', models.ForeignKey(related_name=b'sitedeployments', to='core.Deployment')), + ('site', models.ForeignKey(related_name=b'sitedeployments', to='core.Site')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SitePrivilege', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SiteRole', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role', models.CharField(unique=True, max_length=30, choices=[(b'admin', b'Admin'), (b'pi', b'PI'), (b'tech', b'Tech'), (b'billing', b'Billing')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Slice', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'The Name of the Slice', unique=True, max_length=80)), + ('enabled', models.BooleanField(default=True, help_text=b'Status for this Slice')), + ('omf_friendly', models.BooleanField(default=False)), + ('description', models.TextField(help_text=b'High level description of the slice and expected activities', max_length=1024, blank=True)), + ('slice_url', models.URLField(max_length=512, blank=True)), + ('max_slivers', models.IntegerField(default=10)), + ('imagePreference', models.CharField(default=b'Ubuntu 12.04 LTS', max_length=256, null=True, blank=True)), + ('network', models.CharField(default=b'Private Only', max_length=256, null=True, blank=True)), + ('mountDataSets', models.CharField(default=b'GenBank', max_length=256, null=True, blank=True)), + ('creator', models.ForeignKey(related_name=b'slices', blank=True, to=settings.AUTH_USER_MODEL, null=True)), + ('service', models.ForeignKey(related_name=b'service', blank=True, to='core.Service', null=True)), + ('serviceClass', models.ForeignKey(related_name=b'slices', default=core.models.serviceclass.get_default_serviceclass, to='core.ServiceClass', null=True)), + ('site', models.ForeignKey(related_name=b'slices', to='core.Site', help_text=b'The Site this Slice belongs to')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SliceCredential', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The credential type, e.g. ec2', max_length=128)), + ('key_id', models.CharField(help_text=b'The backend id of this credential', max_length=1024)), + ('enc_value', encrypted_fields.fields.EncryptedCharField(help_text=b'The key value of this credential', max_length=1024)), + ('slice', models.ForeignKey(related_name=b'slicecredentials', to='core.Slice', help_text=b'The User this credential is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SlicePrivilege', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SliceRole', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('role', models.CharField(unique=True, max_length=30, choices=[(b'admin', b'Admin'), (b'default', b'Default')])), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SliceTag', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'The name of this tag', max_length=30, choices=[(b'privatekey', b'Private Key'), (b'publickey', b'Public Key')])), + ('value', models.CharField(help_text=b'The value of this tag', max_length=1024)), + ('slice', models.ForeignKey(related_name=b'slicetags', to='core.Slice')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Sliver', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('instance_id', models.CharField(help_text=b'Nova instance id', max_length=200, null=True, blank=True)), + ('name', models.CharField(help_text=b'Sliver name', max_length=200)), + ('instance_name', models.CharField(help_text=b'OpenStack generated name', max_length=200, null=True, blank=True)), + ('ip', models.GenericIPAddressField(help_text=b'Sliver ip address', null=True, blank=True)), + ('numberCores', models.IntegerField(default=0, help_text=b'Number of cores for sliver', verbose_name=b'Number of Cores')), + ('userData', models.TextField(help_text=b'user_data passed to instance during creation', null=True, blank=True)), + ('controllerNetwork', models.ForeignKey(related_name=b'sliver_controllerNetwork', verbose_name=b'controller', to='core.Controller')), + ('creator', models.ForeignKey(related_name=b'slivers', blank=True, to=settings.AUTH_USER_MODEL, null=True)), + ('flavor', models.ForeignKey(default=core.models.sliver.get_default_flavor, to='core.Flavor', help_text=b'Flavor of this instance')), + ('image', models.ForeignKey(related_name=b'slivers', to='core.Image')), + ('node', models.ForeignKey(related_name=b'slivers', to='core.Node')), + ('slice', models.ForeignKey(related_name=b'slivers', to='core.Slice')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='Tag', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The name of this tag', max_length=128)), + ('value', models.CharField(help_text=b'The value of this tag', max_length=1024)), + ('object_id', models.PositiveIntegerField()), + ('content_type', models.ForeignKey(to='contenttypes.ContentType')), + ('service', models.ForeignKey(related_name=b'tags', to='core.Service', help_text=b'The Service this Tag is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='UsableObject', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(max_length=1024)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='UserCredential', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'The credential type, e.g. ec2', max_length=128)), + ('key_id', models.CharField(help_text=b'The backend id of this credential', max_length=1024)), + ('enc_value', encrypted_fields.fields.EncryptedCharField(help_text=b'The key value of this credential', max_length=1024)), + ('user', models.ForeignKey(related_name=b'usercredentials', to=settings.AUTH_USER_MODEL, help_text=b'The User this credential is associated with')), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='UserDashboardView', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('order', models.IntegerField(default=0)), + ('dashboardView', models.ForeignKey(related_name=b'userdashboardviews', to='core.DashboardView')), + ('user', models.ForeignKey(related_name=b'userdashboardviews', to=settings.AUTH_USER_MODEL)), + ], + options={ + 'abstract': False, + }, + bases=(models.Model,), + ), + migrations.AddField( + model_name='sliceprivilege', + name='role', + field=models.ForeignKey(related_name=b'sliceprivileges', to='core.SliceRole'), + preserve_default=True, + ), + migrations.AddField( + model_name='sliceprivilege', + name='slice', + field=models.ForeignKey(related_name=b'sliceprivileges', to='core.Slice'), + preserve_default=True, + ), + migrations.AddField( + model_name='sliceprivilege', + name='user', + field=models.ForeignKey(related_name=b'sliceprivileges', to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='siteprivilege', + name='role', + field=models.ForeignKey(related_name=b'siteprivileges', to='core.SiteRole'), + preserve_default=True, + ), + migrations.AddField( + model_name='siteprivilege', + name='site', + field=models.ForeignKey(related_name=b'siteprivileges', to='core.Site'), + preserve_default=True, + ), + migrations.AddField( + model_name='siteprivilege', + name='user', + field=models.ForeignKey(related_name=b'siteprivileges', to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='site', + name='deployments', + field=models.ManyToManyField(help_text=b'Select which sites are allowed to host nodes in this deployment', related_name=b'sites', through='core.SiteDeployments', to='core.Deployment', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='router', + name='owner', + field=models.ForeignKey(related_name=b'routers', to='core.Slice'), + preserve_default=True, + ), + migrations.AddField( + model_name='router', + name='permittedNetworks', + field=models.ManyToManyField(related_name=b'availableRouters', to='core.Network', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='reservedresource', + name='resource', + field=models.ForeignKey(related_name=b'reservedresources', to='core.ServiceResource'), + preserve_default=True, + ), + migrations.AddField( + model_name='reservedresource', + name='sliver', + field=models.ForeignKey(related_name=b'reservedresources', to='core.Sliver'), + preserve_default=True, + ), + migrations.AddField( + model_name='reservation', + name='slice', + field=models.ForeignKey(related_name=b'reservations', to='core.Slice'), + preserve_default=True, + ), + migrations.AddField( + model_name='planetstackprivilege', + name='role', + field=models.ForeignKey(to='core.PlanetStackRole'), + preserve_default=True, + ), + migrations.AddField( + model_name='planetstackprivilege', + name='user', + field=models.ForeignKey(related_name=b'planetstackprivileges', to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='node', + name='site_deployment', + field=models.ForeignKey(related_name=b'nodes', to='core.SiteDeployments'), + preserve_default=True, + ), + migrations.AddField( + model_name='networksliver', + name='sliver', + field=models.ForeignKey(related_name=b'networkslivers', to='core.Sliver'), + preserve_default=True, + ), + migrations.AddField( + model_name='networkslice', + name='slice', + field=models.ForeignKey(related_name=b'networkslices', to='core.Slice'), + preserve_default=True, + ), + migrations.AddField( + model_name='networkparameter', + name='parameter', + field=models.ForeignKey(related_name=b'networkparameters', to='core.NetworkParameterType', help_text=b'The type of the parameter'), + preserve_default=True, + ), + migrations.AddField( + model_name='network', + name='owner', + field=models.ForeignKey(related_name=b'ownedNetworks', to='core.Slice', help_text=b'Slice that owns control of this Network'), + preserve_default=True, + ), + migrations.AddField( + model_name='network', + name='permittedSlices', + field=models.ManyToManyField(related_name=b'availableNetworks', to='core.Slice', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='network', + name='slices', + field=models.ManyToManyField(related_name=b'networks', through='core.NetworkSlice', to='core.Slice', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='network', + name='slivers', + field=models.ManyToManyField(related_name=b'networks', through='core.NetworkSliver', to='core.Sliver', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='network', + name='template', + field=models.ForeignKey(to='core.NetworkTemplate'), + preserve_default=True, + ), + migrations.AddField( + model_name='image', + name='deployments', + field=models.ManyToManyField(help_text=b'Select which images should be instantiated on this deployment', related_name=b'images', through='core.ImageDeployments', to='core.Deployment', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='deploymentprivilege', + name='role', + field=models.ForeignKey(related_name=b'deploymentprivileges', to='core.DeploymentRole'), + preserve_default=True, + ), + migrations.AddField( + model_name='deploymentprivilege', + name='user', + field=models.ForeignKey(related_name=b'deploymentprivileges', to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='controllerslices', + name='slice', + field=models.ForeignKey(related_name=b'controllerslices', to='core.Slice'), + preserve_default=True, + ), + migrations.AddField( + model_name='controllersitedeployments', + name='site_deployment', + field=models.ForeignKey(related_name=b'controllersitedeployments', to='core.SiteDeployments'), + preserve_default=True, + ), + migrations.AddField( + model_name='controllerprivilege', + name='role', + field=models.ForeignKey(related_name=b'controllerprivileges', to='core.ControllerRole'), + preserve_default=True, + ), + migrations.AddField( + model_name='controllerprivilege', + name='user', + field=models.ForeignKey(related_name=b'controllerprivileges', to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='controllernetworks', + name='network', + field=models.ForeignKey(related_name=b'controllernetworks', to='core.Network'), + preserve_default=True, + ), + migrations.AddField( + model_name='controllerimages', + name='image', + field=models.ForeignKey(related_name=b'controllerimages', to='core.Image'), + preserve_default=True, + ), + migrations.AddField( + model_name='controllerdashboardview', + name='dashboardView', + field=models.ForeignKey(related_name=b'controllerdashboardviews', to='core.DashboardView'), + preserve_default=True, + ), + migrations.AddField( + model_name='charge', + name='invoice', + field=models.ForeignKey(related_name=b'charges', blank=True, to='core.Invoice', null=True), + preserve_default=True, + ), + migrations.AddField( + model_name='charge', + name='object', + field=models.ForeignKey(to='core.UsableObject'), + preserve_default=True, + ), + migrations.AddField( + model_name='charge', + name='slice', + field=models.ForeignKey(related_name=b'charges', blank=True, to='core.Slice', null=True), + preserve_default=True, + ), + migrations.AddField( + model_name='account', + name='site', + field=models.ForeignKey(related_name=b'accounts', to='core.Site', help_text=b'Site for this account'), + preserve_default=True, + ), + migrations.AddField( + model_name='user', + name='dashboards', + field=models.ManyToManyField(to='core.DashboardView', through='core.UserDashboardView', blank=True), + preserve_default=True, + ), + migrations.AddField( + model_name='user', + name='site', + field=models.ForeignKey(related_name=b'users', to='core.Site', help_text=b'Site this user will be homed too', null=True), + preserve_default=True, + ), + ] diff --git a/planetstack/core/migrations/__init__.py b/planetstack/core/migrations/__init__.py index 8b13789..e69de29 100644 --- a/planetstack/core/migrations/__init__.py +++ b/planetstack/core/migrations/__init__.py @@ -1 +0,0 @@ - diff --git a/planetstack/hpc/migrations/0001_initial.py b/planetstack/hpc/migrations/0001_initial.py new file mode 100644 index 0000000..e1bdd01 --- /dev/null +++ b/planetstack/hpc/migrations/0001_initial.py @@ -0,0 +1,159 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations +import django.utils.timezone +from django.conf import settings + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='AccessMap', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('name', models.CharField(help_text=b'Name of the Access Map', max_length=64)), + ('description', models.TextField(max_length=130, null=True, blank=True)), + ('map', models.FileField(help_text=b'specifies which client requests are allowed', upload_to=b'maps/')), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='CDNPrefix', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('cdn_prefix_id', models.IntegerField(null=True, blank=True)), + ('prefix', models.CharField(help_text=b'Registered Prefix for Domain', max_length=200)), + ('description', models.TextField(help_text=b'Description of Content Provider', max_length=254, null=True, blank=True)), + ('enabled', models.BooleanField(default=True)), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ContentProvider', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('content_provider_id', models.IntegerField(null=True, blank=True)), + ('name', models.CharField(max_length=254)), + ('enabled', models.BooleanField(default=True)), + ('description', models.TextField(help_text=b'Description of Content Provider', max_length=254, null=True, blank=True)), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='HpcService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ], + options={ + 'verbose_name': 'HPC Service', + }, + bases=('core.service', models.Model), + ), + migrations.CreateModel( + name='OriginServer', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('origin_server_id', models.IntegerField(null=True, blank=True)), + ('url', models.URLField()), + ('authenticated', models.BooleanField(default=False, help_text=b'Status for this Site')), + ('enabled', models.BooleanField(default=True, help_text=b'Status for this Site')), + ('protocol', models.CharField(default=b'HTTP', max_length=12, choices=[(b'http', b'HTTP'), (b'rtmp', b'RTMP'), (b'rtp', b'RTP'), (b'shout', b'SHOUTcast')])), + ('redirects', models.BooleanField(default=True, help_text=b'Indicates whether Origin Server redirects should be used for this Origin Server')), + ('description', models.TextField(max_length=255, null=True, blank=True)), + ('contentProvider', models.ForeignKey(to='hpc.ContentProvider')), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='ServiceProvider', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('service_provider_id', models.IntegerField(null=True, blank=True)), + ('name', models.CharField(help_text=b'Service Provider Name', max_length=254)), + ('description', models.TextField(help_text=b'Description of Service Provider', max_length=254, null=True, blank=True)), + ('enabled', models.BooleanField(default=True)), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SiteMap', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('name', models.CharField(help_text=b'Name of the Site Map', max_length=64)), + ('description', models.TextField(max_length=130, null=True, blank=True)), + ('map', models.FileField(help_text=b'specifies how to map requests to hpc instances', upload_to=b'maps/')), + ('contentProvider', models.ForeignKey(blank=True, to='hpc.ContentProvider', null=True)), + ('serviceProvider', models.ForeignKey(blank=True, to='hpc.ServiceProvider', null=True)), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.AddField( + model_name='contentprovider', + name='serviceProvider', + field=models.ForeignKey(to='hpc.ServiceProvider'), + preserve_default=True, + ), + migrations.AddField( + model_name='contentprovider', + name='users', + field=models.ManyToManyField(to=settings.AUTH_USER_MODEL), + preserve_default=True, + ), + migrations.AddField( + model_name='cdnprefix', + name='contentProvider', + field=models.ForeignKey(to='hpc.ContentProvider'), + preserve_default=True, + ), + migrations.AddField( + model_name='cdnprefix', + name='defaultOriginServer', + field=models.ForeignKey(blank=True, to='hpc.OriginServer', null=True), + preserve_default=True, + ), + migrations.AddField( + model_name='accessmap', + name='contentProvider', + field=models.ForeignKey(to='hpc.ContentProvider'), + preserve_default=True, + ), + ] diff --git a/planetstack/kairos/migrations/0001_initial.py b/planetstack/kairos/migrations/0001_initial.py new file mode 100644 index 0000000..e7ca65e --- /dev/null +++ b/planetstack/kairos/migrations/0001_initial.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='KairosDBService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ], + options={ + 'verbose_name': 'KairosDB Service', + }, + bases=('core.service', models.Model), + ), + ] diff --git a/planetstack/nagios/migrations/0001_initial.py b/planetstack/nagios/migrations/0001_initial.py new file mode 100644 index 0000000..b948e4e --- /dev/null +++ b/planetstack/nagios/migrations/0001_initial.py @@ -0,0 +1,24 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='NagiosService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ], + options={ + 'verbose_name': 'Nagios Service', + }, + bases=('core.service', models.Model), + ), + ] diff --git a/planetstack/requestrouter/migrations/0001_initial.py b/planetstack/requestrouter/migrations/0001_initial.py new file mode 100644 index 0000000..a398283 --- /dev/null +++ b/planetstack/requestrouter/migrations/0001_initial.py @@ -0,0 +1,50 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations +import django.utils.timezone + + +class Migration(migrations.Migration): + + dependencies = [ + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='RequestRouterService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ('behindNat', models.BooleanField(default=False, help_text=b"Enables 'Behind NAT' mode.")), + ('defaultTTL', models.PositiveIntegerField(default=30, help_text=b'DNS response time-to-live(TTL)')), + ('defaultAction', models.CharField(default=b'best', help_text=b'Review if this should be enum', max_length=30)), + ('lastResortAction', models.CharField(default=b'random', help_text=b'Review if this should be enum', max_length=30)), + ('maxAnswers', models.PositiveIntegerField(default=3, help_text=b'Maximum number of answers in DNS response.')), + ], + options={ + 'verbose_name': 'Request Router Service', + }, + bases=('core.service', models.Model), + ), + migrations.CreateModel( + name='ServiceMap', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.SlugField(help_text=b'name of this service map', unique=True)), + ('prefix', models.CharField(help_text=b'FQDN of the region of URI space managed by RR on behalf of this service', max_length=256)), + ('siteMap', models.FileField(help_text=b'maps client requests to service instances', upload_to=b'maps/', blank=True)), + ('accessMap', models.FileField(help_text=b'specifies which client requests are allowed', upload_to=b'maps/', blank=True)), + ('owner', models.ForeignKey(help_text=b'service which owns this map', to='core.Service')), + ('slice', models.ForeignKey(help_text=b'slice that implements this service', to='core.Slice')), + ], + options={ + }, + bases=(models.Model,), + ), + ] diff --git a/planetstack/syndicate_storage/migrations/0001_initial.py b/planetstack/syndicate_storage/migrations/0001_initial.py new file mode 100644 index 0000000..51c8f94 --- /dev/null +++ b/planetstack/syndicate_storage/migrations/0001_initial.py @@ -0,0 +1,127 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.db import models, migrations +import syndicate_storage.models +import django.utils.timezone +from django.conf import settings + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ('core', '0001_initial'), + ] + + operations = [ + migrations.CreateModel( + name='SliceSecret', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('secret', syndicate_storage.models.ObserverSecretValue(help_text=b"Shared secret between OpenCloud and this slice's Syndicate daemons.", blank=True)), + ('slice_id', models.ForeignKey(to='core.Slice')), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SyndicatePrincipal', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('principal_id', models.TextField(unique=True)), + ('public_key_pem', models.TextField()), + ('sealed_private_key', models.TextField()), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='SyndicateService', + fields=[ + ('service_ptr', models.OneToOneField(parent_link=True, auto_created=True, primary_key=True, serialize=False, to='core.Service')), + ], + options={ + 'verbose_name': 'Syndicate Service', + 'verbose_name_plural': 'Syndicate Service', + }, + bases=('core.service', models.Model), + ), + migrations.CreateModel( + name='Volume', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('name', models.CharField(help_text=b'Human-readable, searchable name of the Volume', max_length=64)), + ('description', models.TextField(help_text=b'Human-readable description of what this Volume is used for.', max_length=130, null=True, blank=True)), + ('blocksize', models.PositiveIntegerField(help_text=b'Number of bytes per block.')), + ('private', models.BooleanField(default=True, help_text=b'Indicates if the Volume is visible to users other than the Volume Owner and Syndicate Administrators.')), + ('archive', models.BooleanField(default=False, help_text=b'Indicates if this Volume is read-only, and only an Aquisition Gateway owned by the Volume owner (or Syndicate admin) can write to it.')), + ('cap_read_data', models.BooleanField(default=True, help_text=b'VM can read Volume data')), + ('cap_write_data', models.BooleanField(default=True, help_text=b'VM can write Volume data')), + ('cap_host_data', models.BooleanField(default=True, help_text=b'VM can host Volume data')), + ('owner_id', models.ForeignKey(verbose_name=b'Owner', to=settings.AUTH_USER_MODEL)), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='VolumeAccessRight', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('cap_read_data', models.BooleanField(default=True, help_text=b'VM can read Volume data')), + ('cap_write_data', models.BooleanField(default=True, help_text=b'VM can write Volume data')), + ('cap_host_data', models.BooleanField(default=True, help_text=b'VM can host Volume data')), + ('owner_id', models.ForeignKey(verbose_name=b'user', to=settings.AUTH_USER_MODEL)), + ('volume', models.ForeignKey(to='syndicate_storage.Volume')), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.CreateModel( + name='VolumeSlice', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('created', models.DateTimeField(default=django.utils.timezone.now, auto_now_add=True)), + ('updated', models.DateTimeField(default=django.utils.timezone.now, auto_now=True)), + ('enacted', models.DateTimeField(default=None, null=True, blank=True)), + ('backend_status', models.CharField(default=b'Provisioning in progress', max_length=140)), + ('deleted', models.BooleanField(default=False)), + ('cap_read_data', models.BooleanField(default=True, help_text=b'VM can read Volume data')), + ('cap_write_data', models.BooleanField(default=True, help_text=b'VM can write Volume data')), + ('cap_host_data', models.BooleanField(default=True, help_text=b'VM can host Volume data')), + ('UG_portnum', models.PositiveIntegerField(help_text=b'User Gateway port. Any port above 1024 will work, but it must be available slice-wide.', verbose_name=b'UG port')), + ('RG_portnum', models.PositiveIntegerField(help_text=b'Replica Gateway port. Any port above 1024 will work, but it must be available slice-wide.', verbose_name=b'RG port')), + ('credentials_blob', models.TextField(help_text=b'Encrypted slice credentials, sealed with the slice secret.', null=True, blank=True)), + ('slice_id', models.ForeignKey(verbose_name=b'Slice', to='core.Slice')), + ('volume_id', models.ForeignKey(verbose_name=b'Volume', to='syndicate_storage.Volume')), + ], + options={ + }, + bases=(models.Model,), + ), + migrations.AddField( + model_name='volume', + name='slice_id', + field=models.ManyToManyField(to='core.Slice', through='syndicate_storage.VolumeSlice'), + preserve_default=True, + ), + ] diff --git a/planetstack/syndicate_storage/migrations/__init__.py b/planetstack/syndicate_storage/migrations/__init__.py new file mode 100644 index 0000000..e69de29