1
# vim: tabstop=4 shiftwidth=4 softtabstop=4
3
# Copyright 2012 OpenStack LLC.
6
# Licensed under the Apache License, Version 2.0 (the "License"); you may
7
# not use this file except in compliance with the License. You may obtain
8
# a copy of the License at
10
# http://www.apache.org/licenses/LICENSE-2.0
12
# Unless required by applicable law or agreed to in writing, software
13
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15
# License for the specific language governing permissions and limitations
18
from sqlalchemy import Index, MetaData, Table
19
from sqlalchemy.exc import IntegrityError
22
def upgrade(migrate_engine):
24
meta.bind = migrate_engine
26
t = Table('fixed_ips', meta, autoload=True)
28
# Based on network_get_all_by_host
29
# from: nova/db/sqlalchemy/api.py
30
i = Index('fixed_ips_host_idx', t.c.host)
32
i.create(migrate_engine)
33
except IntegrityError:
36
# Based on fixed_ip_get_by_network_host
37
# from: nova/db/sqlalchemy/api.py
38
i = Index('fixed_ips_network_id_host_deleted_idx',
39
t.c.network_id, t.c.host, t.c.deleted)
41
i.create(migrate_engine)
42
except IntegrityError:
45
# Based on fixed_ip_associate
46
# from: nova/db/sqlalchemy/api.py
47
i = Index('fixed_ips_address_reserved_network_id_deleted_idx',
48
t.c.address, t.c.reserved, t.c.network_id, t.c.deleted)
50
i.create(migrate_engine)
51
except IntegrityError:
55
def downgrade(migrate_engine):
57
meta.bind = migrate_engine
59
t = Table('fixed_ips', meta, autoload=True)
61
# Based on network_get_all_by_host
62
# from: nova/db/sqlalchemy/api.py
63
i = Index('fixed_ips_host_idx', t.c.host)
64
i.drop(migrate_engine)
66
# Based on fixed_ip_get_by_network_host
67
# from: nova/db/sqlalchemy/api.py
68
i = Index('fixed_ips_network_id_host_deleted_idx',
69
t.c.network_id, t.c.host, t.c.deleted)
70
i.drop(migrate_engine)
72
# Based on fixed_ip_associate
73
# from: nova/db/sqlalchemy/api.py
74
i = Index('fixed_ips_address_reserved_network_id_deleted_idx',
75
t.c.address, t.c.reserved, t.c.network_id, t.c.deleted)
76
i.drop(migrate_engine)