mirror of
https://github.com/GNS3/gns3-server
synced 2024-11-28 03:08:14 +00:00
commit
85fd3ef4a4
11
CHANGELOG
11
CHANGELOG
@ -1,5 +1,16 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
|
## 2.2.45 12/01/2024
|
||||||
|
|
||||||
|
* Bundle web-ui v2.2.45
|
||||||
|
* Fix mouse offset issues with VNC in Qemu. Fixes #2335
|
||||||
|
* Add project.created, project.opened and project.deleted controller notification stream. Move project.updated and project.closed from project notification to controller notification stream.
|
||||||
|
* Do not stop searching for Qemu binaries if one binary cannot be executed. Ref #2306
|
||||||
|
* Fix Ethernet switch and Ethernet hub port validations. Fixes #2334
|
||||||
|
* Update CORS policy
|
||||||
|
* Add custom executable paths on Windows
|
||||||
|
* Upgrade sentry-sdk and aiohttp
|
||||||
|
|
||||||
## 2.2.44.1 07/11/2023
|
## 2.2.44.1 07/11/2023
|
||||||
|
|
||||||
* Catch exceptions when computing image checksums. Ref https://github.com/GNS3/gns3-server/issues/2228
|
* Catch exceptions when computing image checksums. Ref https://github.com/GNS3/gns3-server/issues/2228
|
||||||
|
@ -11,7 +11,8 @@
|
|||||||
10
|
10
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"link_id": "b76bd8b1-2171-4361-9228-801713d23079",
|
"link_id": "c3f1b38a-160d-4a67-baa0-34fc3d9759ed",
|
||||||
|
"link_style": {},
|
||||||
"link_type": "ethernet",
|
"link_type": "ethernet",
|
||||||
"nodes": [
|
"nodes": [
|
||||||
{
|
{
|
||||||
@ -21,7 +22,7 @@
|
|||||||
"x": 64,
|
"x": 64,
|
||||||
"y": 0
|
"y": 0
|
||||||
},
|
},
|
||||||
"node_id": "8b77b480-361e-488b-96b1-a769890e11ec",
|
"node_id": "481e5898-cd97-4351-8b1e-0c9e77fc7c58",
|
||||||
"port_number": 3
|
"port_number": 3
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -30,10 +31,10 @@
|
|||||||
"style": "font-family: TypeWriter;font-size: 10.0;font-weight: bold;fill: #000000;fill-opacity: 1.0;",
|
"style": "font-family: TypeWriter;font-size: 10.0;font-weight: bold;fill: #000000;fill-opacity: 1.0;",
|
||||||
"text": "2/4"
|
"text": "2/4"
|
||||||
},
|
},
|
||||||
"node_id": "b4688a3d-0af8-4ddc-b85f-e26dc1031c4c",
|
"node_id": "63f7b8ab-146d-4142-b8c5-cf387ac1d963",
|
||||||
"port_number": 4
|
"port_number": 4
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"project_id": "85333131-b83a-4112-9a51-184ba0c536a8",
|
"project_id": "292936d2-9f54-4e29-959f-b59ed9ac5e6f",
|
||||||
"suspend": false
|
"suspend": false
|
||||||
}
|
}
|
@ -1,3 +1,3 @@
|
|||||||
{
|
{
|
||||||
"message": "Warning ASA 8 is not officialy supported by GNS3"
|
"message": "Warning ASA 8 is not officially supported by GNS3"
|
||||||
}
|
}
|
3
docs/api/notifications/node.deleted.json
Normal file
3
docs/api/notifications/node.deleted.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"a": "b"
|
||||||
|
}
|
3
docs/api/notifications/node.updated.json
Normal file
3
docs/api/notifications/node.updated.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"a": "b"
|
||||||
|
}
|
21
docs/api/notifications/project.created.json
Normal file
21
docs/api/notifications/project.created.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"auto_close": true,
|
||||||
|
"auto_open": false,
|
||||||
|
"auto_start": false,
|
||||||
|
"drawing_grid_size": 25,
|
||||||
|
"filename": "Test.gns3",
|
||||||
|
"grid_size": 75,
|
||||||
|
"name": "Test",
|
||||||
|
"path": "/tmp/tmprusds8mt/projects/87d4b692-52b4-4b4c-8828-13666306a68a",
|
||||||
|
"project_id": "87d4b692-52b4-4b4c-8828-13666306a68a",
|
||||||
|
"scene_height": 1000,
|
||||||
|
"scene_width": 2000,
|
||||||
|
"show_grid": false,
|
||||||
|
"show_interface_labels": false,
|
||||||
|
"show_layers": false,
|
||||||
|
"snap_to_grid": false,
|
||||||
|
"status": "opened",
|
||||||
|
"supplier": null,
|
||||||
|
"variables": null,
|
||||||
|
"zoom": 100
|
||||||
|
}
|
21
docs/api/notifications/project.deleted.json
Normal file
21
docs/api/notifications/project.deleted.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"auto_close": true,
|
||||||
|
"auto_open": false,
|
||||||
|
"auto_start": false,
|
||||||
|
"drawing_grid_size": 25,
|
||||||
|
"filename": "Test.gns3",
|
||||||
|
"grid_size": 75,
|
||||||
|
"name": "Test",
|
||||||
|
"path": "/tmp/tmpvqf8d5mx/projects/6f01ee8c-5fe7-47a2-95ab-a0f4c0a355f9",
|
||||||
|
"project_id": "6f01ee8c-5fe7-47a2-95ab-a0f4c0a355f9",
|
||||||
|
"scene_height": 1000,
|
||||||
|
"scene_width": 2000,
|
||||||
|
"show_grid": false,
|
||||||
|
"show_interface_labels": false,
|
||||||
|
"show_layers": false,
|
||||||
|
"snap_to_grid": false,
|
||||||
|
"status": "closed",
|
||||||
|
"supplier": null,
|
||||||
|
"variables": null,
|
||||||
|
"zoom": 100
|
||||||
|
}
|
21
docs/api/notifications/project.opened.json
Normal file
21
docs/api/notifications/project.opened.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"auto_close": true,
|
||||||
|
"auto_open": false,
|
||||||
|
"auto_start": false,
|
||||||
|
"drawing_grid_size": 25,
|
||||||
|
"filename": "test.gns3",
|
||||||
|
"grid_size": 75,
|
||||||
|
"name": "test",
|
||||||
|
"path": "/tmp/tmp7swwxptj/projects/e5b0b37a-a74e-40a2-9adb-42908f146fba",
|
||||||
|
"project_id": "e5b0b37a-a74e-40a2-9adb-42908f146fba",
|
||||||
|
"scene_height": 1000,
|
||||||
|
"scene_width": 2000,
|
||||||
|
"show_grid": false,
|
||||||
|
"show_interface_labels": false,
|
||||||
|
"show_layers": false,
|
||||||
|
"snap_to_grid": false,
|
||||||
|
"status": "opened",
|
||||||
|
"supplier": null,
|
||||||
|
"variables": null,
|
||||||
|
"zoom": 100
|
||||||
|
}
|
@ -23,7 +23,7 @@ Types
|
|||||||
+++++++++
|
+++++++++
|
||||||
EthernetSwitchPort
|
EthernetSwitchPort
|
||||||
^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^
|
||||||
Ethernet port
|
Ethernet switch port
|
||||||
|
|
||||||
.. raw:: html
|
.. raw:: html
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ Types
|
|||||||
+++++++++
|
+++++++++
|
||||||
EthernetSwitchPort
|
EthernetSwitchPort
|
||||||
^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^
|
||||||
Ethernet port
|
Ethernet switch port
|
||||||
|
|
||||||
.. raw:: html
|
.. raw:: html
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ Input
|
|||||||
|
|
||||||
<table>
|
<table>
|
||||||
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
||||||
<tr><td>application_id</td> <td> </td> <td>['integer', 'null']</td> <td>Application ID for running IOU image</td> </tr>
|
<tr><td>application_id</td> <td>✔</td> <td>['integer', 'null']</td> <td>Application ID for running IOU image</td> </tr>
|
||||||
<tr><td>console</td> <td> </td> <td>['integer', 'null']</td> <td>Console TCP port</td> </tr>
|
<tr><td>console</td> <td> </td> <td>['integer', 'null']</td> <td>Console TCP port</td> </tr>
|
||||||
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, none</td> </tr>
|
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, none</td> </tr>
|
||||||
<tr><td>ethernet_adapters</td> <td> </td> <td>integer</td> <td>How many ethernet adapters are connected to the IOU</td> </tr>
|
<tr><td>ethernet_adapters</td> <td> </td> <td>integer</td> <td>How many ethernet adapters are connected to the IOU</td> </tr>
|
||||||
|
@ -35,6 +35,8 @@ Input
|
|||||||
<table>
|
<table>
|
||||||
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
||||||
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
||||||
|
<tr><td>auto_open</td> <td> </td> <td>boolean</td> <td>Project open when GNS3 start</td> </tr>
|
||||||
|
<tr><td>auto_start</td> <td> </td> <td>boolean</td> <td>Project start when opened</td> </tr>
|
||||||
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
||||||
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
||||||
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
||||||
|
@ -34,6 +34,7 @@ Input
|
|||||||
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td> </td> <td>['integer', 'null']</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td> </td> <td>['integer', 'null']</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td> </td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td> </td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td> </td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>custom_adapters</td> <td> </td> <td>array</td> <td></td> </tr>
|
<tr><td>custom_adapters</td> <td> </td> <td>array</td> <td></td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td> </td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td> </td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td> </td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td> </td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
@ -63,6 +64,9 @@ Input
|
|||||||
<tr><td>process_priority</td> <td> </td> <td>enum</td> <td>Possible values: realtime, very high, high, normal, low, very low, null</td> </tr>
|
<tr><td>process_priority</td> <td> </td> <td>enum</td> <td>Possible values: realtime, very high, high, normal, low, very low, null</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td> </td> <td>['string', 'null']</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td> </td> <td>['string', 'null']</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td> </td> <td>['integer', 'null']</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td> </td> <td>['integer', 'null']</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td> </td> <td>['boolean', 'null']</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td> </td> <td>['boolean', 'null']</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td> </td> <td>string</td> <td>How to use the Qemu VM</td> </tr>
|
<tr><td>usage</td> <td> </td> <td>string</td> <td>How to use the Qemu VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
@ -84,6 +88,7 @@ Output
|
|||||||
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td>✔</td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
||||||
@ -113,8 +118,11 @@ Output
|
|||||||
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td>✔</td> <td>boolean</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
||||||
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td>✔</td> <td>boolean</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td>✔</td> <td>boolean</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ Output
|
|||||||
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td>✔</td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
||||||
@ -65,8 +66,11 @@ Output
|
|||||||
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td>✔</td> <td>boolean</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
||||||
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td>✔</td> <td>boolean</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td>✔</td> <td>boolean</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
@ -110,6 +114,7 @@ Input
|
|||||||
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td> </td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td> </td> <td>['integer', 'null']</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td> </td> <td>['integer', 'null']</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td> </td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td> </td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td> </td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>custom_adapters</td> <td> </td> <td>array</td> <td></td> </tr>
|
<tr><td>custom_adapters</td> <td> </td> <td>array</td> <td></td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td> </td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td> </td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td> </td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td> </td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
@ -138,6 +143,9 @@ Input
|
|||||||
<tr><td>process_priority</td> <td> </td> <td>enum</td> <td>Possible values: realtime, very high, high, normal, low, very low, null</td> </tr>
|
<tr><td>process_priority</td> <td> </td> <td>enum</td> <td>Possible values: realtime, very high, high, normal, low, very low, null</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td> </td> <td>['string', 'null']</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td> </td> <td>['string', 'null']</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td> </td> <td>['integer', 'null']</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td> </td> <td>['integer', 'null']</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td> </td> <td>['boolean', 'null']</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td> </td> <td>['boolean', 'null']</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td> </td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
<tr><td>usage</td> <td> </td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
@ -159,6 +167,7 @@ Output
|
|||||||
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td>✔</td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
||||||
@ -188,8 +197,11 @@ Output
|
|||||||
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td>✔</td> <td>boolean</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
||||||
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td>✔</td> <td>boolean</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td>✔</td> <td>boolean</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ Output
|
|||||||
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
<tr><td>console_type</td> <td>✔</td> <td>enum</td> <td>Possible values: telnet, vnc, spice, spice+agent, none</td> </tr>
|
||||||
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
<tr><td>cpu_throttling</td> <td>✔</td> <td>integer</td> <td>Percentage of CPU allowed for QEMU</td> </tr>
|
||||||
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
<tr><td>cpus</td> <td>✔</td> <td>['integer', 'null']</td> <td>Number of vCPUs</td> </tr>
|
||||||
|
<tr><td>create_config_disk</td> <td>✔</td> <td>['boolean', 'null']</td> <td>Automatically create a config disk on HDD disk interface (secondary slave)</td> </tr>
|
||||||
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
<tr><td>hda_disk_image</td> <td>✔</td> <td>string</td> <td>QEMU hda disk image path</td> </tr>
|
||||||
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
<tr><td>hda_disk_image_md5sum</td> <td>✔</td> <td>['string', 'null']</td> <td>QEMU hda disk image checksum</td> </tr>
|
||||||
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
<tr><td>hda_disk_interface</td> <td>✔</td> <td>string</td> <td>QEMU hda interface</td> </tr>
|
||||||
@ -65,8 +66,11 @@ Output
|
|||||||
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td>✔</td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
<tr><td>qemu_path</td> <td>✔</td> <td>string</td> <td>Path to QEMU</td> </tr>
|
||||||
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
<tr><td>ram</td> <td>✔</td> <td>integer</td> <td>Amount of RAM in MB</td> </tr>
|
||||||
|
<tr><td>replicate_network_connection_state</td> <td>✔</td> <td>boolean</td> <td>Replicate the network connection state for links in Qemu</td> </tr>
|
||||||
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
<tr><td>save_vm_state</td> <td> </td> <td>['boolean', 'null']</td> <td>Save VM state support</td> </tr>
|
||||||
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
<tr><td>status</td> <td>✔</td> <td>enum</td> <td>Possible values: started, stopped, suspended</td> </tr>
|
||||||
|
<tr><td>tpm</td> <td>✔</td> <td>boolean</td> <td>Enable the Trusted Platform Module (TPM) in Qemu</td> </tr>
|
||||||
|
<tr><td>uefi</td> <td>✔</td> <td>boolean</td> <td>Enable the UEFI boot mode in Qemu</td> </tr>
|
||||||
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
<tr><td>usage</td> <td>✔</td> <td>string</td> <td>How to use the QEMU VM</td> </tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
@ -47,6 +47,7 @@ Input
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
@ -65,6 +66,7 @@ Output
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
|
@ -30,6 +30,7 @@ Output
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
@ -69,6 +70,7 @@ Input
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
@ -87,6 +89,7 @@ Output
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
|
@ -39,6 +39,7 @@ Output
|
|||||||
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
<tr><td>capturing</td> <td> </td> <td>boolean</td> <td>Read only property. True if a capture running on the link</td> </tr>
|
||||||
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
<tr><td>filters</td> <td> </td> <td>object</td> <td>Packet filter. This allow to simulate latency and errors</td> </tr>
|
||||||
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
<tr><td>link_id</td> <td> </td> <td>string</td> <td>Link UUID</td> </tr>
|
||||||
|
<tr><td>link_style</td> <td> </td> <td>object</td> <td>Link line style</td> </tr>
|
||||||
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
<tr><td>link_type</td> <td> </td> <td>enum</td> <td>Possible values: ethernet, serial</td> </tr>
|
||||||
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
<tr><td>nodes</td> <td> </td> <td>array</td> <td>List of the VMS</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>string</td> <td>Project UUID</td> </tr>
|
||||||
|
@ -19,6 +19,8 @@ Input
|
|||||||
<table>
|
<table>
|
||||||
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
||||||
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
||||||
|
<tr><td>auto_open</td> <td> </td> <td>boolean</td> <td>Project open when GNS3 start</td> </tr>
|
||||||
|
<tr><td>auto_start</td> <td> </td> <td>boolean</td> <td>Project start when opened</td> </tr>
|
||||||
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
||||||
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
||||||
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
||||||
|
@ -24,11 +24,14 @@ Input
|
|||||||
<table>
|
<table>
|
||||||
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
<tr> <th>Name</th> <th>Mandatory</th> <th>Type</th> <th>Description</th> </tr>
|
||||||
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
<tr><td>auto_close</td> <td> </td> <td>boolean</td> <td>Project auto close</td> </tr>
|
||||||
|
<tr><td>auto_open</td> <td> </td> <td>boolean</td> <td>Project open when GNS3 start</td> </tr>
|
||||||
|
<tr><td>auto_start</td> <td> </td> <td>boolean</td> <td>Project start when opened</td> </tr>
|
||||||
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
<tr><td>drawing_grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for drawings</td> </tr>
|
||||||
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
<tr><td>grid_size</td> <td> </td> <td>integer</td> <td>Grid size for the drawing area for nodes</td> </tr>
|
||||||
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
<tr><td>name</td> <td>✔</td> <td>['string', 'null']</td> <td>Project name</td> </tr>
|
||||||
<tr><td>path</td> <td> </td> <td>['string', 'null']</td> <td>Project directory</td> </tr>
|
<tr><td>path</td> <td> </td> <td>['string', 'null']</td> <td>Project directory</td> </tr>
|
||||||
<tr><td>project_id</td> <td> </td> <td>['string', 'null']</td> <td>Project UUID</td> </tr>
|
<tr><td>project_id</td> <td> </td> <td>['string', 'null']</td> <td>Project UUID</td> </tr>
|
||||||
|
<tr><td>reset_mac_addresses</td> <td> </td> <td>boolean</td> <td>Reset MAC addresses for this project</td> </tr>
|
||||||
<tr><td>scene_height</td> <td> </td> <td>integer</td> <td>Height of the drawing area</td> </tr>
|
<tr><td>scene_height</td> <td> </td> <td>integer</td> <td>Height of the drawing area</td> </tr>
|
||||||
<tr><td>scene_width</td> <td> </td> <td>integer</td> <td>Width of the drawing area</td> </tr>
|
<tr><td>scene_width</td> <td> </td> <td>integer</td> <td>Width of the drawing area</td> </tr>
|
||||||
<tr><td>show_grid</td> <td> </td> <td>boolean</td> <td>Show the grid on the drawing area</td> </tr>
|
<tr><td>show_grid</td> <td> </td> <td>boolean</td> <td>Show the grid on the drawing area</td> </tr>
|
||||||
|
@ -50,6 +50,38 @@ A compute has been deleted.
|
|||||||
.. literalinclude:: api/notifications/compute.deleted.json
|
.. literalinclude:: api/notifications/compute.deleted.json
|
||||||
|
|
||||||
|
|
||||||
|
project.created
|
||||||
|
---------------
|
||||||
|
|
||||||
|
A project has been created.
|
||||||
|
|
||||||
|
.. literalinclude:: api/notifications/project.created.json
|
||||||
|
|
||||||
|
|
||||||
|
project.updated
|
||||||
|
---------------
|
||||||
|
|
||||||
|
A project has been updated.
|
||||||
|
|
||||||
|
.. literalinclude:: api/notifications/project.updated.json
|
||||||
|
|
||||||
|
|
||||||
|
project.closed
|
||||||
|
---------------
|
||||||
|
|
||||||
|
A project has been closed.
|
||||||
|
|
||||||
|
.. literalinclude:: api/notifications/project.closed.json
|
||||||
|
|
||||||
|
|
||||||
|
project.deleted
|
||||||
|
---------------
|
||||||
|
|
||||||
|
A project has been deleted.
|
||||||
|
|
||||||
|
.. literalinclude:: api/notifications/project.deleted.json
|
||||||
|
|
||||||
|
|
||||||
template.created
|
template.created
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
@ -576,7 +576,7 @@ Read :doc:`project_notifications` for more information.
|
|||||||
|
|
||||||
|
|
||||||
Where to find the endpoints?
|
Where to find the endpoints?
|
||||||
###########################
|
############################
|
||||||
|
|
||||||
A list of all endpoints is available: :doc:`endpoints`
|
A list of all endpoints is available: :doc:`endpoints`
|
||||||
|
|
||||||
|
@ -103,7 +103,8 @@
|
|||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"name": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Variable name"
|
"description": "Variable name",
|
||||||
|
"minLength": 1
|
||||||
},
|
},
|
||||||
"value": {
|
"value": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
@ -387,6 +388,27 @@
|
|||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
"description": "Suspend the link"
|
"description": "Suspend the link"
|
||||||
},
|
},
|
||||||
|
"link_style": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Link line style",
|
||||||
|
"items": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"color": {
|
||||||
|
"description": "Link line color",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"width": {
|
||||||
|
"description": "Link line width",
|
||||||
|
"type": "integer"
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"description": "Link line type",
|
||||||
|
"type": "integer"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"filters": {
|
"filters": {
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
||||||
"description": "Packet filter. This allow to simulate latency and errors",
|
"description": "Packet filter. This allow to simulate latency and errors",
|
||||||
|
@ -100,28 +100,12 @@ A drawing has been deleted.
|
|||||||
.. literalinclude:: api/notifications/drawing.deleted.json
|
.. literalinclude:: api/notifications/drawing.deleted.json
|
||||||
|
|
||||||
|
|
||||||
project.updated
|
|
||||||
---------------
|
|
||||||
|
|
||||||
A project has been updated.
|
|
||||||
|
|
||||||
.. literalinclude:: api/notifications/project.updated.json
|
|
||||||
|
|
||||||
|
|
||||||
project.closed
|
|
||||||
---------------
|
|
||||||
|
|
||||||
A project has been closed.
|
|
||||||
|
|
||||||
.. literalinclude:: api/notifications/project.closed.json
|
|
||||||
|
|
||||||
|
|
||||||
snapshot.restored
|
snapshot.restored
|
||||||
--------------------------
|
--------------------------
|
||||||
|
|
||||||
A snapshot has been restored
|
A snapshot has been restored
|
||||||
|
|
||||||
.. literalinclude:: api/notifications/project.snapshot_restored.json
|
.. literalinclude:: api/notifications/snapshot.restored.json
|
||||||
|
|
||||||
log.error
|
log.error
|
||||||
---------
|
---------
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
"status": "stable",
|
"status": "stable",
|
||||||
"maintainer": "GNS3 Team",
|
"maintainer": "GNS3 Team",
|
||||||
"maintainer_email": "developers@gns3.net",
|
"maintainer_email": "developers@gns3.net",
|
||||||
"usage": "Configure interfaces in /opt/bootlocal.sh, BIRD configuration is done in /usr/local/etc/bird",
|
"usage": "\n*** BIRD v1 is end-of-life ***\nPlease use the BIRD2 appliance.\n\nConfigure interfaces in /opt/bootlocal.sh, BIRD configuration is done in /usr/local/etc/bird",
|
||||||
"qemu": {
|
"qemu": {
|
||||||
"adapter_type": "e1000",
|
"adapter_type": "e1000",
|
||||||
"adapters": 4,
|
"adapters": 4,
|
||||||
|
@ -26,6 +26,13 @@
|
|||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "asav9-18-2.qcow2",
|
||||||
|
"version": "9.18.2 CML",
|
||||||
|
"md5sum": "6f10fe106edfad9163625770a47a6b73",
|
||||||
|
"filesize": 340262912,
|
||||||
|
"download_url": "https://learningnetworkstore.cisco.com/cisco-modeling-labs-personal/cisco-modeling-labs-personal/CML-PERSONAL.html"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "asav9-16-2.qcow2",
|
"filename": "asav9-16-2.qcow2",
|
||||||
"version": "9.16.2 CML",
|
"version": "9.16.2 CML",
|
||||||
@ -119,6 +126,12 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "9.18.2 CML",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "asav9-18-2.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "9.16.2 CML",
|
"name": "9.16.2 CML",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -24,6 +24,13 @@
|
|||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "c8000v-universalk9_8G_serial.17.09.01a.qcow2",
|
||||||
|
"version": "17.09.01a 8G",
|
||||||
|
"md5sum": "a10ae2c4d71f4eb611bc4d83ad7709f0",
|
||||||
|
"filesize": 1856634880,
|
||||||
|
"download_url": "https://software.cisco.com/download/home/286327102/type/282046477/release/Bengaluru-17.6.5"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "c8000v-universalk9_8G_serial.17.06.05.qcow2",
|
"filename": "c8000v-universalk9_8G_serial.17.06.05.qcow2",
|
||||||
"version": "17.06.05 8G",
|
"version": "17.06.05 8G",
|
||||||
@ -54,6 +61,12 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "17.09.01a 8G",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "c8000v-universalk9_8G_serial.17.09.01a.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "17.06.05 8G",
|
"name": "17.06.05 8G",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -24,6 +24,13 @@
|
|||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "csr1000v-universalk9.17.03.06-serial.qcow2",
|
||||||
|
"version": "17.03.06",
|
||||||
|
"md5sum": "086ab9bef6e66de847af0da3910c60e8",
|
||||||
|
"filesize": 1422000128,
|
||||||
|
"download_url": "https://software.cisco.com/download/home/284364978/type/282046477/release/Gibraltar-16.12.3"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "csr1000v-universalk9.16.12.03-serial.qcow2",
|
"filename": "csr1000v-universalk9.16.12.03-serial.qcow2",
|
||||||
"version": "16.12.3",
|
"version": "16.12.3",
|
||||||
@ -159,6 +166,12 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "17.03.06",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "csr1000v-universalk9.17.03.06-serial.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "16.12.3",
|
"name": "16.12.3",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -26,6 +26,13 @@
|
|||||||
"options": "-smp 4 -cpu host"
|
"options": "-smp 4 -cpu host"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "xrv9k-fullk9-x-7.7.1.qcow2",
|
||||||
|
"version": "7.7.1",
|
||||||
|
"md5sum": "682fff40d2ff373d8da3342906553b54",
|
||||||
|
"filesize": 1643905024,
|
||||||
|
"download_url": "https://software.cisco.com/download/home/286288939/type/280805694/release/7.1.1"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "xrv9k-fullk9-x-7.1.1.qcow2",
|
"filename": "xrv9k-fullk9-x-7.1.1.qcow2",
|
||||||
"version": "7.1.1",
|
"version": "7.1.1",
|
||||||
@ -105,6 +112,12 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "7.7.1",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "xrv9k-fullk9-x-7.7.1.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "7.1.1",
|
"name": "7.1.1",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -26,6 +26,13 @@
|
|||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "nexus9300v64.10.3.1.F.qcow2",
|
||||||
|
"version": "9300v 10.3.1.F",
|
||||||
|
"md5sum": "a6ffd2501a5791c11cee319943b912da",
|
||||||
|
"filesize": 2097086464,
|
||||||
|
"download_url": "https://software.cisco.com/download/home/286312239/type/282088129/release/10.1(1)"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "nexus9500v64.10.1.1.qcow2",
|
"filename": "nexus9500v64.10.1.1.qcow2",
|
||||||
"version": "9500v 10.1.1",
|
"version": "9500v 10.1.1",
|
||||||
@ -198,6 +205,13 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "9300v 10.3.1.F",
|
||||||
|
"images": {
|
||||||
|
"bios_image": "OVMF-edk2-stable202305.fd",
|
||||||
|
"hda_disk_image": "nexus9300v64.10.3.1.F.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "9500v 10.1.1",
|
"name": "9500v 10.1.1",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -24,12 +24,12 @@
|
|||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
{
|
{
|
||||||
"filename": "debian-12.2.qcow2",
|
"filename": "debian-12.4.qcow2",
|
||||||
"version": "12.2",
|
"version": "12.4",
|
||||||
"md5sum": "adf7716ec4a4e4e9e5ccfc7a1d7bd103",
|
"md5sum": "adcf7fdc25e10b3d2d9e2ef91168bffd",
|
||||||
"filesize": 286654464,
|
"filesize": 286179840,
|
||||||
"download_url": "https://sourceforge.net/projects/gns-3/files/Qemu%20Appliances/",
|
"download_url": "https://sourceforge.net/projects/gns-3/files/Qemu%20Appliances/",
|
||||||
"direct_download_url": "https://downloads.sourceforge.net/project/gns-3/Qemu%20Appliances/debian-12.2.qcow2"
|
"direct_download_url": "https://downloads.sourceforge.net/project/gns-3/Qemu%20Appliances/debian-12.4.qcow2"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"filename": "debian-11.8.qcow2",
|
"filename": "debian-11.8.qcow2",
|
||||||
@ -42,9 +42,9 @@
|
|||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
{
|
{
|
||||||
"name": "12.2",
|
"name": "12.4",
|
||||||
"images": {
|
"images": {
|
||||||
"hda_disk_image": "debian-12.2.qcow2"
|
"hda_disk_image": "debian-12.4.qcow2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -11,26 +11,36 @@
|
|||||||
"status": "experimental",
|
"status": "experimental",
|
||||||
"maintainer": "GNS3 Team",
|
"maintainer": "GNS3 Team",
|
||||||
"maintainer_email": "developers@gns3.net",
|
"maintainer_email": "developers@gns3.net",
|
||||||
"usage": "Make sure the Boot priority of the configuration template is HDD or CD.\n\nAbort the BCM process and format the flash after first boot by entering these commands:\nen\nformat flash:\n\nSometimes the flash device is not available after boot.",
|
"usage": "Make sure the Boot priority of the configuration template is HDD or CD.\n\nFor FTOS 9.8, switch to vnc console, start the device, abort the BMP process and format the flash after first boot by entering these commands:\nen\nformat flash:\n\nSometimes the flash device is not available after boot.",
|
||||||
"first_port_name": "Management0/0",
|
"first_port_name": "Management0/0",
|
||||||
"port_name_format": "fortyGigE0/{0}",
|
"port_name_format": "fortyGigE0/{0}",
|
||||||
"qemu": {
|
"qemu": {
|
||||||
"adapter_type": "e1000",
|
"adapter_type": "e1000",
|
||||||
"adapters": 6,
|
"adapters": 6,
|
||||||
"ram": 512,
|
"ram": 1024,
|
||||||
"hda_disk_interface": "ide",
|
"hda_disk_interface": "ide",
|
||||||
"arch": "i386",
|
"arch": "i386",
|
||||||
"console_type": "vnc",
|
"console_type": "telnet",
|
||||||
"boot_priority": "cd",
|
"boot_priority": "cd",
|
||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "FTOS-SI-9.13.0.0.iso",
|
||||||
|
"version": "9.13.0",
|
||||||
|
"md5sum": "8418049e451c76e7b85e36eca0a0a730",
|
||||||
|
"filesize": 131278848,
|
||||||
|
"download_url": "https://www.dell.com/support/kbdoc/en-us/000184062/ftos-for-s-series-os-emulator-current-release-evaluation-version",
|
||||||
|
"direct_download_url": "https://downloads.dell.com/translatedpdf/force10/os9/FTOS-SI-9.13.0.0.zip",
|
||||||
|
"compression": "zip"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "FTOS-SI-9.8.0.0.iso",
|
"filename": "FTOS-SI-9.8.0.0.iso",
|
||||||
"version": "9.8.0",
|
"version": "9.8.0",
|
||||||
"md5sum": "b9b50eda0a73407dc381792ff7975e24",
|
"md5sum": "b9b50eda0a73407dc381792ff7975e24",
|
||||||
"filesize": 108115968,
|
"filesize": 108115968,
|
||||||
"download_url": "https://www.force10networks.com/CSPortal20/Software/SSeriesDownloads.aspx",
|
"download_url": "https://www.dell.com/support/kbdoc/en-us/000184062/ftos-for-s-series-os-emulator-current-release-evaluation-version",
|
||||||
|
"direct_download_url": "https://downloads.dell.com/translatedpdf/force10/os9/FTOS-SI-9.8.0.0.zip",
|
||||||
"compression": "zip"
|
"compression": "zip"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -43,6 +53,13 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "9.13.0",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "empty30G.qcow2",
|
||||||
|
"cdrom_image": "FTOS-SI-9.13.0.0.iso"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "9.8.0",
|
"name": "9.8.0",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -26,6 +26,14 @@
|
|||||||
"options": "-nographic"
|
"options": "-nographic"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "Fedora-Cloud-Base-39-1.5.x86_64.qcow2",
|
||||||
|
"version": "39-1.5",
|
||||||
|
"md5sum": "800a10df2d369891ed65900bcacacd47",
|
||||||
|
"filesize": 544604160,
|
||||||
|
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/39/Cloud/x86_64/images",
|
||||||
|
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/39/Cloud/x86_64/images/Fedora-Cloud-Base-39-1.5.x86_64.qcow2"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "Fedora-Cloud-Base-38-1.6.x86_64.qcow2",
|
"filename": "Fedora-Cloud-Base-38-1.6.x86_64.qcow2",
|
||||||
"version": "38-1.6",
|
"version": "38-1.6",
|
||||||
@ -34,30 +42,6 @@
|
|||||||
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/38/Cloud/x86_64/images",
|
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/38/Cloud/x86_64/images",
|
||||||
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/38/Cloud/x86_64/images/Fedora-Cloud-Base-38-1.6.x86_64.qcow2"
|
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/38/Cloud/x86_64/images/Fedora-Cloud-Base-38-1.6.x86_64.qcow2"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"filename": "Fedora-Cloud-Base-37-1.7.x86_64.qcow2",
|
|
||||||
"version": "37-1.7",
|
|
||||||
"md5sum": "36f7b464b6ab46ad97c001b539495e90",
|
|
||||||
"filesize": 492830720,
|
|
||||||
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/37/Cloud/x86_64/images",
|
|
||||||
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/37/Cloud/x86_64/images/Fedora-Cloud-Base-37-1.7.x86_64.qcow2"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"filename": "Fedora-Cloud-Base-36-1.5.x86_64.qcow2",
|
|
||||||
"version": "36-1.5",
|
|
||||||
"md5sum": "7f7cdad25b77f232078bf454c39529d3",
|
|
||||||
"filesize": 448266240,
|
|
||||||
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/36/Cloud/x86_64/images",
|
|
||||||
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/36/Cloud/x86_64/images/Fedora-Cloud-Base-36-1.5.x86_64.qcow2"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"filename": "Fedora-Cloud-Base-35-1.2.x86_64.qcow2",
|
|
||||||
"version": "35-1.2",
|
|
||||||
"md5sum": "cfa9cdcfb946e5f4cf9dd4d7906008d0",
|
|
||||||
"filesize": 376897536,
|
|
||||||
"download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/35/Cloud/x86_64/images",
|
|
||||||
"direct_download_url": "https://download.fedoraproject.org/pub/fedora/linux/releases/35/Cloud/x86_64/images/Fedora-Cloud-Base-35-1.2.x86_64.qcow2"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"filename": "fedora-cloud-init-data.iso",
|
"filename": "fedora-cloud-init-data.iso",
|
||||||
"version": "1.0",
|
"version": "1.0",
|
||||||
@ -68,33 +52,19 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "39-1.5",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "Fedora-Cloud-Base-39-1.5.x86_64.qcow2",
|
||||||
|
"cdrom_image": "fedora-cloud-init-data.iso"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "38-1.6",
|
"name": "38-1.6",
|
||||||
"images": {
|
"images": {
|
||||||
"hda_disk_image": "Fedora-Cloud-Base-38-1.6.x86_64.qcow2",
|
"hda_disk_image": "Fedora-Cloud-Base-38-1.6.x86_64.qcow2",
|
||||||
"cdrom_image": "fedora-cloud-init-data.iso"
|
"cdrom_image": "fedora-cloud-init-data.iso"
|
||||||
}
|
}
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "37-1.7",
|
|
||||||
"images": {
|
|
||||||
"hda_disk_image": "Fedora-Cloud-Base-37-1.7.x86_64.qcow2",
|
|
||||||
"cdrom_image": "fedora-cloud-init-data.iso"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "36-1.5",
|
|
||||||
"images": {
|
|
||||||
"hda_disk_image": "Fedora-Cloud-Base-36-1.5.x86_64.qcow2",
|
|
||||||
"cdrom_image": "fedora-cloud-init-data.iso"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "35-1.2",
|
|
||||||
"images": {
|
|
||||||
"hda_disk_image": "Fedora-Cloud-Base-35-1.2.x86_64.qcow2",
|
|
||||||
"cdrom_image": "fedora-cloud-init-data.iso"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -7,16 +7,65 @@
|
|||||||
"vendor_url": "https://www.huawei.com",
|
"vendor_url": "https://www.huawei.com",
|
||||||
"product_name": "HuaWei NE40E",
|
"product_name": "HuaWei NE40E",
|
||||||
"product_url": "https://e.huawei.com/en/products/enterprise-networking/routers/ne/ne40e",
|
"product_url": "https://e.huawei.com/en/products/enterprise-networking/routers/ne/ne40e",
|
||||||
"registry_version": 4,
|
"registry_version": 6,
|
||||||
"status": "experimental",
|
"status": "experimental",
|
||||||
"availability": "service-contract",
|
"availability": "service-contract",
|
||||||
"maintainer": "none",
|
"maintainer": "none",
|
||||||
"maintainer_email": "",
|
"maintainer_email": "",
|
||||||
"first_port_name": "eth0",
|
|
||||||
"port_name_format": "Ethernet1/0/{0}",
|
"port_name_format": "Ethernet1/0/{0}",
|
||||||
"qemu": {
|
"qemu": {
|
||||||
"adapter_type": "e1000",
|
"adapter_type": "e1000",
|
||||||
"adapters": 12,
|
"adapters": 12,
|
||||||
|
"custom_adapters": [
|
||||||
|
{
|
||||||
|
"adapter_number": 0,
|
||||||
|
"port_name": "Gi0/0/0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 1,
|
||||||
|
"port_name": "Mgmt0/0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 2,
|
||||||
|
"port_name": "Ethernet1/0/0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 3,
|
||||||
|
"port_name": "Ethernet1/0/1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 4,
|
||||||
|
"port_name": "Ethernet1/0/2"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 5,
|
||||||
|
"port_name": "Ethernet1/0/3"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 6,
|
||||||
|
"port_name": "Ethernet1/0/4"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 7,
|
||||||
|
"port_name": "Ethernet1/0/5"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 8,
|
||||||
|
"port_name": "Ethernet1/0/6"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 9,
|
||||||
|
"port_name": "Ethernet1/0/7"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 10,
|
||||||
|
"port_name": "Ethernet1/0/8"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"adapter_number": 11,
|
||||||
|
"port_name": "Ethernet1/0/9"
|
||||||
|
}
|
||||||
|
],
|
||||||
"ram": 2048,
|
"ram": 2048,
|
||||||
"cpus": 2,
|
"cpus": 2,
|
||||||
"hda_disk_interface": "ide",
|
"hda_disk_interface": "ide",
|
||||||
|
@ -30,6 +30,13 @@
|
|||||||
"options": "-vga std -usbdevice tablet"
|
"options": "-vga std -usbdevice tablet"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"version": "1.3.0",
|
||||||
|
"filename": "ostinatostd-1.3.0-1.qcow2",
|
||||||
|
"filesize": 173735936,
|
||||||
|
"md5sum": "ff25fed989c43aeac84bf0d542ad43ba",
|
||||||
|
"download_url": "https://ostinato.org/pricing/gns3"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "ostinatostd-1.2.0-1.qcow2",
|
"filename": "ostinatostd-1.2.0-1.qcow2",
|
||||||
"version": "1.2.0",
|
"version": "1.2.0",
|
||||||
@ -46,6 +53,12 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "1.3.0",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "ostinatostd-1.3.0-1.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "1.2.0",
|
"name": "1.2.0",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -11,9 +11,9 @@
|
|||||||
"registry_version": 4,
|
"registry_version": 4,
|
||||||
"status": "stable",
|
"status": "stable",
|
||||||
"availability": "service-contract",
|
"availability": "service-contract",
|
||||||
"maintainer": "Neyder Achahuanco",
|
"maintainer": "Da-Geek",
|
||||||
"maintainer_email": "neyder@neyder.net",
|
"maintainer_email": "dageek@dageeks-geeks.gg",
|
||||||
"usage": "You should download Red Hat Enterprise Linux KVM Guest Image from https://access.redhat.com/downloads/content/479/ver=/rhel---9/9.2/x86_64/product-software attach/customize cloud-init.iso and start.\nusername: cloud-user\npassword: redhat",
|
"usage": "You should download Red Hat Enterprise Linux KVM Guest Image from https://access.redhat.com/downloads/content/479/ver=/rhel---9/9.3/x86_64/product-software attach/customize rhel-cloud-init.iso and start.\nusername: cloud-user\npassword: redhat",
|
||||||
"qemu": {
|
"qemu": {
|
||||||
"adapter_type": "virtio-net-pci",
|
"adapter_type": "virtio-net-pci",
|
||||||
"adapters": 1,
|
"adapters": 1,
|
||||||
@ -26,6 +26,13 @@
|
|||||||
"options": "-cpu host -nographic"
|
"options": "-cpu host -nographic"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "rhel-9.3-x86_64-kvm.qcow2",
|
||||||
|
"version": "9.3",
|
||||||
|
"md5sum": "409d8d15f5177db2617b0e3e02139b5c",
|
||||||
|
"filesize": 858193920,
|
||||||
|
"download_url": "https://access.redhat.com/downloads/content/479/ver=/rhel---9/9.3/x86_64/product-software"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "rhel-9.2-x86_64-kvm.qcow2",
|
"filename": "rhel-9.2-x86_64-kvm.qcow2",
|
||||||
"version": "9.2",
|
"version": "9.2",
|
||||||
@ -112,6 +119,13 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "9.3",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "rhel-9.3-x86_64-kvm.qcow2",
|
||||||
|
"cdrom_image": "rhel-cloud-init.iso"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "9.2",
|
"name": "9.2",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -26,6 +26,14 @@
|
|||||||
"options": "-nographic -cpu host"
|
"options": "-nographic -cpu host"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "Rocky-9-GenericCloud-Base-9.3-20231113.0.x86_64.qcow2",
|
||||||
|
"version": "9.3",
|
||||||
|
"md5sum": "48cdeb033364af5909e15ee48d0e144d",
|
||||||
|
"filesize": 1083965440,
|
||||||
|
"download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/",
|
||||||
|
"direct_download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/Rocky-9-GenericCloud-Base-9.3-20231113.0.x86_64.qcow2"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "Rocky-9-GenericCloud-Base-9.2-20230513.0.x86_64.qcow2",
|
"filename": "Rocky-9-GenericCloud-Base-9.2-20230513.0.x86_64.qcow2",
|
||||||
"version": "9.2",
|
"version": "9.2",
|
||||||
@ -34,6 +42,14 @@
|
|||||||
"download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/",
|
"download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/",
|
||||||
"direct_download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/Rocky-9-GenericCloud-Base-9.2-20230513.0.x86_64.qcow2"
|
"direct_download_url": "https://download.rockylinux.org/pub/rocky/9/images/x86_64/Rocky-9-GenericCloud-Base-9.2-20230513.0.x86_64.qcow2"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"filename": "Rocky-8-GenericCloud-Base-8.9-20231119.0.x86_64.qcow2",
|
||||||
|
"version": "8.9",
|
||||||
|
"md5sum": "50c44d8d9c4df43694372c13768f114c",
|
||||||
|
"filesize": 1971978240,
|
||||||
|
"download_url": "https://download.rockylinux.org/pub/rocky/8/images/x86_64/",
|
||||||
|
"direct_download_url": "https://download.rockylinux.org/pub/rocky/8/images/x86_64/Rocky-8-GenericCloud-Base-8.9-20231119.0.x86_64.qcow2"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "Rocky-8-GenericCloud-Base-8.8-20230518.0.x86_64.qcow2",
|
"filename": "Rocky-8-GenericCloud-Base-8.8-20230518.0.x86_64.qcow2",
|
||||||
"version": "8.8",
|
"version": "8.8",
|
||||||
@ -52,6 +68,13 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "9.3",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "Rocky-9-GenericCloud-Base-9.3-20231113.0.x86_64.qcow2",
|
||||||
|
"cdrom_image": "rocky-cloud-init-data.iso"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "9.2",
|
"name": "9.2",
|
||||||
"images": {
|
"images": {
|
||||||
@ -59,6 +82,13 @@
|
|||||||
"cdrom_image": "rocky-cloud-init-data.iso"
|
"cdrom_image": "rocky-cloud-init-data.iso"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "8.9",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "Rocky-8-GenericCloud-Base-8.9-20231119.0.x86_64.qcow2",
|
||||||
|
"cdrom_image": "rocky-cloud-init-data.iso"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "8.8",
|
"name": "8.8",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -28,12 +28,12 @@
|
|||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
{
|
{
|
||||||
"filename": "ubuntu-23.04-server-cloudimg-arm64.img",
|
"filename": "ubuntu-23.04-server-cloudimg-amd64.img",
|
||||||
"version": "Ubuntu 23.04 (Lunar Lobster)",
|
"version": "Ubuntu 23.04 (Lunar Lobster)",
|
||||||
"md5sum": "35fa3b31b65717af6f0520a769aac8c0",
|
"md5sum": "369e3b1f68416c39245a8014172406dd",
|
||||||
"filesize": 786432000,
|
"filesize": 756678656,
|
||||||
"download_url": "https://cloud-images.ubuntu.com/releases/23.04/release/",
|
"download_url": "https://cloud-images.ubuntu.com/releases/23.04/release/",
|
||||||
"direct_download_url": "https://cloud-images.ubuntu.com/releases/23.04/release/ubuntu-23.04-server-cloudimg-arm64.img"
|
"direct_download_url": "https://cloud-images.ubuntu.com/releases/23.04/release/ubuntu-23.04-server-cloudimg-amd64.img"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"filename": "ubuntu-22.04-server-cloudimg-amd64.img",
|
"filename": "ubuntu-22.04-server-cloudimg-amd64.img",
|
||||||
@ -72,7 +72,7 @@
|
|||||||
{
|
{
|
||||||
"name": "Ubuntu 23.04 (Lunar Lobster)",
|
"name": "Ubuntu 23.04 (Lunar Lobster)",
|
||||||
"images": {
|
"images": {
|
||||||
"hda_disk_image": "ubuntu-23.04-server-cloudimg-arm64.img",
|
"hda_disk_image": "ubuntu-23.04-server-cloudimg-amd64.img",
|
||||||
"cdrom_image": "ubuntu-cloud-init-data.iso"
|
"cdrom_image": "ubuntu-cloud-init-data.iso"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -656,6 +656,9 @@ class BaseNode:
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
path = self._manager.config.get_section_config("Server").get("ubridge_path", "ubridge")
|
path = self._manager.config.get_section_config("Server").get("ubridge_path", "ubridge")
|
||||||
|
if sys.platform.startswith("win") and hasattr(sys, "frozen"):
|
||||||
|
ubridge_dir = os.path.normpath(os.path.join(os.path.dirname(os.path.abspath(sys.executable)), "ubridge"))
|
||||||
|
os.environ["PATH"] = os.pathsep.join(ubridge_dir) + os.pathsep + os.environ.get("PATH", "")
|
||||||
path = shutil.which(path)
|
path = shutil.which(path)
|
||||||
return path
|
return path
|
||||||
|
|
||||||
|
@ -252,6 +252,9 @@ class Dynamips(BaseManager):
|
|||||||
# look for Dynamips
|
# look for Dynamips
|
||||||
dynamips_path = self.config.get_section_config("Dynamips").get("dynamips_path", "dynamips")
|
dynamips_path = self.config.get_section_config("Dynamips").get("dynamips_path", "dynamips")
|
||||||
if not os.path.isabs(dynamips_path):
|
if not os.path.isabs(dynamips_path):
|
||||||
|
if sys.platform.startswith("win") and hasattr(sys, "frozen"):
|
||||||
|
dynamips_dir = os.path.normpath(os.path.join(os.path.dirname(os.path.abspath(sys.executable)), "dynamips"))
|
||||||
|
os.environ["PATH"] = os.pathsep.join(dynamips_dir) + os.pathsep + os.environ.get("PATH", "")
|
||||||
dynamips_path = shutil.which(dynamips_path)
|
dynamips_path = shutil.which(dynamips_path)
|
||||||
|
|
||||||
if not dynamips_path:
|
if not dynamips_path:
|
||||||
|
@ -160,13 +160,20 @@ class Qemu(BaseManager):
|
|||||||
for arch in archs:
|
for arch in archs:
|
||||||
if f.endswith(arch) or f.endswith("{}.exe".format(arch)) or f.endswith("{}w.exe".format(arch)):
|
if f.endswith(arch) or f.endswith("{}.exe".format(arch)) or f.endswith("{}w.exe".format(arch)):
|
||||||
qemu_path = os.path.join(path, f)
|
qemu_path = os.path.join(path, f)
|
||||||
version = await Qemu.get_qemu_version(qemu_path)
|
try:
|
||||||
|
version = await Qemu.get_qemu_version(qemu_path)
|
||||||
|
except QemuError as e:
|
||||||
|
log.warning(str(e))
|
||||||
|
continue
|
||||||
qemus.append({"path": qemu_path, "version": version})
|
qemus.append({"path": qemu_path, "version": version})
|
||||||
else:
|
else:
|
||||||
qemu_path = os.path.join(path, f)
|
qemu_path = os.path.join(path, f)
|
||||||
version = await Qemu.get_qemu_version(qemu_path)
|
try:
|
||||||
|
version = await Qemu.get_qemu_version(qemu_path)
|
||||||
|
except QemuError as e:
|
||||||
|
log.warning(str(e))
|
||||||
|
continue
|
||||||
qemus.append({"path": qemu_path, "version": version})
|
qemus.append({"path": qemu_path, "version": version})
|
||||||
|
|
||||||
except OSError:
|
except OSError:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
@ -2426,6 +2426,9 @@ class QemuVM(BaseNode):
|
|||||||
command.extend(shlex.split(additional_options))
|
command.extend(shlex.split(additional_options))
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
raise QemuError("Invalid additional options: {} error {}".format(additional_options, e))
|
raise QemuError("Invalid additional options: {} error {}".format(additional_options, e))
|
||||||
|
# avoiding mouse offset (see https://github.com/GNS3/gns3-server/issues/2335)
|
||||||
|
if self._console_type == "vnc":
|
||||||
|
command.extend(['-machine', 'usb=on', '-device', 'usb-tablet'])
|
||||||
return command
|
return command
|
||||||
|
|
||||||
def __json__(self):
|
def __json__(self):
|
||||||
|
@ -140,6 +140,9 @@ class VPCSVM(BaseNode):
|
|||||||
|
|
||||||
vpcs_path = self._manager.config.get_section_config("VPCS").get("vpcs_path", "vpcs")
|
vpcs_path = self._manager.config.get_section_config("VPCS").get("vpcs_path", "vpcs")
|
||||||
if not os.path.isabs(vpcs_path):
|
if not os.path.isabs(vpcs_path):
|
||||||
|
if sys.platform.startswith("win") and hasattr(sys, "frozen"):
|
||||||
|
vpcs_dir = os.path.normpath(os.path.join(os.path.dirname(os.path.abspath(sys.executable)), "vpcs"))
|
||||||
|
os.environ["PATH"] = os.pathsep.join(vpcs_dir) + os.pathsep + os.environ.get("PATH", "")
|
||||||
vpcs_path = shutil.which(vpcs_path)
|
vpcs_path = shutil.which(vpcs_path)
|
||||||
return vpcs_path
|
return vpcs_path
|
||||||
|
|
||||||
|
@ -130,16 +130,27 @@ class Project:
|
|||||||
self._iou_id_lock = asyncio.Lock()
|
self._iou_id_lock = asyncio.Lock()
|
||||||
|
|
||||||
log.debug('Project "{name}" [{id}] loaded'.format(name=self.name, id=self._id))
|
log.debug('Project "{name}" [{id}] loaded'.format(name=self.name, id=self._id))
|
||||||
|
self.emit_controller_notification("project.created", self.__json__())
|
||||||
|
|
||||||
def emit_notification(self, action, event):
|
def emit_notification(self, action, event):
|
||||||
"""
|
"""
|
||||||
Emit a notification to all clients using this project.
|
Emit a project notification to all clients using this project.
|
||||||
|
|
||||||
:param action: Action name
|
:param action: Action name
|
||||||
:param event: Event to send
|
:param event: Event to send
|
||||||
"""
|
"""
|
||||||
|
|
||||||
self.controller.notification.project_emit(action, event, project_id=self.id)
|
self._controller.notification.project_emit(action, event, project_id=self.id)
|
||||||
|
|
||||||
|
def emit_controller_notification(self, action, event):
|
||||||
|
"""
|
||||||
|
Emit a controller notification, all clients will see it.
|
||||||
|
|
||||||
|
:param action: Action name
|
||||||
|
:param event: Event to send
|
||||||
|
"""
|
||||||
|
|
||||||
|
self._controller.notification.controller_emit(action, event)
|
||||||
|
|
||||||
async def update(self, **kwargs):
|
async def update(self, **kwargs):
|
||||||
"""
|
"""
|
||||||
@ -154,7 +165,7 @@ class Project:
|
|||||||
|
|
||||||
# We send notif only if object has changed
|
# We send notif only if object has changed
|
||||||
if old_json != self.__json__():
|
if old_json != self.__json__():
|
||||||
self.emit_notification("project.updated", self.__json__())
|
self.emit_controller_notification("project.updated", self.__json__())
|
||||||
self.dump()
|
self.dump()
|
||||||
|
|
||||||
# update on computes
|
# update on computes
|
||||||
@ -803,7 +814,8 @@ class Project:
|
|||||||
self._clean_pictures()
|
self._clean_pictures()
|
||||||
self._status = "closed"
|
self._status = "closed"
|
||||||
if not ignore_notification:
|
if not ignore_notification:
|
||||||
self.emit_notification("project.closed", self.__json__())
|
self.emit_controller_notification("project.closed", self.__json__())
|
||||||
|
|
||||||
self.reset()
|
self.reset()
|
||||||
self._closing = False
|
self._closing = False
|
||||||
|
|
||||||
@ -857,6 +869,7 @@ class Project:
|
|||||||
shutil.rmtree(self.path)
|
shutil.rmtree(self.path)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
raise aiohttp.web.HTTPConflict(text="Cannot delete project directory {}: {}".format(self.path, str(e)))
|
raise aiohttp.web.HTTPConflict(text="Cannot delete project directory {}: {}".format(self.path, str(e)))
|
||||||
|
self.emit_controller_notification("project.deleted", self.__json__())
|
||||||
|
|
||||||
async def delete_on_computes(self):
|
async def delete_on_computes(self):
|
||||||
"""
|
"""
|
||||||
@ -976,7 +989,7 @@ class Project:
|
|||||||
await self.add_drawing(dump=False, **drawing_data)
|
await self.add_drawing(dump=False, **drawing_data)
|
||||||
|
|
||||||
self.dump()
|
self.dump()
|
||||||
# We catch all error to be able to rollback the .gns3 to the previous state
|
# We catch all error to be able to roll back the .gns3 to the previous state
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
for compute in list(self._project_created_on_compute):
|
for compute in list(self._project_created_on_compute):
|
||||||
try:
|
try:
|
||||||
@ -1001,6 +1014,7 @@ class Project:
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
self._loading = False
|
self._loading = False
|
||||||
|
self.emit_controller_notification("project.opened", self.__json__())
|
||||||
# Should we start the nodes when project is open
|
# Should we start the nodes when project is open
|
||||||
if self._auto_start:
|
if self._auto_start:
|
||||||
# Start all in the background without waiting for completion
|
# Start all in the background without waiting for completion
|
||||||
|
@ -57,7 +57,7 @@ class CrashReport:
|
|||||||
Report crash to a third party service
|
Report crash to a third party service
|
||||||
"""
|
"""
|
||||||
|
|
||||||
DSN = "https://eb1150edfa1530053154ff1fcb67afd1@o19455.ingest.sentry.io/38482"
|
DSN = "https://ffea69bec1b4f934d815234ea0046382@o19455.ingest.sentry.io/38482"
|
||||||
_instance = None
|
_instance = None
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
@ -17,28 +17,30 @@
|
|||||||
|
|
||||||
import copy
|
import copy
|
||||||
|
|
||||||
|
ETHERNET_HUB_PORT_SCHEMA = {
|
||||||
|
"description": "Ethernet port",
|
||||||
|
"properties": {
|
||||||
|
"name": {
|
||||||
|
"description": "Port name",
|
||||||
|
"type": "string",
|
||||||
|
"minLength": 1,
|
||||||
|
},
|
||||||
|
"port_number": {
|
||||||
|
"description": "Port number",
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 0
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"required": ["name", "port_number"],
|
||||||
|
"additionalProperties": False
|
||||||
|
}
|
||||||
|
|
||||||
ETHERNET_HUB_CREATE_SCHEMA = {
|
ETHERNET_HUB_CREATE_SCHEMA = {
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
||||||
"description": "Request validation to create a new Ethernet hub instance",
|
"description": "Request validation to create a new Ethernet hub instance",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"definitions": {
|
"definitions": {
|
||||||
"EthernetHubPort": {
|
"EthernetHubPort": ETHERNET_HUB_PORT_SCHEMA
|
||||||
"description": "Ethernet port",
|
|
||||||
"properties": {
|
|
||||||
"name": {
|
|
||||||
"description": "Port name",
|
|
||||||
"type": "string",
|
|
||||||
"minLength": 1,
|
|
||||||
},
|
|
||||||
"port_number": {
|
|
||||||
"description": "Port number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 0
|
|
||||||
},
|
|
||||||
},
|
|
||||||
"required": ["name", "port_number"],
|
|
||||||
"additionalProperties": False
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"name": {
|
||||||
@ -57,12 +59,9 @@ ETHERNET_HUB_CREATE_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"ports_mapping": {
|
"ports_mapping": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": [
|
"items": {
|
||||||
{"type": "object",
|
"$ref": "#/definitions/EthernetHubPort"
|
||||||
"oneOf": [
|
}
|
||||||
{"$ref": "#/definitions/EthernetHubPort"}
|
|
||||||
]},
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
@ -74,23 +73,7 @@ ETHERNET_HUB_OBJECT_SCHEMA = {
|
|||||||
"description": "Ethernet hub instance",
|
"description": "Ethernet hub instance",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"definitions": {
|
"definitions": {
|
||||||
"EthernetHubPort": {
|
"EthernetHubPort": ETHERNET_HUB_PORT_SCHEMA
|
||||||
"description": "Ethernet port",
|
|
||||||
"properties": {
|
|
||||||
"name": {
|
|
||||||
"description": "Port name",
|
|
||||||
"type": "string",
|
|
||||||
"minLength": 1,
|
|
||||||
},
|
|
||||||
"port_number": {
|
|
||||||
"description": "Port number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 0
|
|
||||||
},
|
|
||||||
},
|
|
||||||
"required": ["name", "port_number"],
|
|
||||||
"additionalProperties": False
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"name": {
|
||||||
@ -114,12 +97,9 @@ ETHERNET_HUB_OBJECT_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"ports_mapping": {
|
"ports_mapping": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": [
|
"items": {
|
||||||
{"type": "object",
|
"$ref": "#/definitions/EthernetHubPort"
|
||||||
"oneOf": [
|
}
|
||||||
{"$ref": "#/definitions/EthernetHubPort"}
|
|
||||||
]},
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"status": {
|
"status": {
|
||||||
"description": "Node status",
|
"description": "Node status",
|
||||||
|
@ -17,40 +17,42 @@
|
|||||||
|
|
||||||
import copy
|
import copy
|
||||||
|
|
||||||
|
ETHERNET_SWITCH_PORT_SCHEMA = {
|
||||||
|
"description": "Ethernet switch port",
|
||||||
|
"properties": {
|
||||||
|
"name": {
|
||||||
|
"description": "Port name",
|
||||||
|
"type": "string",
|
||||||
|
"minLength": 1,
|
||||||
|
},
|
||||||
|
"port_number": {
|
||||||
|
"description": "Port number",
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 0
|
||||||
|
},
|
||||||
|
"type": {
|
||||||
|
"description": "Port type",
|
||||||
|
"enum": ["access", "dot1q", "qinq"],
|
||||||
|
},
|
||||||
|
"vlan": {"description": "VLAN number",
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1
|
||||||
|
},
|
||||||
|
"ethertype": {
|
||||||
|
"description": "QinQ Ethertype",
|
||||||
|
"enum": ["", "0x8100", "0x88A8", "0x9100", "0x9200"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"required": ["name", "port_number", "type"],
|
||||||
|
"additionalProperties": False
|
||||||
|
}
|
||||||
|
|
||||||
ETHERNET_SWITCH_CREATE_SCHEMA = {
|
ETHERNET_SWITCH_CREATE_SCHEMA = {
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
||||||
"description": "Request validation to create a new Ethernet switch instance",
|
"description": "Request validation to create a new Ethernet switch instance",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"definitions": {
|
"definitions": {
|
||||||
"EthernetSwitchPort": {
|
"EthernetSwitchPort": ETHERNET_SWITCH_PORT_SCHEMA
|
||||||
"description": "Ethernet port",
|
|
||||||
"properties": {
|
|
||||||
"name": {
|
|
||||||
"description": "Port name",
|
|
||||||
"type": "string",
|
|
||||||
"minLength": 1,
|
|
||||||
},
|
|
||||||
"port_number": {
|
|
||||||
"description": "Port number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 0
|
|
||||||
},
|
|
||||||
"type": {
|
|
||||||
"description": "Port type",
|
|
||||||
"enum": ["access", "dot1q", "qinq"],
|
|
||||||
},
|
|
||||||
"vlan": {"description": "VLAN number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 1
|
|
||||||
},
|
|
||||||
"ethertype": {
|
|
||||||
"description": "QinQ Ethertype",
|
|
||||||
"enum": ["", "0x8100", "0x88A8", "0x9100", "0x9200"],
|
|
||||||
},
|
|
||||||
},
|
|
||||||
"required": ["name", "port_number", "type"],
|
|
||||||
"additionalProperties": False
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"name": {
|
||||||
@ -79,12 +81,9 @@ ETHERNET_SWITCH_CREATE_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"ports_mapping": {
|
"ports_mapping": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": [
|
"items": {
|
||||||
{"type": "object",
|
"$ref": "#/definitions/EthernetSwitchPort"
|
||||||
"oneOf": [
|
}
|
||||||
{"$ref": "#/definitions/EthernetSwitchPort"}
|
|
||||||
]},
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
@ -96,35 +95,7 @@ ETHERNET_SWITCH_OBJECT_SCHEMA = {
|
|||||||
"description": "Ethernet switch instance",
|
"description": "Ethernet switch instance",
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"definitions": {
|
"definitions": {
|
||||||
"EthernetSwitchPort": {
|
"EthernetSwitchPort": ETHERNET_SWITCH_PORT_SCHEMA
|
||||||
"description": "Ethernet port",
|
|
||||||
"properties": {
|
|
||||||
"name": {
|
|
||||||
"description": "Port name",
|
|
||||||
"type": "string",
|
|
||||||
"minLength": 1,
|
|
||||||
},
|
|
||||||
"port_number": {
|
|
||||||
"description": "Port number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 0
|
|
||||||
},
|
|
||||||
"type": {
|
|
||||||
"description": "Port type",
|
|
||||||
"enum": ["access", "dot1q", "qinq"],
|
|
||||||
},
|
|
||||||
"vlan": {"description": "VLAN number",
|
|
||||||
"type": "integer",
|
|
||||||
"minimum": 1
|
|
||||||
},
|
|
||||||
"ethertype": {
|
|
||||||
"description": "QinQ Ethertype",
|
|
||||||
"enum": ["", "0x8100", "0x88A8", "0x9100", "0x9200"],
|
|
||||||
},
|
|
||||||
},
|
|
||||||
"required": ["name", "port_number", "type"],
|
|
||||||
"additionalProperties": False
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"properties": {
|
"properties": {
|
||||||
"name": {
|
"name": {
|
||||||
@ -148,12 +119,9 @@ ETHERNET_SWITCH_OBJECT_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"ports_mapping": {
|
"ports_mapping": {
|
||||||
"type": "array",
|
"type": "array",
|
||||||
"items": [
|
"items": {
|
||||||
{"type": "object",
|
"$ref": "#/definitions/EthernetSwitchPort"
|
||||||
"oneOf": [
|
}
|
||||||
{"$ref": "#/definitions/EthernetSwitchPort"}
|
|
||||||
]},
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"status": {
|
"status": {
|
||||||
"description": "Node status",
|
"description": "Node status",
|
||||||
|
@ -1542,6 +1542,29 @@ ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|||||||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
|
||||||
|
ipaddr.js
|
||||||
|
MIT
|
||||||
|
Copyright (C) 2011-2017 whitequark <whitequark@whitequark.org>
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
THE SOFTWARE.
|
||||||
|
|
||||||
|
|
||||||
mdn-data
|
mdn-data
|
||||||
CC0-1.0
|
CC0-1.0
|
||||||
CC0 1.0 Universal
|
CC0 1.0 Universal
|
||||||
|
@ -46,6 +46,6 @@
|
|||||||
|
|
||||||
gtag('config', 'G-5D6FZL9923');
|
gtag('config', 'G-5D6FZL9923');
|
||||||
</script>
|
</script>
|
||||||
<script src="runtime.baa1121a4737aeb68bb7.js" defer></script><script src="polyfills-es5.865074f5cd9a121111a2.js" nomodule defer></script><script src="polyfills.2f91a039d848e57ff02e.js" defer></script><script src="main.383fdade2fd9dbccffbc.js" defer></script>
|
<script src="runtime.ecefb4ce510d1c218e7d.js" defer></script><script src="polyfills-es5.865074f5cd9a121111a2.js" nomodule defer></script><script src="polyfills.2f91a039d848e57ff02e.js" defer></script><script src="main.054d2e56a89c0b6f1b49.js" defer></script>
|
||||||
|
|
||||||
</body></html>
|
</body></html>
|
1
gns3server/static/web-ui/main.054d2e56a89c0b6f1b49.js
Normal file
1
gns3server/static/web-ui/main.054d2e56a89c0b6f1b49.js
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -1 +0,0 @@
|
|||||||
!function(){"use strict";var e,v={},g={};function n(e){var a=g[e];if(void 0!==a)return a.exports;var t=g[e]={id:e,loaded:!1,exports:{}};return v[e](t,t.exports,n),t.loaded=!0,t.exports}n.m=v,e=[],n.O=function(a,t,u,o){if(!t){var r=1/0;for(i=0;i<e.length;i++){t=e[i][0],u=e[i][1],o=e[i][2];for(var l=!0,f=0;f<t.length;f++)(!1&o||r>=o)&&Object.keys(n.O).every(function(b){return n.O[b](t[f])})?t.splice(f--,1):(l=!1,o<r&&(r=o));if(l){e.splice(i--,1);var s=u();void 0!==s&&(a=s)}}return a}o=o||0;for(var i=e.length;i>0&&e[i-1][2]>o;i--)e[i]=e[i-1];e[i]=[t,u,o]},n.n=function(e){var a=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(a,{a:a}),a},n.d=function(e,a){for(var t in a)n.o(a,t)&&!n.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:a[t]})},n.f={},n.e=function(e){return Promise.all(Object.keys(n.f).reduce(function(a,t){return n.f[t](e,a),a},[]))},n.u=function(e){return e+".49028ab13de5de406c90.js"},n.miniCssF=function(e){return"styles.f8555f2eecf8cf87f666.css"},n.hmd=function(e){return(e=Object.create(e)).children||(e.children=[]),Object.defineProperty(e,"exports",{enumerable:!0,set:function(){throw new Error("ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: "+e.id)}}),e},n.o=function(e,a){return Object.prototype.hasOwnProperty.call(e,a)},function(){var e={},a="gns3-web-ui:";n.l=function(t,u,o,i){if(e[t])e[t].push(u);else{var r,l;if(void 0!==o)for(var f=document.getElementsByTagName("script"),s=0;s<f.length;s++){var c=f[s];if(c.getAttribute("src")==t||c.getAttribute("data-webpack")==a+o){r=c;break}}r||(l=!0,(r=document.createElement("script")).charset="utf-8",r.timeout=120,n.nc&&r.setAttribute("nonce",n.nc),r.setAttribute("data-webpack",a+o),r.src=n.tu(t)),e[t]=[u];var d=function(h,b){r.onerror=r.onload=null,clearTimeout(p);var _=e[t];if(delete e[t],r.parentNode&&r.parentNode.removeChild(r),_&&_.forEach(function(m){return m(b)}),h)return h(b)},p=setTimeout(d.bind(null,void 0,{type:"timeout",target:r}),12e4);r.onerror=d.bind(null,r.onerror),r.onload=d.bind(null,r.onload),l&&document.head.appendChild(r)}}}(),n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},function(){var e;n.tu=function(a){return void 0===e&&(e={createScriptURL:function(t){return t}},"undefined"!=typeof trustedTypes&&trustedTypes.createPolicy&&(e=trustedTypes.createPolicy("angular#bundler",e))),e.createScriptURL(a)}}(),n.p="",function(){var e={666:0};n.f.j=function(u,o){var i=n.o(e,u)?e[u]:void 0;if(0!==i)if(i)o.push(i[2]);else if(666!=u){var r=new Promise(function(c,d){i=e[u]=[c,d]});o.push(i[2]=r);var l=n.p+n.u(u),f=new Error;n.l(l,function(c){if(n.o(e,u)&&(0!==(i=e[u])&&(e[u]=void 0),i)){var d=c&&("load"===c.type?"missing":c.type),p=c&&c.target&&c.target.src;f.message="Loading chunk "+u+" failed.\n("+d+": "+p+")",f.name="ChunkLoadError",f.type=d,f.request=p,i[1](f)}},"chunk-"+u,u)}else e[u]=0},n.O.j=function(u){return 0===e[u]};var a=function(u,o){var f,s,i=o[0],r=o[1],l=o[2],c=0;for(f in r)n.o(r,f)&&(n.m[f]=r[f]);if(l)var d=l(n);for(u&&u(o);c<i.length;c++)n.o(e,s=i[c])&&e[s]&&e[s][0](),e[i[c]]=0;return n.O(d)},t=self.webpackChunkgns3_web_ui=self.webpackChunkgns3_web_ui||[];t.forEach(a.bind(null,0)),t.push=a.bind(null,t.push.bind(t))}()}();
|
|
1
gns3server/static/web-ui/runtime.ecefb4ce510d1c218e7d.js
Normal file
1
gns3server/static/web-ui/runtime.ecefb4ce510d1c218e7d.js
Normal file
@ -0,0 +1 @@
|
|||||||
|
!function(){"use strict";var e,v={},g={};function n(e){var a=g[e];if(void 0!==a)return a.exports;var t=g[e]={id:e,loaded:!1,exports:{}};return v[e].call(t.exports,t,t.exports,n),t.loaded=!0,t.exports}n.m=v,e=[],n.O=function(a,t,u,o){if(!t){var r=1/0;for(i=0;i<e.length;i++){t=e[i][0],u=e[i][1],o=e[i][2];for(var l=!0,f=0;f<t.length;f++)(!1&o||r>=o)&&Object.keys(n.O).every(function(b){return n.O[b](t[f])})?t.splice(f--,1):(l=!1,o<r&&(r=o));if(l){e.splice(i--,1);var s=u();void 0!==s&&(a=s)}}return a}o=o||0;for(var i=e.length;i>0&&e[i-1][2]>o;i--)e[i]=e[i-1];e[i]=[t,u,o]},n.n=function(e){var a=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(a,{a:a}),a},n.d=function(e,a){for(var t in a)n.o(a,t)&&!n.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:a[t]})},n.f={},n.e=function(e){return Promise.all(Object.keys(n.f).reduce(function(a,t){return n.f[t](e,a),a},[]))},n.u=function(e){return e+".49028ab13de5de406c90.js"},n.miniCssF=function(e){return"styles.f8555f2eecf8cf87f666.css"},n.hmd=function(e){return(e=Object.create(e)).children||(e.children=[]),Object.defineProperty(e,"exports",{enumerable:!0,set:function(){throw new Error("ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: "+e.id)}}),e},n.o=function(e,a){return Object.prototype.hasOwnProperty.call(e,a)},function(){var e={},a="gns3-web-ui:";n.l=function(t,u,o,i){if(e[t])e[t].push(u);else{var r,l;if(void 0!==o)for(var f=document.getElementsByTagName("script"),s=0;s<f.length;s++){var c=f[s];if(c.getAttribute("src")==t||c.getAttribute("data-webpack")==a+o){r=c;break}}r||(l=!0,(r=document.createElement("script")).charset="utf-8",r.timeout=120,n.nc&&r.setAttribute("nonce",n.nc),r.setAttribute("data-webpack",a+o),r.src=n.tu(t)),e[t]=[u];var d=function(h,b){r.onerror=r.onload=null,clearTimeout(p);var _=e[t];if(delete e[t],r.parentNode&&r.parentNode.removeChild(r),_&&_.forEach(function(m){return m(b)}),h)return h(b)},p=setTimeout(d.bind(null,void 0,{type:"timeout",target:r}),12e4);r.onerror=d.bind(null,r.onerror),r.onload=d.bind(null,r.onload),l&&document.head.appendChild(r)}}}(),n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},function(){var e;n.tu=function(a){return void 0===e&&(e={createScriptURL:function(t){return t}},"undefined"!=typeof trustedTypes&&trustedTypes.createPolicy&&(e=trustedTypes.createPolicy("angular#bundler",e))),e.createScriptURL(a)}}(),n.p="",function(){var e={666:0};n.f.j=function(u,o){var i=n.o(e,u)?e[u]:void 0;if(0!==i)if(i)o.push(i[2]);else if(666!=u){var r=new Promise(function(c,d){i=e[u]=[c,d]});o.push(i[2]=r);var l=n.p+n.u(u),f=new Error;n.l(l,function(c){if(n.o(e,u)&&(0!==(i=e[u])&&(e[u]=void 0),i)){var d=c&&("load"===c.type?"missing":c.type),p=c&&c.target&&c.target.src;f.message="Loading chunk "+u+" failed.\n("+d+": "+p+")",f.name="ChunkLoadError",f.type=d,f.request=p,i[1](f)}},"chunk-"+u,u)}else e[u]=0},n.O.j=function(u){return 0===e[u]};var a=function(u,o){var f,s,i=o[0],r=o[1],l=o[2],c=0;for(f in r)n.o(r,f)&&(n.m[f]=r[f]);if(l)var d=l(n);for(u&&u(o);c<i.length;c++)n.o(e,s=i[c])&&e[s]&&e[s][0](),e[i[c]]=0;return n.O(d)},t=self.webpackChunkgns3_web_ui=self.webpackChunkgns3_web_ui||[];t.forEach(a.bind(null,0)),t.push=a.bind(null,t.push.bind(t))}()}();
|
@ -23,8 +23,8 @@
|
|||||||
# or negative for a release candidate or beta (after the base version
|
# or negative for a release candidate or beta (after the base version
|
||||||
# number has been incremented)
|
# number has been incremented)
|
||||||
|
|
||||||
__version__ = "2.2.44.1"
|
__version__ = "2.2.45"
|
||||||
__version_info__ = (2, 2, 44, -99)
|
__version_info__ = (2, 2, 45, 0)
|
||||||
|
|
||||||
if "dev" in __version__:
|
if "dev" in __version__:
|
||||||
try:
|
try:
|
||||||
|
@ -311,13 +311,13 @@ class WebServer:
|
|||||||
# Background task started with the server
|
# Background task started with the server
|
||||||
self._app.on_startup.append(self._on_startup)
|
self._app.on_startup.append(self._on_startup)
|
||||||
|
|
||||||
resource_options = aiohttp_cors.ResourceOptions(expose_headers="*", allow_headers="*", max_age=0)
|
resource_options = aiohttp_cors.ResourceOptions(allow_credentials=True, expose_headers="*", allow_headers="*", max_age=0)
|
||||||
|
|
||||||
# Allow CORS for this domains
|
# Allow CORS for this domains
|
||||||
cors = aiohttp_cors.setup(self._app, defaults={
|
cors = aiohttp_cors.setup(self._app, defaults={
|
||||||
# Default web server for web gui dev
|
# Default web server for web gui dev
|
||||||
"http://127.0.0.1:8080": resource_options,
|
"http://127.0.0.1:3080": resource_options,
|
||||||
"http://localhost:8080": resource_options,
|
"http://localhost:3080": resource_options,
|
||||||
"http://127.0.0.1:4200": resource_options,
|
"http://127.0.0.1:4200": resource_options,
|
||||||
"http://localhost:4200": resource_options,
|
"http://localhost:4200": resource_options,
|
||||||
"http://gns3.github.io": resource_options,
|
"http://gns3.github.io": resource_options,
|
||||||
|
@ -1,5 +1,9 @@
|
|||||||
build:
|
version: 2
|
||||||
image: latest
|
|
||||||
|
|
||||||
python:
|
build:
|
||||||
version: 3.6
|
os: "ubuntu-22.04"
|
||||||
|
tools:
|
||||||
|
python: "3.12"
|
||||||
|
|
||||||
|
sphinx:
|
||||||
|
configuration: docs/conf.py
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
jsonschema>=4.17.3,<4.18; python_version >= '3.7' # v4.17.3 is the last version to support Python 3.7
|
jsonschema>=4.17.3,<4.18; python_version >= '3.7' # v4.17.3 is the last version to support Python 3.7
|
||||||
jsonschema==3.2.0; python_version < '3.7' # v3.2.0 is the last version to support Python 3.6
|
jsonschema==3.2.0; python_version < '3.7' # v3.2.0 is the last version to support Python 3.6
|
||||||
aiohttp>=3.8.5,<3.9; python_version < '3.12'
|
aiohttp>=3.8.5,<3.9; python_version <= '3.7'
|
||||||
aiohttp==3.9.0b0; python_version == '3.12'
|
aiohttp>=3.9.0,<3.10; python_version > '3.7'
|
||||||
aiohttp-cors>=0.7.0,<0.8
|
aiohttp-cors>=0.7.0,<0.8
|
||||||
aiofiles>=23.2.1,<23.3; python_version >= '3.7'
|
aiofiles>=23.2.1,<23.3; python_version >= '3.7'
|
||||||
aiofiles==0.8.0; python_version < '3.7' # v0.8.0 is the last version to support Python 3.6
|
aiofiles==0.8.0; python_version < '3.7' # v0.8.0 is the last version to support Python 3.6
|
||||||
Jinja2>=3.1.2,<3.2; python_version >= '3.7'
|
Jinja2>=3.1.2,<3.2; python_version >= '3.7'
|
||||||
Jinja2==3.0.3; python_version < '3.7' # v3.0.3 is the last version to support Python 3.6
|
Jinja2==3.0.3; python_version < '3.7' # v3.0.3 is the last version to support Python 3.6
|
||||||
sentry-sdk==1.34.0,<1.35
|
sentry-sdk==1.36.0,<1.37
|
||||||
psutil==5.9.6
|
psutil==5.9.6
|
||||||
async-timeout>=4.0.2,<4.1
|
async-timeout>=4.0.2,<4.1
|
||||||
distro>=1.8.0
|
distro>=1.8.0
|
||||||
|
@ -213,7 +213,9 @@ async def test_compute_httpQuery_project(compute):
|
|||||||
response = MagicMock()
|
response = MagicMock()
|
||||||
with asyncio_patch("aiohttp.ClientSession.request", return_value=response) as mock:
|
with asyncio_patch("aiohttp.ClientSession.request", return_value=response) as mock:
|
||||||
response.status = 200
|
response.status = 200
|
||||||
project = Project(name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification') as mock_notification:
|
||||||
|
project = Project(name="Test")
|
||||||
|
mock_notification.assert_called()
|
||||||
await compute.post("/projects", project)
|
await compute.post("/projects", project)
|
||||||
mock.assert_called_with("POST", "https://example.com:84/v2/compute/projects", data=json.dumps(project.__json__()), headers={'content-type': 'application/json'}, auth=None, chunked=None, timeout=20)
|
mock.assert_called_with("POST", "https://example.com:84/v2/compute/projects", data=json.dumps(project.__json__()), headers={'content-type': 'application/json'}, auth=None, chunked=None, timeout=20)
|
||||||
await compute.close()
|
await compute.close()
|
||||||
|
@ -47,15 +47,19 @@ async def node(controller, project):
|
|||||||
|
|
||||||
async def test_affect_uuid():
|
async def test_affect_uuid():
|
||||||
|
|
||||||
p = Project(name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification') as mock_notification:
|
||||||
assert len(p.id) == 36
|
p = Project(name="Test")
|
||||||
p = Project(project_id='00010203-0405-0607-0809-0a0b0c0d0e0f', name="Test 2")
|
mock_notification.assert_called()
|
||||||
assert p.id == '00010203-0405-0607-0809-0a0b0c0d0e0f'
|
assert len(p.id) == 36
|
||||||
|
p = Project(project_id='00010203-0405-0607-0809-0a0b0c0d0e0f', name="Test 2")
|
||||||
|
assert p.id == '00010203-0405-0607-0809-0a0b0c0d0e0f'
|
||||||
|
|
||||||
|
|
||||||
async def test_json():
|
async def test_json():
|
||||||
|
|
||||||
p = Project(name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification') as mock_notification:
|
||||||
|
p = Project(name="Test")
|
||||||
|
mock_notification.assert_called()
|
||||||
|
|
||||||
assert p.__json__() == {
|
assert p.__json__() == {
|
||||||
"name": "Test",
|
"name": "Test",
|
||||||
@ -83,11 +87,11 @@ async def test_json():
|
|||||||
async def test_update(controller):
|
async def test_update(controller):
|
||||||
|
|
||||||
project = Project(controller=controller, name="Hello")
|
project = Project(controller=controller, name="Hello")
|
||||||
project.emit_notification = MagicMock()
|
project.emit_controller_notification = MagicMock()
|
||||||
assert project.name == "Hello"
|
assert project.name == "Hello"
|
||||||
await project.update(name="World")
|
await project.update(name="World")
|
||||||
assert project.name == "World"
|
assert project.name == "World"
|
||||||
project.emit_notification.assert_any_call("project.updated", project.__json__())
|
project.emit_controller_notification.assert_any_call("project.updated", project.__json__())
|
||||||
|
|
||||||
|
|
||||||
async def test_update_on_compute(controller):
|
async def test_update_on_compute(controller):
|
||||||
@ -106,7 +110,9 @@ async def test_path(projects_dir):
|
|||||||
|
|
||||||
directory = projects_dir
|
directory = projects_dir
|
||||||
with patch("gns3server.utils.path.get_default_project_directory", return_value=directory):
|
with patch("gns3server.utils.path.get_default_project_directory", return_value=directory):
|
||||||
p = Project(project_id=str(uuid4()), name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification') as mock_notification:
|
||||||
|
p = Project(project_id=str(uuid4()), name="Test")
|
||||||
|
mock_notification.assert_called()
|
||||||
assert p.path == os.path.join(directory, p.id)
|
assert p.path == os.path.join(directory, p.id)
|
||||||
assert os.path.exists(os.path.join(directory, p.id))
|
assert os.path.exists(os.path.join(directory, p.id))
|
||||||
|
|
||||||
@ -124,23 +130,27 @@ def test_path_exist(tmpdir):
|
|||||||
|
|
||||||
async def test_init_path(tmpdir):
|
async def test_init_path(tmpdir):
|
||||||
|
|
||||||
p = Project(path=str(tmpdir), project_id=str(uuid4()), name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification') as mock_notification:
|
||||||
assert p.path == str(tmpdir)
|
p = Project(path=str(tmpdir), project_id=str(uuid4()), name="Test")
|
||||||
|
mock_notification.assert_called()
|
||||||
|
assert p.path == str(tmpdir)
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.skipif(sys.platform.startswith("win"), reason="Not supported on Windows")
|
@pytest.mark.skipif(sys.platform.startswith("win"), reason="Not supported on Windows")
|
||||||
async def test_changing_path_with_quote_not_allowed(tmpdir):
|
async def test_changing_path_with_quote_not_allowed(tmpdir):
|
||||||
|
|
||||||
with pytest.raises(aiohttp.web.HTTPForbidden):
|
with pytest.raises(aiohttp.web.HTTPForbidden):
|
||||||
p = Project(project_id=str(uuid4()), name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
p.path = str(tmpdir / "project\"53")
|
p = Project(project_id=str(uuid4()), name="Test")
|
||||||
|
p.path = str(tmpdir / "project\"53")
|
||||||
|
|
||||||
|
|
||||||
async def test_captures_directory(tmpdir):
|
async def test_captures_directory(tmpdir):
|
||||||
|
|
||||||
p = Project(path=str(tmpdir / "capturestest"), name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
assert p.captures_directory == str(tmpdir / "capturestest" / "project-files" / "captures")
|
p = Project(path=str(tmpdir / "capturestest"), name="Test")
|
||||||
assert os.path.exists(p.captures_directory)
|
assert p.captures_directory == str(tmpdir / "capturestest" / "project-files" / "captures")
|
||||||
|
assert os.path.exists(p.captures_directory)
|
||||||
|
|
||||||
|
|
||||||
async def test_add_node_local(controller):
|
async def test_add_node_local(controller):
|
||||||
@ -649,36 +659,39 @@ async def test_dump(projects_dir):
|
|||||||
|
|
||||||
directory = projects_dir
|
directory = projects_dir
|
||||||
with patch("gns3server.utils.path.get_default_project_directory", return_value=directory):
|
with patch("gns3server.utils.path.get_default_project_directory", return_value=directory):
|
||||||
p = Project(project_id='00010203-0405-0607-0809-0a0b0c0d0e0f', name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
p.dump()
|
p = Project(project_id='00010203-0405-0607-0809-0a0b0c0d0e0f', name="Test")
|
||||||
with open(os.path.join(directory, p.id, "Test.gns3")) as f:
|
p.dump()
|
||||||
content = f.read()
|
with open(os.path.join(directory, p.id, "Test.gns3")) as f:
|
||||||
assert "00010203-0405-0607-0809-0a0b0c0d0e0f" in content
|
content = f.read()
|
||||||
|
assert "00010203-0405-0607-0809-0a0b0c0d0e0f" in content
|
||||||
|
|
||||||
|
|
||||||
async def test_open_close(controller):
|
async def test_open_close(controller):
|
||||||
|
|
||||||
project = Project(controller=controller, name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
assert project.status == "opened"
|
project = Project(controller=controller, name="Test")
|
||||||
await project.close()
|
assert project.status == "opened"
|
||||||
project.start_all = AsyncioMagicMock()
|
await project.close()
|
||||||
await project.open()
|
project.start_all = AsyncioMagicMock()
|
||||||
assert not project.start_all.called
|
await project.open()
|
||||||
assert project.status == "opened"
|
assert not project.start_all.called
|
||||||
project.emit_notification = MagicMock()
|
assert project.status == "opened"
|
||||||
await project.close()
|
project.emit_controller_notification = MagicMock()
|
||||||
assert project.status == "closed"
|
await project.close()
|
||||||
project.emit_notification.assert_any_call("project.closed", project.__json__())
|
assert project.status == "closed"
|
||||||
|
project.emit_controller_notification.assert_any_call("project.closed", project.__json__())
|
||||||
|
|
||||||
|
|
||||||
async def test_open_auto_start(controller):
|
async def test_open_auto_start(controller):
|
||||||
|
|
||||||
project = Project(controller=controller, name="Test", auto_start=True)
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
assert project.status == "opened"
|
project = Project(controller=controller, name="Test", auto_start=True)
|
||||||
await project.close()
|
assert project.status == "opened"
|
||||||
project.start_all = AsyncioMagicMock()
|
await project.close()
|
||||||
await project.open()
|
project.start_all = AsyncioMagicMock()
|
||||||
assert project.start_all.called
|
await project.open()
|
||||||
|
assert project.start_all.called
|
||||||
|
|
||||||
|
|
||||||
def test_is_running(project, node):
|
def test_is_running(project, node):
|
||||||
|
@ -19,7 +19,7 @@ import json
|
|||||||
import uuid
|
import uuid
|
||||||
import pytest
|
import pytest
|
||||||
import aiohttp
|
import aiohttp
|
||||||
from unittest.mock import MagicMock
|
from unittest.mock import MagicMock, patch
|
||||||
from tests.utils import asyncio_patch
|
from tests.utils import asyncio_patch
|
||||||
|
|
||||||
from gns3server.controller.project import Project
|
from gns3server.controller.project import Project
|
||||||
@ -30,35 +30,36 @@ from gns3server.version import __version__
|
|||||||
|
|
||||||
async def test_project_to_topology_empty(tmpdir):
|
async def test_project_to_topology_empty(tmpdir):
|
||||||
|
|
||||||
project = Project(name="Test")
|
with patch('gns3server.controller.project.Project.emit_controller_notification'):
|
||||||
topo = project_to_topology(project)
|
project = Project(name="Test")
|
||||||
assert topo == {
|
topo = project_to_topology(project)
|
||||||
"project_id": project.id,
|
assert topo == {
|
||||||
"name": "Test",
|
"project_id": project.id,
|
||||||
"auto_start": False,
|
"name": "Test",
|
||||||
"auto_close": True,
|
"auto_start": False,
|
||||||
"auto_open": False,
|
"auto_close": True,
|
||||||
"scene_width": 2000,
|
"auto_open": False,
|
||||||
"scene_height": 1000,
|
"scene_width": 2000,
|
||||||
"revision": GNS3_FILE_FORMAT_REVISION,
|
"scene_height": 1000,
|
||||||
"zoom": 100,
|
"revision": GNS3_FILE_FORMAT_REVISION,
|
||||||
"show_grid": False,
|
"zoom": 100,
|
||||||
"show_interface_labels": False,
|
"show_grid": False,
|
||||||
"show_layers": False,
|
"show_interface_labels": False,
|
||||||
"snap_to_grid": False,
|
"show_layers": False,
|
||||||
"grid_size": 75,
|
"snap_to_grid": False,
|
||||||
"drawing_grid_size": 25,
|
"grid_size": 75,
|
||||||
"topology": {
|
"drawing_grid_size": 25,
|
||||||
"nodes": [],
|
"topology": {
|
||||||
"links": [],
|
"nodes": [],
|
||||||
"computes": [],
|
"links": [],
|
||||||
"drawings": []
|
"computes": [],
|
||||||
},
|
"drawings": []
|
||||||
"type": "topology",
|
},
|
||||||
"supplier": None,
|
"type": "topology",
|
||||||
"variables": None,
|
"supplier": None,
|
||||||
"version": __version__
|
"variables": None,
|
||||||
}
|
"version": __version__
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
async def test_basic_topology(controller):
|
async def test_basic_topology(controller):
|
||||||
|
@ -186,7 +186,9 @@ async def test_notification(controller_api, http_client, project, controller):
|
|||||||
assert b'"cpu_usage_percent"' in response.body
|
assert b'"cpu_usage_percent"' in response.body
|
||||||
assert b'{"action": "node.created", "event": {"a": "b"}}\n' in response.body
|
assert b'{"action": "node.created", "event": {"a": "b"}}\n' in response.body
|
||||||
assert project.status == "opened"
|
assert project.status == "opened"
|
||||||
|
controller.notification.project_emit("node.updated", {"a": "b"})
|
||||||
|
controller.notification.project_emit("node.deleted", {"a": "b"})
|
||||||
|
controller.notification.project_emit("snapshot.restored", {"a": "b"})
|
||||||
|
|
||||||
async def test_notification_invalid_id(controller_api):
|
async def test_notification_invalid_id(controller_api):
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user