# -*- coding: utf-8 -*-
# Generated by Django 1.10 on 2016-09-05 12:50
from __future__ import unicode_literals

from django.db import migrations, models
import django.db.models.deletion


class Migration(migrations.Migration):

    initial = True

    dependencies = [
    ]

    operations = [
        migrations.CreateModel(
            name='AdminUser',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name', models.CharField(blank=True, max_length=128, null=True, unique=True, verbose_name='Name')),
                ('username', models.CharField(blank=True, max_length=16, null=True, verbose_name='Username')),
                ('password', models.CharField(blank=True, max_length=256, null=True, verbose_name='Password')),
                ('private_key', models.CharField(blank=True, max_length=4096, null=True, verbose_name='SSH private key')),
                ('is_default', models.BooleanField(default=True, verbose_name='As default')),
                ('auto_update', models.BooleanField(default=True, verbose_name='Auto update pass/key')),
                ('date_added', models.DateTimeField(auto_now=True, null=True)),
                ('create_by', models.CharField(blank=True, max_length=32, null=True, verbose_name='Created by')),
                ('comment', models.TextField(blank=True, verbose_name='Comment')),
            ],
            options={
                'db_table': 'adminuser',
            },
        ),
        migrations.CreateModel(
            name='Asset',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('ip', models.CharField(blank=True, max_length=32, null=True, verbose_name='IP')),
                ('other_ip', models.CharField(blank=True, max_length=255, null=True, verbose_name='Other IP')),
                ('remote_card_ip', models.CharField(blank=True, max_length=16, null=True, verbose_name='Remote card IP')),
                ('hostname', models.CharField(blank=True, max_length=128, null=True, unique=True, verbose_name='Hostname')),
                ('port', models.IntegerField(blank=True, null=True, verbose_name='Port')),
                ('username', models.CharField(blank=True, max_length=16, null=True, verbose_name='Admin user')),
                ('password', models.CharField(blank=True, max_length=256, null=True, verbose_name='Admin password')),
                ('mac_addr', models.CharField(blank=True, max_length=20, null=True, verbose_name='Mac address')),
                ('brand', models.CharField(blank=True, max_length=64, null=True, verbose_name='Brand')),
                ('cpu', models.CharField(blank=True, max_length=64, null=True, verbose_name='CPU')),
                ('memory', models.CharField(blank=True, max_length=128, null=True, verbose_name='Memory')),
                ('disk', models.CharField(blank=True, max_length=1024, null=True, verbose_name='Disk')),
                ('os', models.CharField(blank=True, max_length=128, null=True, verbose_name='OS')),
                ('cabinet_no', models.CharField(blank=True, max_length=32, null=True, verbose_name='Cabinet number')),
                ('cabinet_pos', models.IntegerField(blank=True, null=True, verbose_name='Cabinet position')),
                ('number', models.CharField(blank=True, max_length=32, null=True, unique=True, verbose_name='Asset number')),
                ('sn', models.CharField(blank=True, max_length=128, null=True, unique=True, verbose_name='Serial number')),
                ('created_by', models.CharField(blank=True, max_length=32, null=True, verbose_name='Created by')),
                ('is_active', models.BooleanField(default=True, verbose_name='Is active')),
                ('date_added', models.DateTimeField(auto_now=True, null=True, verbose_name='Date added')),
                ('comment', models.CharField(blank=True, max_length=128, null=True, verbose_name='Comment')),
                ('admin_user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='assets.AdminUser', verbose_name='Admin user')),
            ],
            options={
                'db_table': 'asset',
            },
        ),
        migrations.CreateModel(
            name='AssetExtend',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('key', models.CharField(blank=True, max_length=64, null=True, verbose_name='KEY')),
                ('value', models.CharField(blank=True, max_length=64, null=True, verbose_name='VALUE')),
                ('created_by', models.CharField(blank=True, max_length=32, verbose_name='Created by')),
                ('date_added', models.DateTimeField(auto_now=True, null=True)),
                ('comment', models.TextField(blank=True, verbose_name='Comment')),
            ],
            options={
                'db_table': 'assetextend',
            },
        ),
        migrations.CreateModel(
            name='AssetGroup',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name', models.CharField(blank=True, max_length=64, null=True, unique=True, verbose_name='Name')),
                ('created_by', models.CharField(blank=True, max_length=32, null=True, verbose_name='Created by')),
                ('comment', models.TextField(blank=True, verbose_name='Comment')),
            ],
            options={
                'db_table': 'assetgroup',
            },
        ),
        migrations.CreateModel(
            name='IDC',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name', models.CharField(max_length=32, verbose_name='Name')),
                ('bandwidth', models.CharField(blank=True, max_length=32, verbose_name='Bandwidth')),
                ('contact', models.CharField(blank=True, max_length=16, verbose_name='Contact')),
                ('phone', models.CharField(blank=True, max_length=32, verbose_name='Phone')),
                ('address', models.CharField(blank=True, max_length=128, verbose_name='Address')),
                ('network', models.TextField(blank=True, verbose_name='Network')),
                ('date_added', models.DateField(auto_now=True, null=True, verbose_name='Date added')),
                ('operator', models.CharField(blank=True, max_length=32, verbose_name='Operator')),
                ('created_by', models.CharField(blank=True, max_length=32, verbose_name='Created by')),
                ('comment', models.TextField(blank=True, verbose_name='Comment')),
            ],
            options={
                'db_table': 'idc',
            },
        ),
        migrations.CreateModel(
            name='Label',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('key', models.CharField(blank=True, max_length=64, null=True, verbose_name='KEY')),
                ('value', models.CharField(blank=True, max_length=64, null=True, verbose_name='VALUE')),
                ('created_by', models.CharField(blank=True, max_length=32, verbose_name='Created by')),
                ('date_added', models.DateTimeField(auto_now=True, null=True)),
                ('comment', models.CharField(blank=True, max_length=128, verbose_name='Comment')),
                ('asset', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='assets.Asset', verbose_name='Asset')),
            ],
            options={
                'db_table': 'label',
            },
        ),
        migrations.CreateModel(
            name='SysUser',
            fields=[
                ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('name', models.CharField(max_length=128, unique=True, verbose_name='Name')),
                ('username', models.CharField(blank=True, max_length=16, verbose_name='Username')),
                ('password', models.CharField(blank=True, max_length=256, verbose_name='Password')),
                ('protocol', models.CharField(default='ssh', max_length=16, verbose_name='Protocol')),
                ('private_key', models.CharField(blank=True, max_length=4096, verbose_name='SSH private key')),
                ('public_key', models.CharField(blank=True, max_length=4096, verbose_name='SSH public key')),
                ('is_default', models.BooleanField(default=True, verbose_name='As default')),
                ('auto_push', models.BooleanField(default=True, verbose_name='Auto push')),
                ('auto_update', models.BooleanField(default=True, verbose_name='Auto update pass/key')),
                ('sudo', models.TextField(blank=True, max_length=4096, verbose_name='Sudo')),
                ('shell', models.CharField(blank=True, max_length=64, verbose_name='Shell')),
                ('home', models.CharField(blank=True, max_length=64, verbose_name='Home')),
                ('uid', models.IntegerField(blank=True, verbose_name='Uid')),
                ('date_added', models.DateTimeField(auto_now=True, null=True)),
                ('create_by', models.CharField(blank=True, max_length=32, verbose_name='Created by')),
                ('comment', models.CharField(blank=True, max_length=128, verbose_name='Comment')),
            ],
            options={
                'db_table': 'sysuser',
            },
        ),
        migrations.AddField(
            model_name='asset',
            name='env',
            field=models.ManyToManyField(related_name='asset_env_extend', to='assets.AssetExtend', verbose_name='Asset environment'),
        ),
        migrations.AddField(
            model_name='asset',
            name='groups',
            field=models.ManyToManyField(blank=True, null=True, to='assets.AssetGroup', verbose_name='Asset groups'),
        ),
        migrations.AddField(
            model_name='asset',
            name='idc',
            field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='assets.IDC', verbose_name='IDC'),
        ),
        migrations.AddField(
            model_name='asset',
            name='status',
            field=models.ManyToManyField(related_name='asset_status_extend', to='assets.AssetExtend', verbose_name='Asset status'),
        ),
        migrations.AddField(
            model_name='asset',
            name='sys_user',
            field=models.ManyToManyField(blank=True, null=True, to='assets.SysUser', verbose_name='System User'),
        ),
        migrations.AddField(
            model_name='asset',
            name='type',
            field=models.ManyToManyField(related_name='asset_type_extend', to='assets.AssetExtend', verbose_name='Asset type'),
        ),
        migrations.AlterIndexTogether(
            name='asset',
            index_together=set([('ip', 'port')]),
        ),
    ]