Matteo Scandolo | d2044a4 | 2017-08-07 16:08:28 -0700 | [diff] [blame] | 1 | # Copyright 2017-present Open Networking Foundation |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | # you may not use this file except in compliance with the License. |
| 5 | # You may obtain a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | # See the License for the specific language governing permissions and |
| 13 | # limitations under the License. |
| 14 | |
| 15 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 16 | from core.models import * |
| 17 | import django |
| 18 | from __future__ import print_function |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 19 | import os |
| 20 | import sys |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 21 | |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 22 | sys.path.append("/opt/xos") |
| 23 | os.environ.setdefault("DJANGO_SETTINGS_MODULE", "xos.settings") |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 24 | |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 25 | django.setup() |
| 26 | |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 27 | for obj in ControllerNetwork.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 28 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 29 | obj.delete(purge=True) |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 30 | |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 31 | for obj in ControllerSite.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 32 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 33 | obj.delete(purge=True) |
| 34 | |
Scott Baker | 8f92217 | 2015-05-11 17:49:28 -0700 | [diff] [blame] | 35 | for obj in ControllerSlice.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 36 | print("Purging deleted object", obj) |
Scott Baker | 8f92217 | 2015-05-11 17:49:28 -0700 | [diff] [blame] | 37 | obj.delete(purge=True) |
| 38 | |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 39 | for obj in NetworkSlice.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 40 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 41 | obj.delete(purge=True) |
| 42 | |
Scott Baker | 8094b6a | 2015-08-28 11:55:19 -0700 | [diff] [blame] | 43 | for obj in Port.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 44 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 45 | obj.delete(purge=True) |
| 46 | |
| 47 | for obj in DeploymentPrivilege.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 48 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 49 | obj.delete(purge=True) |
| 50 | |
| 51 | for obj in SiteDeployment.deleted_objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 52 | print("Purging deleted object", obj) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 53 | obj.delete(purge=True) |
| 54 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 55 | seen = [] |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 56 | for obj in ControllerNetwork.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 57 | seen.append(obj.id) |
| 58 | conflicts = ControllerNetwork.objects.filter( |
| 59 | network=obj.network, controller=obj.controller |
| 60 | ) |
| 61 | for conflict in conflicts: |
| 62 | if conflict.id not in seen: |
| 63 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 64 | conflict.delete(purge=True) |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 65 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 66 | seen = [] |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 67 | for obj in NetworkSlice.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 68 | seen.append(obj.id) |
| 69 | conflicts = NetworkSlice.objects.filter(network=obj.network, slice=obj.slice) |
| 70 | for conflict in conflicts: |
| 71 | if conflict.id not in seen: |
| 72 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 73 | conflict.delete(purge=True) |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 74 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 75 | seen = [] |
Scott Baker | 8094b6a | 2015-08-28 11:55:19 -0700 | [diff] [blame] | 76 | for obj in Port.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 77 | seen.append(obj.id) |
| 78 | conflicts = Port.objects.filter(network=obj.network, instance=obj.instanc) |
| 79 | for conflict in conflicts: |
| 80 | if conflict.id not in seen: |
| 81 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 82 | conflict.delete(purge=True) |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 83 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 84 | seen = [] |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 85 | for obj in DeploymentPrivilege.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 86 | seen.append(obj.id) |
| 87 | conflicts = DeploymentPrivilege.objects.filter( |
| 88 | user=obj.user, deployment=obj.deployment, role=obj.role |
| 89 | ) |
| 90 | for conflict in conflicts: |
| 91 | if conflict.id not in seen: |
| 92 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 93 | conflict.delete(purge=True) |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 94 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 95 | seen = [] |
Sapan Bhatia | 8918ac3 | 2017-07-09 00:43:27 -0400 | [diff] [blame] | 96 | for obj in Privilege.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 97 | seen.append(obj.id) |
| 98 | conflicts = Privilege.objects.filter( |
| 99 | accessor_id=obj.accessor_id, |
| 100 | object_id=obj.object_id, |
| 101 | permission=obj.permission, |
| 102 | accessor_type=obj.accessor_type, |
| 103 | object_type=obj.object_type, |
| 104 | ) |
| 105 | for conflict in conflicts: |
| 106 | if conflict.id not in seen: |
| 107 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 108 | conflict.delete(purge=True) |
Sapan Bhatia | 8918ac3 | 2017-07-09 00:43:27 -0400 | [diff] [blame] | 109 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 110 | seen = [] |
Scott Baker | 64c162f | 2015-05-11 16:56:01 -0700 | [diff] [blame] | 111 | for obj in SiteDeployment.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 112 | seen.append(obj.id) |
| 113 | conflicts = SiteDeployment.objects.filter( |
| 114 | site=obj.site, deployment=obj.deployment, controller=obj.controller |
| 115 | ) |
| 116 | for conflict in conflicts: |
| 117 | if conflict.id not in seen: |
| 118 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 119 | conflict.delete(purge=True) |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 120 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 121 | seen = [] |
Scott Baker | 7b0eee4 | 2015-05-11 17:26:00 -0700 | [diff] [blame] | 122 | for obj in ControllerSite.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 123 | seen.append(obj.id) |
| 124 | conflicts = ControllerSite.objects.filter(site=obj.site, controller=obj.controller) |
| 125 | for conflict in conflicts: |
| 126 | if conflict.id not in seen: |
| 127 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 128 | conflict.delete(purge=True) |
Scott Baker | 8f92217 | 2015-05-11 17:49:28 -0700 | [diff] [blame] | 129 | |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 130 | seen = [] |
Scott Baker | 8f92217 | 2015-05-11 17:49:28 -0700 | [diff] [blame] | 131 | for obj in ControllerSlice.objects.all(): |
Zack Williams | 045b63d | 2019-01-22 16:30:57 -0700 | [diff] [blame^] | 132 | seen.append(obj.id) |
| 133 | conflicts = ControllerSlice.objects.filter( |
| 134 | slice=obj.slice, controller=obj.controller |
| 135 | ) |
| 136 | for conflict in conflicts: |
| 137 | if conflict.id not in seen: |
| 138 | print("Purging", conflict, conflict.id, "due to duplicate of", obj.id) |
| 139 | conflict.delete(purge=True) |