1
0
mirror of https://github.com/GNS3/gns3-server synced 2025-01-12 09:00:57 +00:00

Option to reset or not all MAC addresses when exporting or duplicating a project.

This commit is contained in:
grossmj 2020-05-27 12:14:47 +09:30
parent 5575657318
commit 8eefaa3f32
3 changed files with 24 additions and 6 deletions

View File

@ -999,7 +999,7 @@ class Project:
while self._loading: while self._loading:
await asyncio.sleep(0.5) await asyncio.sleep(0.5)
async def duplicate(self, name=None, location=None): async def duplicate(self, name=None, location=None, reset_mac_addresses=True):
""" """
Duplicate a project Duplicate a project
@ -1009,6 +1009,7 @@ class Project:
:param name: Name of the new project. A new one will be generated in case of conflicts :param name: Name of the new project. A new one will be generated in case of conflicts
:param location: Parent directory of the new project :param location: Parent directory of the new project
:param reset_mac_addresses: Reset MAC addresses for the new project
""" """
# If the project was not open we open it temporary # If the project was not open we open it temporary
previous_status = self._status previous_status = self._status
@ -1022,7 +1023,7 @@ class Project:
with tempfile.TemporaryDirectory() as tmpdir: with tempfile.TemporaryDirectory() as tmpdir:
# Do not compress the exported project when duplicating # Do not compress the exported project when duplicating
with aiozipstream.ZipFile(compression=zipfile.ZIP_STORED) as zstream: with aiozipstream.ZipFile(compression=zipfile.ZIP_STORED) as zstream:
await export_project(zstream, self, tmpdir, keep_compute_id=True, allow_all_nodes=True, reset_mac_addresses=True) await export_project(zstream, self, tmpdir, keep_compute_id=True, allow_all_nodes=True, reset_mac_addresses=reset_mac_addresses)
# export the project to a temporary location # export the project to a temporary location
project_path = os.path.join(tmpdir, "project.gns3p") project_path = os.path.join(tmpdir, "project.gns3p")

View File

@ -35,7 +35,8 @@ from gns3server.schemas.project import (
PROJECT_OBJECT_SCHEMA, PROJECT_OBJECT_SCHEMA,
PROJECT_UPDATE_SCHEMA, PROJECT_UPDATE_SCHEMA,
PROJECT_LOAD_SCHEMA, PROJECT_LOAD_SCHEMA,
PROJECT_CREATE_SCHEMA PROJECT_CREATE_SCHEMA,
PROJECT_DUPLICATE_SCHEMA
) )
import logging import logging
@ -313,6 +314,11 @@ class ProjectHandler:
include_images = True include_images = True
else: else:
include_images = False include_images = False
if request.query.get("reset_mac_addresses", "no").lower() == "yes":
reset_mac_addresses = True
else:
reset_mac_addresses = False
compression_query = request.query.get("compression", "zip").lower() compression_query = request.query.get("compression", "zip").lower()
if compression_query == "zip": if compression_query == "zip":
compression = zipfile.ZIP_DEFLATED compression = zipfile.ZIP_DEFLATED
@ -327,7 +333,7 @@ class ProjectHandler:
begin = time.time() begin = time.time()
with tempfile.TemporaryDirectory() as tmp_dir: with tempfile.TemporaryDirectory() as tmp_dir:
with aiozipstream.ZipFile(compression=compression) as zstream: with aiozipstream.ZipFile(compression=compression) as zstream:
await export_project(zstream, project, tmp_dir, include_snapshots=include_snapshots, include_images=include_images) await export_project(zstream, project, tmp_dir, include_snapshots=include_snapshots, include_images=include_images, reset_mac_addresses=reset_mac_addresses)
# We need to do that now because export could failed and raise an HTTP error # We need to do that now because export could failed and raise an HTTP error
# that why response start need to be the later possible # that why response start need to be the later possible
@ -398,7 +404,7 @@ class ProjectHandler:
parameters={ parameters={
"project_id": "Project UUID", "project_id": "Project UUID",
}, },
input=PROJECT_CREATE_SCHEMA, input=PROJECT_DUPLICATE_SCHEMA,
output=PROJECT_OBJECT_SCHEMA, output=PROJECT_OBJECT_SCHEMA,
status_codes={ status_codes={
201: "Project duplicate", 201: "Project duplicate",
@ -419,7 +425,9 @@ class ProjectHandler:
else: else:
location = None location = None
new_project = await project.duplicate(name=request.json.get("name"), location=location) reset_mac_addresses = request.json.get("reset_mac_addresses", False)
new_project = await project.duplicate(name=request.json.get("name"), location=location, reset_mac_addresses=reset_mac_addresses)
response.json(new_project) response.json(new_project)
response.set_status(201) response.set_status(201)

View File

@ -15,6 +15,8 @@
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
import copy
SUPPLIER_OBJECT_SCHEMA = { SUPPLIER_OBJECT_SCHEMA = {
"type": ["object", "null"], "type": ["object", "null"],
"description": "Supplier of the project", "description": "Supplier of the project",
@ -120,6 +122,13 @@ PROJECT_CREATE_SCHEMA = {
"required": ["name"] "required": ["name"]
} }
# Create a project duplicate schema based on create schema and add "reset_mac_addresses" properties
PROJECT_DUPLICATE_SCHEMA = copy.deepcopy(PROJECT_CREATE_SCHEMA)
PROJECT_DUPLICATE_SCHEMA["description"] = "Request validation to duplicate a Project instance"
PROJECT_DUPLICATE_SCHEMA["properties"].update({"reset_mac_addresses": {"type": "boolean",
"description": "Reset MAC addresses for this project"
}})
PROJECT_UPDATE_SCHEMA = { PROJECT_UPDATE_SCHEMA = {
"$schema": "http://json-schema.org/draft-04/schema#", "$schema": "http://json-schema.org/draft-04/schema#",
"description": "Request validation to update a Project instance", "description": "Request validation to update a Project instance",