0001_initial.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. # -*- coding: utf-8 -*-
  2. # Generated by Django 1.9.7 on 2016-06-22 18:21
  3. from __future__ import unicode_literals
  4. import django.core.validators
  5. from django.db import migrations, models
  6. import django.db.models.deletion
  7. import utilities.fields
  8. class Migration(migrations.Migration):
  9. initial = True
  10. dependencies = [
  11. ]
  12. operations = [
  13. migrations.CreateModel(
  14. name='ConsolePort',
  15. fields=[
  16. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  17. ('name', models.CharField(max_length=30)),
  18. ('connection_status', models.NullBooleanField(choices=[[False, b'Planned'], [True, b'Connected']], default=True)),
  19. ],
  20. options={
  21. 'ordering': ['device', 'name'],
  22. },
  23. ),
  24. migrations.CreateModel(
  25. name='ConsolePortTemplate',
  26. fields=[
  27. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  28. ('name', models.CharField(max_length=30)),
  29. ],
  30. options={
  31. 'ordering': ['device_type', 'name'],
  32. },
  33. ),
  34. migrations.CreateModel(
  35. name='ConsoleServerPort',
  36. fields=[
  37. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  38. ('name', models.CharField(max_length=30)),
  39. ],
  40. ),
  41. migrations.CreateModel(
  42. name='ConsoleServerPortTemplate',
  43. fields=[
  44. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  45. ('name', models.CharField(max_length=30)),
  46. ],
  47. options={
  48. 'ordering': ['device_type', 'name'],
  49. },
  50. ),
  51. migrations.CreateModel(
  52. name='Device',
  53. fields=[
  54. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  55. ('created', models.DateField(auto_now_add=True)),
  56. ('last_updated', models.DateTimeField(auto_now=True)),
  57. ('name', utilities.fields.NullableCharField(blank=True, max_length=50, null=True, unique=True)),
  58. ('serial', models.CharField(blank=True, max_length=50, verbose_name=b'Serial number')),
  59. ('position', models.PositiveSmallIntegerField(blank=True, help_text=b'Number of the lowest U position occupied by the device', null=True, validators=[django.core.validators.MinValueValidator(1)], verbose_name=b'Position (U)')),
  60. ('face', models.PositiveSmallIntegerField(blank=True, choices=[[0, b'Front'], [1, b'Rear']], null=True, verbose_name=b'Rack face')),
  61. ('status', models.BooleanField(choices=[[True, b'Active'], [False, b'Offline']], default=True, verbose_name=b'Status')),
  62. ('comments', models.TextField(blank=True)),
  63. ],
  64. options={
  65. 'ordering': ['name'],
  66. },
  67. ),
  68. migrations.CreateModel(
  69. name='DeviceRole',
  70. fields=[
  71. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  72. ('name', models.CharField(max_length=50, unique=True)),
  73. ('slug', models.SlugField(unique=True)),
  74. ('color', models.CharField(choices=[[b'teal', b'Teal'], [b'green', b'Green'], [b'blue', b'Blue'], [b'purple', b'Purple'], [b'yellow', b'Yellow'], [b'orange', b'Orange'], [b'red', b'Red'], [b'light_gray', b'Light Gray'], [b'medium_gray', b'Medium Gray'], [b'dark_gray', b'Dark Gray']], max_length=30)),
  75. ],
  76. options={
  77. 'ordering': ['name'],
  78. },
  79. ),
  80. migrations.CreateModel(
  81. name='DeviceType',
  82. fields=[
  83. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  84. ('model', models.CharField(max_length=50)),
  85. ('slug', models.SlugField()),
  86. ('u_height', models.PositiveSmallIntegerField(default=1, verbose_name=b'Height (U)')),
  87. ('is_full_depth', models.BooleanField(default=True, help_text=b'Device consumes both front and rear rack faces', verbose_name=b'Is full depth')),
  88. ('is_console_server', models.BooleanField(default=False, help_text=b'This type of device has console server ports', verbose_name=b'Is a console server')),
  89. ('is_pdu', models.BooleanField(default=False, help_text=b'This type of device has power outlets', verbose_name=b'Is a PDU')),
  90. ('is_network_device', models.BooleanField(default=True, help_text=b'This type of device has network interfaces', verbose_name=b'Is a network device')),
  91. ],
  92. options={
  93. 'ordering': ['manufacturer', 'model'],
  94. },
  95. ),
  96. migrations.CreateModel(
  97. name='Interface',
  98. fields=[
  99. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  100. ('name', models.CharField(max_length=30)),
  101. ('form_factor', models.PositiveSmallIntegerField(choices=[[0, b'Virtual'], [800, b'10/100M (Copper)'], [1000, b'1GE (Copper)'], [1100, b'1GE (SFP)'], [1200, b'10GE (SFP+)'], [1300, b'10GE (XFP)'], [1400, b'40GE (QSFP+)']], default=1200)),
  102. ('mgmt_only', models.BooleanField(default=False, help_text=b'This interface is used only for out-of-band management', verbose_name=b'OOB Management')),
  103. ('description', models.CharField(blank=True, max_length=100)),
  104. ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='interfaces', to='dcim.Device')),
  105. ],
  106. options={
  107. 'ordering': ['device', 'name'],
  108. },
  109. ),
  110. migrations.CreateModel(
  111. name='InterfaceConnection',
  112. fields=[
  113. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  114. ('connection_status', models.BooleanField(choices=[[False, b'Planned'], [True, b'Connected']], default=True, verbose_name=b'Status')),
  115. ('interface_a', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='connected_as_a', to='dcim.Interface')),
  116. ('interface_b', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='connected_as_b', to='dcim.Interface')),
  117. ],
  118. ),
  119. migrations.CreateModel(
  120. name='InterfaceTemplate',
  121. fields=[
  122. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  123. ('name', models.CharField(max_length=30)),
  124. ('form_factor', models.PositiveSmallIntegerField(choices=[[0, b'Virtual'], [800, b'10/100M (Copper)'], [1000, b'1GE (Copper)'], [1100, b'1GE (SFP)'], [1200, b'10GE (SFP+)'], [1300, b'10GE (XFP)'], [1400, b'40GE (QSFP+)']], default=1200)),
  125. ('mgmt_only', models.BooleanField(default=False, verbose_name=b'Management only')),
  126. ('device_type', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='interface_templates', to='dcim.DeviceType')),
  127. ],
  128. options={
  129. 'ordering': ['device_type', 'name'],
  130. },
  131. ),
  132. migrations.CreateModel(
  133. name='Manufacturer',
  134. fields=[
  135. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  136. ('name', models.CharField(max_length=50, unique=True)),
  137. ('slug', models.SlugField(unique=True)),
  138. ],
  139. options={
  140. 'ordering': ['name'],
  141. },
  142. ),
  143. migrations.CreateModel(
  144. name='Module',
  145. fields=[
  146. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  147. ('name', models.CharField(max_length=50, verbose_name=b'Name')),
  148. ('part_id', models.CharField(blank=True, max_length=50, verbose_name=b'Part ID')),
  149. ('serial', models.CharField(blank=True, max_length=50, verbose_name=b'Serial number')),
  150. ('discovered', models.BooleanField(default=False, verbose_name=b'Discovered')),
  151. ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='modules', to='dcim.Device')),
  152. ('parent', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='submodules', to='dcim.Module')),
  153. ],
  154. options={
  155. 'ordering': ['device__id', 'parent__id', 'name'],
  156. },
  157. ),
  158. migrations.CreateModel(
  159. name='Platform',
  160. fields=[
  161. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  162. ('name', models.CharField(max_length=50, unique=True)),
  163. ('slug', models.SlugField(unique=True)),
  164. ('rpc_client', models.CharField(blank=True, choices=[[b'juniper-junos', b'Juniper Junos (NETCONF)'], [b'cisco-ios', b'Cisco IOS (SSH)'], [b'opengear', b'Opengear (SSH)']], max_length=30, verbose_name=b'RPC client')),
  165. ],
  166. options={
  167. 'ordering': ['name'],
  168. },
  169. ),
  170. migrations.CreateModel(
  171. name='PowerOutlet',
  172. fields=[
  173. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  174. ('name', models.CharField(max_length=30)),
  175. ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='power_outlets', to='dcim.Device')),
  176. ],
  177. ),
  178. migrations.CreateModel(
  179. name='PowerOutletTemplate',
  180. fields=[
  181. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  182. ('name', models.CharField(max_length=30)),
  183. ('device_type', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='power_outlet_templates', to='dcim.DeviceType')),
  184. ],
  185. options={
  186. 'ordering': ['device_type', 'name'],
  187. },
  188. ),
  189. migrations.CreateModel(
  190. name='PowerPort',
  191. fields=[
  192. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  193. ('name', models.CharField(max_length=30)),
  194. ('connection_status', models.NullBooleanField(choices=[[False, b'Planned'], [True, b'Connected']], default=True)),
  195. ('device', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='power_ports', to='dcim.Device')),
  196. ('power_outlet', models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='connected_port', to='dcim.PowerOutlet')),
  197. ],
  198. options={
  199. 'ordering': ['device', 'name'],
  200. },
  201. ),
  202. migrations.CreateModel(
  203. name='PowerPortTemplate',
  204. fields=[
  205. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  206. ('name', models.CharField(max_length=30)),
  207. ('device_type', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='power_port_templates', to='dcim.DeviceType')),
  208. ],
  209. options={
  210. 'ordering': ['device_type', 'name'],
  211. },
  212. ),
  213. migrations.CreateModel(
  214. name='Rack',
  215. fields=[
  216. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  217. ('created', models.DateField(auto_now_add=True)),
  218. ('last_updated', models.DateTimeField(auto_now=True)),
  219. ('name', models.CharField(max_length=50)),
  220. ('facility_id', utilities.fields.NullableCharField(blank=True, max_length=30, null=True, verbose_name=b'Facility ID')),
  221. ('u_height', models.PositiveSmallIntegerField(default=42, verbose_name=b'Height (U)')),
  222. ('comments', models.TextField(blank=True)),
  223. ],
  224. options={
  225. 'ordering': ['site', 'name'],
  226. },
  227. ),
  228. migrations.CreateModel(
  229. name='RackGroup',
  230. fields=[
  231. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  232. ('name', models.CharField(max_length=50)),
  233. ('slug', models.SlugField()),
  234. ],
  235. options={
  236. 'ordering': ['site', 'name'],
  237. },
  238. ),
  239. migrations.CreateModel(
  240. name='Site',
  241. fields=[
  242. ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
  243. ('created', models.DateField(auto_now_add=True)),
  244. ('last_updated', models.DateTimeField(auto_now=True)),
  245. ('name', models.CharField(max_length=50, unique=True)),
  246. ('slug', models.SlugField(unique=True)),
  247. ('facility', models.CharField(blank=True, max_length=50)),
  248. ('asn', models.PositiveIntegerField(blank=True, null=True, verbose_name=b'ASN')),
  249. ('physical_address', models.CharField(blank=True, max_length=200)),
  250. ('shipping_address', models.CharField(blank=True, max_length=200)),
  251. ('comments', models.TextField(blank=True)),
  252. ],
  253. options={
  254. 'ordering': ['name'],
  255. },
  256. ),
  257. migrations.AddField(
  258. model_name='rackgroup',
  259. name='site',
  260. field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='rack_groups', to='dcim.Site'),
  261. ),
  262. migrations.AddField(
  263. model_name='rack',
  264. name='group',
  265. field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='racks', to='dcim.RackGroup'),
  266. ),
  267. migrations.AddField(
  268. model_name='rack',
  269. name='site',
  270. field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='racks', to='dcim.Site'),
  271. ),
  272. migrations.AddField(
  273. model_name='devicetype',
  274. name='manufacturer',
  275. field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='device_types', to='dcim.Manufacturer'),
  276. ),
  277. migrations.AddField(
  278. model_name='device',
  279. name='device_role',
  280. field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='devices', to='dcim.DeviceRole'),
  281. ),
  282. migrations.AddField(
  283. model_name='device',
  284. name='device_type',
  285. field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='instances', to='dcim.DeviceType'),
  286. ),
  287. migrations.AddField(
  288. model_name='device',
  289. name='platform',
  290. field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='devices', to='dcim.Platform'),
  291. ),
  292. ]