#!/usr/bin/env python # # Copyright (C) 2015 GNS3 Technologies Inc. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # # This file contains the validation for checking a .gns3 file # from gns3server.endpoints.schemas.computes import Compute from gns3server.endpoints.schemas.drawings import Drawing from gns3server.endpoints.schemas.links import Link from gns3server.endpoints.schemas.nodes import Node from gns3server.endpoints.schemas.projects import ( Supplier, Variable ) from pydantic import BaseModel, Field from typing import Optional, List from enum import Enum from uuid import UUID class TopologyType(str, Enum): topology = "topology" class TopologyContent(BaseModel): computes: List[Compute] = Field(..., description="List of computes") drawings: List[Drawing] = Field(..., description="List of drawings") links: List[Link] = Field(..., description="List of links") nodes: List[Node] = Field(..., description="List of nodes") class Topology(BaseModel): project_id: UUID = Field(..., description="Project UUID") type: TopologyType = Field(..., description="Type of file. It's always topology") revision: int = Field(..., description="Version of the .gns3 specification") version: str = Field(..., description="Version of the GNS3 software which have update the file for the last time") name: str = Field(..., description="Name of the project") topology: TopologyContent = Field(..., description="Topology content") auto_start: Optional[bool] = Field(None, description="Start the topology when opened") auto_close: Optional[bool] = Field(None, description="Close the topology when no client is connected") scene_height: Optional[int] = Field(None, description="Height of the drawing area") scene_width: Optional[int] = Field(None, description="Width of the drawing area") zoom: Optional[int] = Field(None, description="Zoom of the drawing area") show_layers: Optional[bool] = Field(None, description="Show layers on the drawing area") snap_to_grid: Optional[bool] = Field(None, description="Snap to grid on the drawing area") show_grid: Optional[bool] = Field(None, description="Show the grid on the drawing area") grid_size: Optional[int] = Field(None, description="Grid size for the drawing area for nodes") drawing_grid_size: Optional[int] = Field(None, description="Grid size for the drawing area for drawings") show_interface_labels: Optional[bool] = Field(None, description="Show interface labels on the drawing area") supplier: Optional[Supplier] = Field(None, description="Supplier of the project") variables: Optional[List[Variable]] = Field(None, description="Variables required to run the project") def main(): import json import sys with open(sys.argv[1]) as f: data = json.load(f) Topology.parse_obj(data) if __name__ == '__main__': main()