mirror of
https://github.com/GNS3/gns3-server
synced 2025-01-23 06:20:59 +00:00
Merge remote-tracking branch 'origin/3.0' into gh-pages
This commit is contained in:
commit
93ba2a6913
5
.github/workflows/testing.yml
vendored
5
.github/workflows/testing.yml
vendored
@ -13,12 +13,11 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest]
|
python-version: ["3.6", "3.7", "3.8", "3.9", "3.10"]
|
||||||
python-version: [3.6, 3.7, 3.8, 3.9]
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
28
CHANGELOG
28
CHANGELOG
@ -1,5 +1,33 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
|
## 2.2.26 08/10/2021
|
||||||
|
|
||||||
|
* Release web UI 2.2.26
|
||||||
|
* Sort symbols by theme. Fixes https://github.com/GNS3/gns3-gui/issues/3230
|
||||||
|
* Fix memory percentage left warning. Fixes #1966
|
||||||
|
* Update affinity symbols. Fixes https://github.com/GNS3/gns3-gui/issues/3232
|
||||||
|
|
||||||
|
## 2.2.25 14/09/2021
|
||||||
|
|
||||||
|
* Release web UI 2.2.25
|
||||||
|
* Fix issue preventing to use custom nested symbols. Fixes #1969
|
||||||
|
* Updated affinity symbols
|
||||||
|
* Fix qemu-img rebase code to support Qemu 6.1. Ref https://github.com/GNS3/gns3-server/pull/1962
|
||||||
|
* Reinstate qemu-img rebase
|
||||||
|
* Return disk usage for partition that contains the default project directory. Fixes #1947
|
||||||
|
* Explicitly require setuptools, utils/get_resource.py imports pkg_resources
|
||||||
|
|
||||||
|
## 2.2.24 25/08/2021
|
||||||
|
|
||||||
|
* Release web UI 2.2.24
|
||||||
|
* Fix issue when searching for image with relative path. Fixes #1925
|
||||||
|
* Fix wrong error when NAT interface is not allowed. Fixes #1943
|
||||||
|
* Fix incorrect Qemu binary selected when importing template. Fixes https://github.com/GNS3/gns3-gui/issues/3216
|
||||||
|
* Fix error when updating a link style. Fixes https://github.com/GNS3/gns3-gui/issues/2461
|
||||||
|
* Some fixes for early support for Python3.10 The loop parameter has been removed from most of asyncio‘s high-level API following deprecation in Python 3.8.
|
||||||
|
* Early support for Python3.10 Fixes #1940
|
||||||
|
* Bump pywin32 from 300 to 301
|
||||||
|
|
||||||
## 2.2.23 05/08/2021
|
## 2.2.23 05/08/2021
|
||||||
|
|
||||||
* Release web UI 2.2.23
|
* Release web UI 2.2.23
|
||||||
|
@ -14,9 +14,8 @@ RUN set -eux \
|
|||||||
&& apk add --no-cache --virtual .build-deps build-base \
|
&& apk add --no-cache --virtual .build-deps build-base \
|
||||||
gcc libc-dev musl-dev linux-headers python3-dev \
|
gcc libc-dev musl-dev linux-headers python3-dev \
|
||||||
vpcs qemu libvirt ubridge \
|
vpcs qemu libvirt ubridge \
|
||||||
&& pip install --upgrade pip setuptools wheel \
|
&& pip install --no-cache-dir --upgrade pip setuptools wheel \
|
||||||
&& pip install -r /gns3server/requirements.txt \
|
&& pip install --no-cache-dir -r /gns3server/requirements.txt
|
||||||
&& rm -rf /root/.cache/pip
|
|
||||||
|
|
||||||
COPY . /gns3server
|
COPY . /gns3server
|
||||||
RUN python3 setup.py install
|
RUN python3 setup.py install
|
||||||
|
@ -32,6 +32,11 @@ In addition of Python dependencies listed in a section below, other software may
|
|||||||
* mtools is recommended to support data transfer to/from QEMU VMs using virtual disks.
|
* mtools is recommended to support data transfer to/from QEMU VMs using virtual disks.
|
||||||
* i386-libraries of libc and libcrypto are optional (Linux only), they are only needed to run IOU based nodes.
|
* i386-libraries of libc and libcrypto are optional (Linux only), they are only needed to run IOU based nodes.
|
||||||
|
|
||||||
|
Docker support
|
||||||
|
**************
|
||||||
|
|
||||||
|
Docker support needs the script program (`bsdutils` or `util-linux` package), when running a docker VM and a static busybox during installation (python3 setup.py install / pip3 install / package creation).
|
||||||
|
|
||||||
Branches
|
Branches
|
||||||
--------
|
--------
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ password = gns3
|
|||||||
; It cannot be changed once the server has started once
|
; It cannot be changed once the server has started once
|
||||||
default_admin_username = "admin"
|
default_admin_username = "admin"
|
||||||
|
|
||||||
; Initial default super admin username
|
; Initial default super admin password
|
||||||
; It cannot be changed once the server has started once
|
; It cannot be changed once the server has started once
|
||||||
default_admin_password = "admin"
|
default_admin_password = "admin"
|
||||||
|
|
||||||
|
@ -139,13 +139,6 @@ async def start_qemu_node(node: QemuVM = Depends(dep_node)) -> Response:
|
|||||||
Start a Qemu node.
|
Start a Qemu node.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
qemu_manager = Qemu.instance()
|
|
||||||
hardware_accel = qemu_manager.config.settings.Qemu.enable_hardware_acceleration
|
|
||||||
if hardware_accel and "-machine accel=tcg" not in node.options:
|
|
||||||
pm = ProjectManager.instance()
|
|
||||||
if pm.check_hardware_virtualization(node) is False:
|
|
||||||
pass # FIXME: check this
|
|
||||||
# raise ComputeError("Cannot start VM with hardware acceleration (KVM/HAX) enabled because hardware virtualization (VT-x/AMD-V) is already used by another software like VMware or VirtualBox")
|
|
||||||
await node.start()
|
await node.start()
|
||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ from . import projects
|
|||||||
from . import snapshots
|
from . import snapshots
|
||||||
from . import symbols
|
from . import symbols
|
||||||
from . import templates
|
from . import templates
|
||||||
|
from . import images
|
||||||
from . import users
|
from . import users
|
||||||
from . import groups
|
from . import groups
|
||||||
from . import roles
|
from . import roles
|
||||||
@ -61,9 +62,17 @@ router.include_router(
|
|||||||
tags=["Permissions"]
|
tags=["Permissions"]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
router.include_router(
|
||||||
|
images.router,
|
||||||
|
dependencies=[Depends(get_current_active_user)],
|
||||||
|
prefix="/images",
|
||||||
|
tags=["Images"]
|
||||||
|
)
|
||||||
|
|
||||||
router.include_router(
|
router.include_router(
|
||||||
templates.router,
|
templates.router,
|
||||||
dependencies=[Depends(get_current_active_user)],
|
dependencies=[Depends(get_current_active_user)],
|
||||||
|
prefix="/templates",
|
||||||
tags=["Templates"]
|
tags=["Templates"]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -18,22 +18,106 @@
|
|||||||
API routes for appliances.
|
API routes for appliances.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from fastapi import APIRouter
|
import logging
|
||||||
|
|
||||||
|
from fastapi import APIRouter, Depends, Response, status
|
||||||
from typing import Optional, List
|
from typing import Optional, List
|
||||||
|
from uuid import UUID
|
||||||
|
|
||||||
|
from gns3server import schemas
|
||||||
|
from gns3server.controller import Controller
|
||||||
|
from gns3server.controller.controller_error import (
|
||||||
|
ControllerError,
|
||||||
|
ControllerBadRequestError,
|
||||||
|
ControllerNotFoundError
|
||||||
|
)
|
||||||
|
|
||||||
|
from gns3server.db.repositories.images import ImagesRepository
|
||||||
|
from gns3server.db.repositories.templates import TemplatesRepository
|
||||||
|
from gns3server.db.repositories.rbac import RbacRepository
|
||||||
|
|
||||||
|
from .dependencies.authentication import get_current_active_user
|
||||||
|
from .dependencies.database import get_repository
|
||||||
|
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
router = APIRouter()
|
router = APIRouter()
|
||||||
|
|
||||||
|
|
||||||
@router.get("")
|
@router.get("")
|
||||||
async def get_appliances(update: Optional[bool] = False, symbol_theme: Optional[str] = "Classic") -> List[dict]:
|
async def get_appliances(
|
||||||
|
update: Optional[bool] = False,
|
||||||
|
symbol_theme: Optional[str] = "Classic"
|
||||||
|
) -> List[schemas.Appliance]:
|
||||||
"""
|
"""
|
||||||
Return all appliances known by the controller.
|
Return all appliances known by the controller.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from gns3server.controller import Controller
|
|
||||||
|
|
||||||
controller = Controller.instance()
|
controller = Controller.instance()
|
||||||
if update:
|
if update:
|
||||||
await controller.appliance_manager.download_appliances()
|
await controller.appliance_manager.download_appliances()
|
||||||
controller.appliance_manager.load_appliances(symbol_theme=symbol_theme)
|
controller.appliance_manager.load_appliances(symbol_theme=symbol_theme)
|
||||||
return [c.asdict() for c in controller.appliance_manager.appliances.values()]
|
return [c.asdict() for c in controller.appliance_manager.appliances.values()]
|
||||||
|
|
||||||
|
|
||||||
|
@router.get("/{appliance_id}")
|
||||||
|
def get_appliance(appliance_id: UUID) -> schemas.Appliance:
|
||||||
|
"""
|
||||||
|
Get an appliance file.
|
||||||
|
"""
|
||||||
|
|
||||||
|
controller = Controller.instance()
|
||||||
|
appliance = controller.appliance_manager.appliances.get(str(appliance_id))
|
||||||
|
if not appliance:
|
||||||
|
raise ControllerNotFoundError(message=f"Could not find appliance '{appliance_id}'")
|
||||||
|
return appliance.asdict()
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/{appliance_id}/version", status_code=status.HTTP_201_CREATED)
|
||||||
|
def add_appliance_version(appliance_id: UUID, appliance_version: schemas.ApplianceVersion) -> schemas.Appliance:
|
||||||
|
"""
|
||||||
|
Add a version to an appliance
|
||||||
|
"""
|
||||||
|
|
||||||
|
controller = Controller.instance()
|
||||||
|
appliance = controller.appliance_manager.appliances.get(str(appliance_id))
|
||||||
|
if not appliance:
|
||||||
|
raise ControllerNotFoundError(message=f"Could not find appliance '{appliance_id}'")
|
||||||
|
|
||||||
|
if not appliance.versions:
|
||||||
|
raise ControllerBadRequestError(message=f"Appliance '{appliance_id}' do not have versions")
|
||||||
|
|
||||||
|
if not appliance_version.images:
|
||||||
|
raise ControllerBadRequestError(message=f"Version '{appliance_version.name}' must contain images")
|
||||||
|
|
||||||
|
for version in appliance.versions:
|
||||||
|
if version.get("name") == appliance_version.name:
|
||||||
|
raise ControllerError(message=f"Appliance '{appliance_id}' already has version '{appliance_version.name}'")
|
||||||
|
|
||||||
|
appliance.versions.append(appliance_version.dict(exclude_unset=True))
|
||||||
|
return appliance.asdict()
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/{appliance_id}/install", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
async def install_appliance(
|
||||||
|
appliance_id: UUID,
|
||||||
|
version: Optional[str] = None,
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
|
current_user: schemas.User = Depends(get_current_active_user),
|
||||||
|
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository))
|
||||||
|
) -> Response:
|
||||||
|
"""
|
||||||
|
Install an appliance.
|
||||||
|
"""
|
||||||
|
|
||||||
|
controller = Controller.instance()
|
||||||
|
await controller.appliance_manager.install_appliance(
|
||||||
|
appliance_id,
|
||||||
|
version,
|
||||||
|
images_repo,
|
||||||
|
templates_repo,
|
||||||
|
rbac_repo,
|
||||||
|
current_user
|
||||||
|
)
|
||||||
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
@ -25,6 +25,7 @@ from typing import List
|
|||||||
|
|
||||||
from gns3server import schemas
|
from gns3server import schemas
|
||||||
from gns3server.controller.controller_error import (
|
from gns3server.controller.controller_error import (
|
||||||
|
ControllerError,
|
||||||
ControllerBadRequestError,
|
ControllerBadRequestError,
|
||||||
ControllerNotFoundError,
|
ControllerNotFoundError,
|
||||||
ControllerForbiddenError,
|
ControllerForbiddenError,
|
||||||
@ -126,7 +127,7 @@ async def delete_user_group(
|
|||||||
|
|
||||||
success = await users_repo.delete_user_group(user_group_id)
|
success = await users_repo.delete_user_group(user_group_id)
|
||||||
if not success:
|
if not success:
|
||||||
raise ControllerNotFoundError(f"User group '{user_group_id}' could not be deleted")
|
raise ControllerError(f"User group '{user_group_id}' could not be deleted")
|
||||||
|
|
||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
169
gns3server/api/routes/controller/images.py
Normal file
169
gns3server/api/routes/controller/images.py
Normal file
@ -0,0 +1,169 @@
|
|||||||
|
#
|
||||||
|
# Copyright (C) 2021 GNS3 Technologies Inc.
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
"""
|
||||||
|
API routes for images.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import logging
|
||||||
|
import urllib.parse
|
||||||
|
|
||||||
|
from fastapi import APIRouter, Request, Response, Depends, status
|
||||||
|
from sqlalchemy.orm.exc import MultipleResultsFound
|
||||||
|
from typing import List, Optional
|
||||||
|
from gns3server import schemas
|
||||||
|
|
||||||
|
from gns3server.utils.images import InvalidImageError, default_images_directory, write_image
|
||||||
|
from gns3server.db.repositories.images import ImagesRepository
|
||||||
|
from gns3server.db.repositories.templates import TemplatesRepository
|
||||||
|
from gns3server.db.repositories.rbac import RbacRepository
|
||||||
|
from gns3server.controller import Controller
|
||||||
|
from gns3server.controller.controller_error import (
|
||||||
|
ControllerError,
|
||||||
|
ControllerNotFoundError,
|
||||||
|
ControllerForbiddenError,
|
||||||
|
ControllerBadRequestError
|
||||||
|
)
|
||||||
|
|
||||||
|
from .dependencies.authentication import get_current_active_user
|
||||||
|
from .dependencies.database import get_repository
|
||||||
|
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
router = APIRouter()
|
||||||
|
|
||||||
|
|
||||||
|
@router.get("", response_model=List[schemas.Image])
|
||||||
|
async def get_images(
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
) -> List[schemas.Image]:
|
||||||
|
"""
|
||||||
|
Return all images.
|
||||||
|
"""
|
||||||
|
|
||||||
|
return await images_repo.get_images()
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/upload/{image_path:path}", response_model=schemas.Image, status_code=status.HTTP_201_CREATED)
|
||||||
|
async def upload_image(
|
||||||
|
image_path: str,
|
||||||
|
request: Request,
|
||||||
|
image_type: schemas.ImageType = schemas.ImageType.qemu,
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
|
current_user: schemas.User = Depends(get_current_active_user),
|
||||||
|
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository)),
|
||||||
|
install_appliances: Optional[bool] = True
|
||||||
|
) -> schemas.Image:
|
||||||
|
"""
|
||||||
|
Upload an image.
|
||||||
|
|
||||||
|
Example: curl -X POST http://host:port/v3/images/upload/my_image_name.qcow2?image_type=qemu \
|
||||||
|
-H 'Authorization: Bearer <token>' --data-binary @"/path/to/image.qcow2"
|
||||||
|
"""
|
||||||
|
|
||||||
|
image_path = urllib.parse.unquote(image_path)
|
||||||
|
image_dir, image_name = os.path.split(image_path)
|
||||||
|
directory = default_images_directory(image_type)
|
||||||
|
full_path = os.path.abspath(os.path.join(directory, image_dir, image_name))
|
||||||
|
if os.path.commonprefix([directory, full_path]) != directory:
|
||||||
|
raise ControllerForbiddenError(f"Cannot write image, '{image_path}' is forbidden")
|
||||||
|
|
||||||
|
if await images_repo.get_image(image_path):
|
||||||
|
raise ControllerBadRequestError(f"Image '{image_path}' already exists")
|
||||||
|
|
||||||
|
try:
|
||||||
|
image = await write_image(image_name, image_type, full_path, request.stream(), images_repo)
|
||||||
|
except (OSError, InvalidImageError) as e:
|
||||||
|
raise ControllerError(f"Could not save {image_type} image '{image_path}': {e}")
|
||||||
|
|
||||||
|
if install_appliances:
|
||||||
|
# attempt to automatically create templates based on image checksum
|
||||||
|
await Controller.instance().appliance_manager.install_appliances_from_image(
|
||||||
|
image_path,
|
||||||
|
image.checksum,
|
||||||
|
images_repo,
|
||||||
|
templates_repo,
|
||||||
|
rbac_repo,
|
||||||
|
current_user,
|
||||||
|
directory
|
||||||
|
)
|
||||||
|
|
||||||
|
return image
|
||||||
|
|
||||||
|
|
||||||
|
@router.get("/{image_path:path}", response_model=schemas.Image)
|
||||||
|
async def get_image(
|
||||||
|
image_path: str,
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
) -> schemas.Image:
|
||||||
|
"""
|
||||||
|
Return an image.
|
||||||
|
"""
|
||||||
|
|
||||||
|
image_path = urllib.parse.unquote(image_path)
|
||||||
|
image = await images_repo.get_image(image_path)
|
||||||
|
if not image:
|
||||||
|
raise ControllerNotFoundError(f"Image '{image_path}' not found")
|
||||||
|
return image
|
||||||
|
|
||||||
|
|
||||||
|
@router.delete("/{image_path:path}", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
async def delete_image(
|
||||||
|
image_path: str,
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
) -> None:
|
||||||
|
"""
|
||||||
|
Delete an image.
|
||||||
|
"""
|
||||||
|
|
||||||
|
image_path = urllib.parse.unquote(image_path)
|
||||||
|
|
||||||
|
try:
|
||||||
|
image = await images_repo.get_image(image_path)
|
||||||
|
except MultipleResultsFound:
|
||||||
|
raise ControllerBadRequestError(f"Image '{image_path}' matches multiple images. "
|
||||||
|
f"Please include the relative path of the image")
|
||||||
|
|
||||||
|
if not image:
|
||||||
|
raise ControllerNotFoundError(f"Image '{image_path}' not found")
|
||||||
|
|
||||||
|
templates = await images_repo.get_image_templates(image.image_id)
|
||||||
|
if templates:
|
||||||
|
template_names = ", ".join([template.name for template in templates])
|
||||||
|
raise ControllerError(f"Image '{image_path}' is used by one or more templates: {template_names}")
|
||||||
|
|
||||||
|
try:
|
||||||
|
os.remove(image.path)
|
||||||
|
except OSError:
|
||||||
|
log.warning(f"Could not delete image file {image.path}")
|
||||||
|
|
||||||
|
success = await images_repo.delete_image(image_path)
|
||||||
|
if not success:
|
||||||
|
raise ControllerError(f"Image '{image_path}' could not be deleted")
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/prune", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
async def prune_images(
|
||||||
|
images_repo: ImagesRepository = Depends(get_repository(ImagesRepository)),
|
||||||
|
) -> Response:
|
||||||
|
"""
|
||||||
|
Prune images not attached to any template.
|
||||||
|
"""
|
||||||
|
|
||||||
|
await images_repo.prune_images()
|
||||||
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
@ -260,6 +260,28 @@ async def reload_node(node: Node = Depends(dep_node)) -> Response:
|
|||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/{node_id}/isolate", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
async def isolate_node(node: Node = Depends(dep_node)) -> Response:
|
||||||
|
"""
|
||||||
|
Isolate a node (suspend all attached links).
|
||||||
|
"""
|
||||||
|
|
||||||
|
for link in node.links:
|
||||||
|
await link.update_suspend(True)
|
||||||
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
|
||||||
|
@router.post("/{node_id}/unisolate", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
async def unisolate_node(node: Node = Depends(dep_node)) -> Response:
|
||||||
|
"""
|
||||||
|
Un-isolate a node (resume all attached suspended links).
|
||||||
|
"""
|
||||||
|
|
||||||
|
for link in node.links:
|
||||||
|
await link.update_suspend(False)
|
||||||
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{node_id}/links", response_model=List[schemas.Link], response_model_exclude_unset=True)
|
@router.get("/{node_id}/links", response_model=List[schemas.Link], response_model_exclude_unset=True)
|
||||||
async def get_node_links(node: Node = Depends(dep_node)) -> List[schemas.Link]:
|
async def get_node_links(node: Node = Depends(dep_node)) -> List[schemas.Link]:
|
||||||
"""
|
"""
|
||||||
|
@ -36,6 +36,7 @@ from gns3server.controller.controller_error import (
|
|||||||
|
|
||||||
from gns3server.db.repositories.rbac import RbacRepository
|
from gns3server.db.repositories.rbac import RbacRepository
|
||||||
from .dependencies.database import get_repository
|
from .dependencies.database import get_repository
|
||||||
|
from .dependencies.authentication import get_current_active_user
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
@ -59,6 +60,7 @@ async def get_permissions(
|
|||||||
async def create_permission(
|
async def create_permission(
|
||||||
request: Request,
|
request: Request,
|
||||||
permission_create: schemas.PermissionCreate,
|
permission_create: schemas.PermissionCreate,
|
||||||
|
current_user: schemas.User = Depends(get_current_active_user),
|
||||||
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository))
|
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository))
|
||||||
) -> schemas.Permission:
|
) -> schemas.Permission:
|
||||||
"""
|
"""
|
||||||
@ -82,11 +84,16 @@ async def create_permission(
|
|||||||
|
|
||||||
# the permission can match multiple routes
|
# the permission can match multiple routes
|
||||||
if permission_create.path.endswith("/*"):
|
if permission_create.path.endswith("/*"):
|
||||||
route_path += r"/\*"
|
route_path += r"/.*"
|
||||||
|
|
||||||
if re.fullmatch(route_path, permission_create.path):
|
if re.fullmatch(route_path, permission_create.path):
|
||||||
for method in permission_create.methods:
|
for method in permission_create.methods:
|
||||||
if method in list(route.methods):
|
if method in list(route.methods):
|
||||||
|
# check user has the right to add the permission (i.e has already to right on the path)
|
||||||
|
if not await rbac_repo.check_user_is_authorized(current_user.user_id, method, permission_create.path):
|
||||||
|
raise ControllerForbiddenError(f"User '{current_user.username}' doesn't have the rights to "
|
||||||
|
f"add a permission on {method} {permission_create.path} or "
|
||||||
|
f"the endpoint doesn't exist")
|
||||||
return await rbac_repo.create_permission(permission_create)
|
return await rbac_repo.create_permission(permission_create)
|
||||||
|
|
||||||
raise ControllerBadRequestError(f"Permission '{permission_create.methods} {permission_create.path}' "
|
raise ControllerBadRequestError(f"Permission '{permission_create.methods} {permission_create.path}' "
|
||||||
|
@ -25,6 +25,7 @@ from typing import List
|
|||||||
|
|
||||||
from gns3server import schemas
|
from gns3server import schemas
|
||||||
from gns3server.controller.controller_error import (
|
from gns3server.controller.controller_error import (
|
||||||
|
ControllerError,
|
||||||
ControllerBadRequestError,
|
ControllerBadRequestError,
|
||||||
ControllerNotFoundError,
|
ControllerNotFoundError,
|
||||||
ControllerForbiddenError,
|
ControllerForbiddenError,
|
||||||
@ -119,7 +120,7 @@ async def delete_role(
|
|||||||
|
|
||||||
success = await rbac_repo.delete_role(role_id)
|
success = await rbac_repo.delete_role(role_id)
|
||||||
if not success:
|
if not success:
|
||||||
raise ControllerNotFoundError(f"Role '{role_id}' could not be deleted")
|
raise ControllerError(f"Role '{role_id}' could not be deleted")
|
||||||
|
|
||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
@ -25,14 +25,15 @@ import logging
|
|||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
from fastapi import APIRouter, Request, Response, HTTPException, Depends, Response, status
|
from fastapi import APIRouter, Request, HTTPException, Depends, Response, status
|
||||||
from typing import List
|
from typing import List, Optional
|
||||||
from uuid import UUID
|
from uuid import UUID
|
||||||
|
|
||||||
from gns3server import schemas
|
from gns3server import schemas
|
||||||
from gns3server.db.repositories.templates import TemplatesRepository
|
from gns3server.db.repositories.templates import TemplatesRepository
|
||||||
from gns3server.services.templates import TemplatesService
|
from gns3server.services.templates import TemplatesService
|
||||||
from gns3server.db.repositories.rbac import RbacRepository
|
from gns3server.db.repositories.rbac import RbacRepository
|
||||||
|
from gns3server.db.repositories.images import ImagesRepository
|
||||||
|
|
||||||
from .dependencies.authentication import get_current_active_user
|
from .dependencies.authentication import get_current_active_user
|
||||||
from .dependencies.database import get_repository
|
from .dependencies.database import get_repository
|
||||||
@ -42,7 +43,7 @@ responses = {404: {"model": schemas.ErrorMessage, "description": "Could not find
|
|||||||
router = APIRouter(responses=responses)
|
router = APIRouter(responses=responses)
|
||||||
|
|
||||||
|
|
||||||
@router.post("/templates", response_model=schemas.Template, status_code=status.HTTP_201_CREATED)
|
@router.post("", response_model=schemas.Template, status_code=status.HTTP_201_CREATED)
|
||||||
async def create_template(
|
async def create_template(
|
||||||
template_create: schemas.TemplateCreate,
|
template_create: schemas.TemplateCreate,
|
||||||
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
@ -59,7 +60,7 @@ async def create_template(
|
|||||||
return template
|
return template
|
||||||
|
|
||||||
|
|
||||||
@router.get("/templates/{template_id}", response_model=schemas.Template, response_model_exclude_unset=True)
|
@router.get("/{template_id}", response_model=schemas.Template, response_model_exclude_unset=True)
|
||||||
async def get_template(
|
async def get_template(
|
||||||
template_id: UUID,
|
template_id: UUID,
|
||||||
request: Request,
|
request: Request,
|
||||||
@ -81,7 +82,7 @@ async def get_template(
|
|||||||
return template
|
return template
|
||||||
|
|
||||||
|
|
||||||
@router.put("/templates/{template_id}", response_model=schemas.Template, response_model_exclude_unset=True)
|
@router.put("/{template_id}", response_model=schemas.Template, response_model_exclude_unset=True)
|
||||||
async def update_template(
|
async def update_template(
|
||||||
template_id: UUID,
|
template_id: UUID,
|
||||||
template_update: schemas.TemplateUpdate,
|
template_update: schemas.TemplateUpdate,
|
||||||
@ -94,13 +95,12 @@ async def update_template(
|
|||||||
return await TemplatesService(templates_repo).update_template(template_id, template_update)
|
return await TemplatesService(templates_repo).update_template(template_id, template_update)
|
||||||
|
|
||||||
|
|
||||||
@router.delete(
|
@router.delete("/{template_id}", status_code=status.HTTP_204_NO_CONTENT)
|
||||||
"/templates/{template_id}",
|
|
||||||
status_code=status.HTTP_204_NO_CONTENT,
|
|
||||||
)
|
|
||||||
async def delete_template(
|
async def delete_template(
|
||||||
template_id: UUID,
|
template_id: UUID,
|
||||||
|
prune_images: Optional[bool] = False,
|
||||||
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
|
images_repo: RbacRepository = Depends(get_repository(ImagesRepository)),
|
||||||
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository))
|
rbac_repo: RbacRepository = Depends(get_repository(RbacRepository))
|
||||||
) -> Response:
|
) -> Response:
|
||||||
"""
|
"""
|
||||||
@ -109,10 +109,12 @@ async def delete_template(
|
|||||||
|
|
||||||
await TemplatesService(templates_repo).delete_template(template_id)
|
await TemplatesService(templates_repo).delete_template(template_id)
|
||||||
await rbac_repo.delete_all_permissions_with_path(f"/templates/{template_id}")
|
await rbac_repo.delete_all_permissions_with_path(f"/templates/{template_id}")
|
||||||
|
if prune_images:
|
||||||
|
await images_repo.prune_images()
|
||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
|
||||||
@router.get("/templates", response_model=List[schemas.Template], response_model_exclude_unset=True)
|
@router.get("", response_model=List[schemas.Template], response_model_exclude_unset=True)
|
||||||
async def get_templates(
|
async def get_templates(
|
||||||
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
current_user: schemas.User = Depends(get_current_active_user),
|
current_user: schemas.User = Depends(get_current_active_user),
|
||||||
@ -139,7 +141,7 @@ async def get_templates(
|
|||||||
return user_templates
|
return user_templates
|
||||||
|
|
||||||
|
|
||||||
@router.post("/templates/{template_id}/duplicate", response_model=schemas.Template, status_code=status.HTTP_201_CREATED)
|
@router.post("/{template_id}/duplicate", response_model=schemas.Template, status_code=status.HTTP_201_CREATED)
|
||||||
async def duplicate_template(
|
async def duplicate_template(
|
||||||
template_id: UUID, templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
template_id: UUID, templates_repo: TemplatesRepository = Depends(get_repository(TemplatesRepository)),
|
||||||
current_user: schemas.User = Depends(get_current_active_user),
|
current_user: schemas.User = Depends(get_current_active_user),
|
||||||
|
@ -26,6 +26,7 @@ from typing import List
|
|||||||
|
|
||||||
from gns3server import schemas
|
from gns3server import schemas
|
||||||
from gns3server.controller.controller_error import (
|
from gns3server.controller.controller_error import (
|
||||||
|
ControllerError,
|
||||||
ControllerBadRequestError,
|
ControllerBadRequestError,
|
||||||
ControllerNotFoundError,
|
ControllerNotFoundError,
|
||||||
ControllerForbiddenError,
|
ControllerForbiddenError,
|
||||||
@ -74,7 +75,7 @@ async def authenticate(
|
|||||||
) -> schemas.Token:
|
) -> schemas.Token:
|
||||||
"""
|
"""
|
||||||
Alternative authentication method using json.
|
Alternative authentication method using json.
|
||||||
Example: curl http://host:port/v3/users/authenticate -d '{"username": "admin", "password": "admin"}'
|
Example: curl http://host:port/v3/users/authenticate -d '{"username": "admin", "password": "admin"} -H "Content-Type: application/json" '
|
||||||
"""
|
"""
|
||||||
|
|
||||||
user = await users_repo.authenticate_user(username=user_credentials.username, password=user_credentials.password)
|
user = await users_repo.authenticate_user(username=user_credentials.username, password=user_credentials.password)
|
||||||
@ -207,7 +208,7 @@ async def delete_user(
|
|||||||
|
|
||||||
success = await users_repo.delete_user(user_id)
|
success = await users_repo.delete_user(user_id)
|
||||||
if not success:
|
if not success:
|
||||||
raise ControllerNotFoundError(f"User '{user_id}' could not be deleted")
|
raise ControllerError(f"User '{user_id}' could not be deleted")
|
||||||
|
|
||||||
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
return Response(status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "bf0a4dd0-9e1f-491e-918a-1d1ac0e23161",
|
||||||
"name": "6WIND Turbo Router",
|
"name": "6WIND Turbo Router",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "6WIND Turbo Router is a high performance, ready-to-use software virtual router. It can be deployed bare metal or in virtual machines on commercial-off-the-shelf (COTS) servers. It is a carrier-grade solution for Service Prodivers aiming at using white boxes to deploy network functions. Typical use-cases are transit/peering router, IPsec VPN gateway and CGNAT.",
|
"description": "6WIND Turbo Router is a high performance, ready-to-use software virtual router. It can be deployed bare metal or in virtual machines on commercial-off-the-shelf (COTS) servers. It is a carrier-grade solution for Service Prodivers aiming at using white boxes to deploy network functions. Typical use-cases are transit/peering router, IPsec VPN gateway and CGNAT.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "c30ea423-b6f8-443e-b599-955ea5647ef0",
|
||||||
"name": "IP Cop",
|
"name": "IP Cop",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "The IPCop Firewall is a Linux firewall distribution. It is geared towards home and SOHO users. The IPCop web-interface is very user-friendly and makes usage easy.",
|
"description": "The IPCop Firewall is a Linux firewall distribution. It is geared towards home and SOHO users. The IPCop web-interface is very user-friendly and makes usage easy.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "2def5797-cb7d-429e-b85e-497ff4b81547",
|
||||||
"name": "ParrotOS",
|
"name": "ParrotOS",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": " Parrot is a GNU/Linux distribution based on Debian Testing and designed with Security, Development and Privacy in mind. It includes a full portable laboratory for security and digital forensics experts, but it also includes all you need to develop your own software or protect your privacy while surfing the net.",
|
"description": " Parrot is a GNU/Linux distribution based on Debian Testing and designed with Security, Development and Privacy in mind. It includes a full portable laboratory for security and digital forensics experts, but it also includes all you need to develop your own software or protect your privacy while surfing the net.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "7aa41b5b-3ae9-40a7-be38-5c109c59e086",
|
||||||
"name": "A10 vThunder",
|
"name": "A10 vThunder",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "vThunder, part of A10 Networks' award-winning A10 Thunder and AX Series Application Delivery Controller (ADC) family, is designed to meet the growing needs of organizations that require a flexible and easy-to-deploy application delivery and server load balancer solution running within a virtualized infrastructure.",
|
"description": "vThunder, part of A10 Networks' award-winning A10 Thunder and AX Series Application Delivery Controller (ADC) family, is designed to meet the growing needs of organizations that require a flexible and easy-to-deploy application delivery and server load balancer solution running within a virtualized infrastructure.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "99920801-829d-4689-8231-7183c21ff878",
|
||||||
"name": "AAA",
|
"name": "AAA",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "This appliance provides RADIUS and TACACS+ services with preconfigured users and groups.",
|
"description": "This appliance provides RADIUS and TACACS+ services with preconfigured users and groups.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "4d06be08-ce6d-4ee7-b5a7-79729fa75489",
|
||||||
"name": "Alcatel 7750",
|
"name": "Alcatel 7750",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The Alcatel-Lucent 7750 Service Router (SR) portfolio is a suite of multiservice edge routing platforms that deliver high performance, service richness, and creates exceptional value for networking in the cloud era. It is designed for the concurrent delivery of advanced residential, business and wireless broadband IP services, and provides cloud, data center and branch office connectivity for enterprise networking on a common IP edge routing platform.",
|
"description": "The Alcatel-Lucent 7750 Service Router (SR) portfolio is a suite of multiservice edge routing platforms that deliver high performance, service richness, and creates exceptional value for networking in the cloud era. It is designed for the concurrent delivery of advanced residential, business and wireless broadband IP services, and provides cloud, data center and branch office connectivity for enterprise networking on a common IP edge routing platform.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "fc520ae2-a4e5-48c3-9a13-516bb2e94668",
|
||||||
"name": "Alpine Linux",
|
"name": "Alpine Linux",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Alpine Linux is a security-oriented, lightweight Linux distribution based on musl libc and busybox.",
|
"description": "Alpine Linux is a security-oriented, lightweight Linux distribution based on musl libc and busybox.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "a7eec173-9680-4c1f-bf79-1bf29d485375",
|
||||||
"name": "cEOS",
|
"name": "cEOS",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "Arista cEOS\u2122 introduces the containerized packaging of EOS software and its agents for deployment in cloud infrastructure with the same proven EOS software image that runs on all Arista products. These flexible deployment options empower cloud network operators that are customizing their operating environments to provide a uniform workflow for development, testing and deployment of differentiated services.",
|
"description": "Arista cEOS\u2122 introduces the containerized packaging of EOS software and its agents for deployment in cloud infrastructure with the same proven EOS software image that runs on all Arista products. These flexible deployment options empower cloud network operators that are customizing their operating environments to provide a uniform workflow for development, testing and deployment of differentiated services.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "c90f3ff3-4ed2-4437-9afb-21232fa92015",
|
||||||
"name": "Arista vEOS",
|
"name": "Arista vEOS",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "Arista EOS\u00ae is the core of Arista cloud networking solutions for next-generation data centers and cloud networks. Cloud architectures built with Arista EOS scale to tens of thousands of compute and storage nodes with management and provisioning capabilities that work at scale. Through its programmability, EOS enables a set of software applications that deliver workflow automation, high availability, unprecedented network visibility and analytics and rapid integration with a wide range of third-party applications for virtualization, management, automation and orchestration services.\n\nArista Extensible Operating System (EOS) is a fully programmable and highly modular, Linux-based network operation system, using familiar industry standard CLI and runs a single binary software image across the Arista switching family. Architected for resiliency and programmability, EOS has a unique multi-process state sharing architecture that separates state information and packet forwarding from protocol processing and application logic.",
|
"description": "Arista EOS\u00ae is the core of Arista cloud networking solutions for next-generation data centers and cloud networks. Cloud architectures built with Arista EOS scale to tens of thousands of compute and storage nodes with management and provisioning capabilities that work at scale. Through its programmability, EOS enables a set of software applications that deliver workflow automation, high availability, unprecedented network visibility and analytics and rapid integration with a wide range of third-party applications for virtualization, management, automation and orchestration services.\n\nArista Extensible Operating System (EOS) is a fully programmable and highly modular, Linux-based network operation system, using familiar industry standard CLI and runs a single binary software image across the Arista switching family. Architected for resiliency and programmability, EOS has a unique multi-process state sharing architecture that separates state information and packet forwarding from protocol processing and application logic.",
|
||||||
@ -26,6 +27,13 @@
|
|||||||
"kvm": "require"
|
"kvm": "require"
|
||||||
},
|
},
|
||||||
"images": [
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "vEOS-lab-4.26.2F.vmdk",
|
||||||
|
"version": "4.26.2F",
|
||||||
|
"md5sum": "de8ce9750fddb63bd3f71bccfcd7651e",
|
||||||
|
"filesize": 475332608,
|
||||||
|
"download_url": "https://www.arista.com/en/support/software-download"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "vEOS-lab-4.25.3M.vmdk",
|
"filename": "vEOS-lab-4.25.3M.vmdk",
|
||||||
"version": "4.25.3M",
|
"version": "4.25.3M",
|
||||||
@ -210,6 +218,13 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versions": [
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "4.26.2F",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "Aboot-veos-serial-8.0.0.iso",
|
||||||
|
"hdb_disk_image": "vEOS-lab-4.26.2F.vmdk"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "4.25.3M",
|
"name": "4.25.3M",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "8f074218-9d61-4e99-ab89-35ca19ad44ee",
|
||||||
"name": "ArubaOS-CX Simulation Software",
|
"name": "ArubaOS-CX Simulation Software",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "The ArubaOS-CX Simulation Software is a virtual platform to enable simulation of the ArubaOS-CX Network Operating System. Simulated networks can be created using many of the protocols in the ArubaOS-CX Operating system like OSPF, BGP (inc. EVPN). Key features like the Aruba Network Analytics Engine and the REST API can be simulated, providing a lightweight development platform to building the modern network.",
|
"description": "The ArubaOS-CX Simulation Software is a virtual platform to enable simulation of the ArubaOS-CX Network Operating System. Simulated networks can be created using many of the protocols in the ArubaOS-CX Operating system like OSPF, BGP (inc. EVPN). Key features like the Aruba Network Analytics Engine and the REST API can be simulated, providing a lightweight development platform to building the modern network.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "38c9e478-4a1d-4611-ac61-945d2f2ca376",
|
||||||
"name": "Aruba VGW",
|
"name": "Aruba VGW",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Aruba Virtual Gateways allow customers to bring their public cloud infrastructure to the SD-WAN fabric and facilitate connectivity between branches and the public cloud.",
|
"description": "Aruba Virtual Gateways allow customers to bring their public cloud infrastructure to the SD-WAN fabric and facilitate connectivity between branches and the public cloud.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "a51fbf46-6350-4db2-8dbc-e90704ed60ef",
|
||||||
"name": "Aruba VMC",
|
"name": "Aruba VMC",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Aruba Virtual Mobility Controller",
|
"description": "Aruba Virtual Mobility Controller",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "b6319fe9-19d5-4a4d-a857-6eee3c92ca2d",
|
||||||
"name": "AsteriskNOW / FreePBX",
|
"name": "AsteriskNOW / FreePBX",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "AsteriskNOW makes it easy to create custom telephony solutions by automatically installing the 'plumbing'. It's a complete Linux distribution with Asterisk, the DAHDI driver framework, and, the FreePBX administrative GUI. Much of the complexity of Asterisk and Linux is handled by the installer, the yum package management utility and the administrative GUI. With AsteriskNOW, application developers and integrators can concentrate on building solutions, not maintaining the plumbing.",
|
"description": "AsteriskNOW makes it easy to create custom telephony solutions by automatically installing the 'plumbing'. It's a complete Linux distribution with Asterisk, the DAHDI driver framework, and, the FreePBX administrative GUI. Much of the complexity of Asterisk and Linux is handled by the installer, the yum package management utility and the administrative GUI. With AsteriskNOW, application developers and integrators can concentrate on building solutions, not maintaining the plumbing.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "8885febc-9067-4c2b-94e9-67090df0c21e",
|
||||||
"name": "Big Cloud Fabric",
|
"name": "Big Cloud Fabric",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Big Cloud Fabric\u2122 is the industry's first data center fabric built using whitebox or britebox switches and SDN controller technology. Embracing hyperscale data center design principles, Big Cloud Fabric solution enables rapid innovation, ease of provisioning and management, while reducing overall costs, making it ideal for current and next generation data centers. Big Cloud Fabric is designed from the ground up to satisfy the requirements of physical, virtual, containerized, or a combination of such workloads. Some of the typical OpenStack or VMware data center workloads include NFV, High Performance Computing, Big Data and Software Defined Storage deployments.",
|
"description": "Big Cloud Fabric\u2122 is the industry's first data center fabric built using whitebox or britebox switches and SDN controller technology. Embracing hyperscale data center design principles, Big Cloud Fabric solution enables rapid innovation, ease of provisioning and management, while reducing overall costs, making it ideal for current and next generation data centers. Big Cloud Fabric is designed from the ground up to satisfy the requirements of physical, virtual, containerized, or a combination of such workloads. Some of the typical OpenStack or VMware data center workloads include NFV, High Performance Computing, Big Data and Software Defined Storage deployments.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "088df570-f637-46f5-8a68-85acde538e5e",
|
||||||
"name": "BIRD",
|
"name": "BIRD",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The BIRD project aims to develop a fully functional dynamic IP routing daemon primarily targeted on (but not limited to) Linux, FreeBSD and other UNIX-like systems and distributed under the GNU General Public License.",
|
"description": "The BIRD project aims to develop a fully functional dynamic IP routing daemon primarily targeted on (but not limited to) Linux, FreeBSD and other UNIX-like systems and distributed under the GNU General Public License.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "5952eca3-fc06-4a57-a3b0-986237cb7de7",
|
||||||
"name": "Brocade Virtual ADX",
|
"name": "Brocade Virtual ADX",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "The Brocade Virtual ADX (vADX\u2122) is a full-fledged Application Delivery Controller (ADC) platform with a virtual footprint that leverages Intel advanced technology to deliver remarkable performance. The software is designed to run on standardsbased hypervisors, hosted on Intel x86 COTS hardware. It offers a complete suite of Layer 4 and Layer 7 server load balancing capabilities and application security services with extensible management via rich SOAP/XML APIs.",
|
"description": "The Brocade Virtual ADX (vADX\u2122) is a full-fledged Application Delivery Controller (ADC) platform with a virtual footprint that leverages Intel advanced technology to deliver remarkable performance. The software is designed to run on standardsbased hypervisors, hosted on Intel x86 COTS hardware. It offers a complete suite of Layer 4 and Layer 7 server load balancing capabilities and application security services with extensible management via rich SOAP/XML APIs.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "52a04aee-1046-4214-a364-18ecd776f7b3",
|
||||||
"name": "vRouter",
|
"name": "vRouter",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "With proven ultra-high performance and scalability, the Brocade vRouter is the networking industry leader in software innovation. The Brocade vRouter has set a the benchmark for all software-based routers, while offering easy scalability, a broad set of capabilities, and the peace of mind that comes with rock solid reliability.",
|
"description": "With proven ultra-high performance and scalability, the Brocade vRouter is the networking industry leader in software innovation. The Brocade vRouter has set a the benchmark for all software-based routers, while offering easy scalability, a broad set of capabilities, and the peace of mind that comes with rock solid reliability.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "cabd6cb2-1c70-4f90-b225-6601fea89cfc",
|
||||||
"name": "vTM DE",
|
"name": "vTM DE",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Take control of your online applications with Brocade virtual Traffic Manager (Developer Edition). Enhance customer experience, inspect traffic in real-time, control service levels to differentiate users and services, and reduce your costs with an extensible delivery platform that can grow with your business using ADC-as-a-Service. A fully functional Developer Edition which needs no license key, is limited to 1 Mbps/100 SSL tps throughput, and has access to the Brocade Community support web pages.",
|
"description": "Take control of your online applications with Brocade virtual Traffic Manager (Developer Edition). Enhance customer experience, inspect traffic in real-time, control service levels to differentiate users and services, and reduce your costs with an extensible delivery platform that can grow with your business using ADC-as-a-Service. A fully functional Developer Edition which needs no license key, is limited to 1 Mbps/100 SSL tps throughput, and has access to the Brocade Community support web pages.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "f28432b3-c5fe-48fa-b9e8-4024aa7cbe9e",
|
||||||
"name": "BSDRP",
|
"name": "BSDRP",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "BSD Router Project (BSDRP) is an embedded free and open source router distribution based on FreeBSD with Quagga and Bird.",
|
"description": "BSD Router Project (BSDRP) is an embedded free and open source router distribution based on FreeBSD with Quagga and Bird.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "f8186e9a-5145-4da0-ac18-b5b13cf57d3b",
|
||||||
"name": "CentOS Cloud Guest",
|
"name": "CentOS Cloud Guest",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "CentOS official image for self-hosted cloud",
|
"description": "CentOS official image for self-hosted cloud",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "b1e84913-1c9b-49f5-bf2e-45f2b42ba404",
|
||||||
"name": "Centos",
|
"name": "Centos",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "The CentOS Linux distribution is a stable, predictable, manageable and reproducible platform derived from the sources of Red Hat Enterprise Linux (RHEL). We are now looking to expand on that by creating the resources needed by other communities to come together and be able to build on the CentOS Linux platform. And today we start the process by delivering a clear governance model, increased transparency and access. In the coming weeks we aim to publish our own roadmap that includes variants of the core CentOS Linux.",
|
"description": "The CentOS Linux distribution is a stable, predictable, manageable and reproducible platform derived from the sources of Red Hat Enterprise Linux (RHEL). We are now looking to expand on that by creating the resources needed by other communities to come together and be able to build on the CentOS Linux platform. And today we start the process by delivering a clear governance model, increased transparency and access. In the coming weeks we aim to publish our own roadmap that includes variants of the core CentOS Linux.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "7bfa7a66-b1fa-4e5e-9b85-95d74440ee31",
|
||||||
"name": "Checkpoint GAiA",
|
"name": "Checkpoint GAiA",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Check Point Gaia is the next generation Secure Operating System for all Check Point Appliances, Open Servers and Virtualized Gateways.\n\nGaia combines the best features from IPSO and SecurePlatform (SPLAT) into a single unified OS providing greater efficiency and robust performance. By upgrading to Gaia, customers will benefit from improved appliance connection capacity and reduced operating costs. With Gaia, IP Appliance customers will gain the ability to leverage the full breadth and power of all Check Point Software Blades.\n\nGaia secures IPv6 networks utilizing the Check Point Acceleration & Clustering technology and it protects the most dynamic network and virtualized environments by supporting 5 different dynamic routing protocols. As a 64-Bit OS, Gaia increases the connection capacity of existing appliances supporting up-to 10M concurrent connections for select 2012 Models.\n\nGaia simplifies management with segregation of duties by enabling role-based administrative access. Furthermore, Gaia greatly increases operation efficiency by offering Automatic Software Update.\n\nThe feature-rich Web interface allows for search of any command or property in a second.\n\nGaia provides backward compatibility with IPSO and SPLAT CLI-style commands making it an easy transition for existing Check Point customers.",
|
"description": "Check Point Gaia is the next generation Secure Operating System for all Check Point Appliances, Open Servers and Virtualized Gateways.\n\nGaia combines the best features from IPSO and SecurePlatform (SPLAT) into a single unified OS providing greater efficiency and robust performance. By upgrading to Gaia, customers will benefit from improved appliance connection capacity and reduced operating costs. With Gaia, IP Appliance customers will gain the ability to leverage the full breadth and power of all Check Point Software Blades.\n\nGaia secures IPv6 networks utilizing the Check Point Acceleration & Clustering technology and it protects the most dynamic network and virtualized environments by supporting 5 different dynamic routing protocols. As a 64-Bit OS, Gaia increases the connection capacity of existing appliances supporting up-to 10M concurrent connections for select 2012 Models.\n\nGaia simplifies management with segregation of duties by enabling role-based administrative access. Furthermore, Gaia greatly increases operation efficiency by offering Automatic Software Update.\n\nThe feature-rich Web interface allows for search of any command or property in a second.\n\nGaia provides backward compatibility with IPSO and SPLAT CLI-style commands making it an easy transition for existing Check Point customers.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "c95b160b-4515-4cc9-81cc-92ac063dd250",
|
||||||
"name": "Chromium",
|
"name": "Chromium",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "The chromium browser",
|
"description": "The chromium browser",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "cc2b1802-3520-4963-8ff7-c19b1f6418c5",
|
||||||
"name": "Cisco 1700",
|
"name": "Cisco 1700",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 1700 Router",
|
"description": "Cisco 1700 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ed474fea-cd3b-4e2e-be84-a855a133060a",
|
||||||
"name": "Cisco 2600",
|
"name": "Cisco 2600",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 2600 Router",
|
"description": "Cisco 2600 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ed0f079e-a506-4cb4-b46c-714a80bbe2d3",
|
||||||
"name": "Cisco 2691",
|
"name": "Cisco 2691",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 2691 Router",
|
"description": "Cisco 2691 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "7ada6336-7280-4306-9f32-6b1e242ae989",
|
||||||
"name": "Cisco 3620",
|
"name": "Cisco 3620",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 3620 Router",
|
"description": "Cisco 3620 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ef119e49-19fe-4239-9c6b-16ea12f6ec01",
|
||||||
"name": "Cisco 3640",
|
"name": "Cisco 3640",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 3640 Router",
|
"description": "Cisco 3640 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ac460a9c-9274-4ccf-a056-af50b699925f",
|
||||||
"name": "Cisco 3660",
|
"name": "Cisco 3660",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 3660 Router",
|
"description": "Cisco 3660 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "5b9c5293-a5a7-47a3-9df4-6cf658f2f378",
|
||||||
"name": "Cisco 3725",
|
"name": "Cisco 3725",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 3725 Router",
|
"description": "Cisco 3725 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "18737edb-e43f-4fb0-8a0f-88982cff58b1",
|
||||||
"name": "Cisco 3745",
|
"name": "Cisco 3745",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 3745 Multiservice Access Router",
|
"description": "Cisco 3745 Multiservice Access Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "38aa3135-f169-4131-9b64-73605787b5ef",
|
||||||
"name": "Cisco 7200",
|
"name": "Cisco 7200",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco 7200 Router",
|
"description": "Cisco 7200 Router",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "fdbfc23e-413f-4b9f-b930-6cd27527d72b",
|
||||||
"name": "Cisco ASA",
|
"name": "Cisco ASA",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco ASA firewall",
|
"description": "Cisco ASA firewall",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "886c4059-4a10-4c62-ab59-7f02beeac292",
|
||||||
"name": "Cisco ASAv",
|
"name": "Cisco ASAv",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "The Adaptive Security Virtual Appliance is a virtualized network security solution based on the market-leading Cisco ASA 5500-X Series firewalls. It supports both traditional and next-generation software-defined network (SDN) and Cisco Application Centric Infrastructure (ACI) environments to provide policy enforcement and threat inspection across heterogeneous multisite environments.",
|
"description": "The Adaptive Security Virtual Appliance is a virtualized network security solution based on the market-leading Cisco ASA 5500-X Series firewalls. It supports both traditional and next-generation software-defined network (SDN) and Cisco Application Centric Infrastructure (ACI) environments to provide policy enforcement and threat inspection across heterogeneous multisite environments.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "d223e573-8de5-4f93-b26d-d5d1f2f18226",
|
||||||
"name": "Cisco Catalyst 8000V",
|
"name": "Cisco Catalyst 8000V",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The Cisco Catalyst 8000V Edge Software is a virtual, form-factor router deployed on a virtual machine (VM) running on an x86 server hardware.",
|
"description": "The Cisco Catalyst 8000V Edge Software is a virtual, form-factor router deployed on a virtual machine (VM) running on an x86 server hardware.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "95d17663-f40a-437f-b5f1-dab4779965de",
|
||||||
"name": "Cisco CSR1000v",
|
"name": "Cisco CSR1000v",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The Cisco Cloud Services Router 1000V (CSR 1000V) is a router and network services platform in virtual form factor that is intended for deployment in cloud and virtual data centers. It is optimized to serve as a single-tenant or multitenant WAN gateway. Using proven, industry-leading Cisco IOS\u00ae XE Software networking and security features, the CSR 1000V enables enterprises to transparently extend their WANs into external provider-hosted clouds and cloud providers to offer their tenants enterprise-class networking services.",
|
"description": "The Cisco Cloud Services Router 1000V (CSR 1000V) is a router and network services platform in virtual form factor that is intended for deployment in cloud and virtual data centers. It is optimized to serve as a single-tenant or multitenant WAN gateway. Using proven, industry-leading Cisco IOS\u00ae XE Software networking and security features, the CSR 1000V enables enterprises to transparently extend their WANs into external provider-hosted clouds and cloud providers to offer their tenants enterprise-class networking services.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ae09653b-c8eb-4ecd-9341-2d0319e16b9b",
|
||||||
"name": "Cisco DCNM",
|
"name": "Cisco DCNM",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Cisco Data Center Network Manager (DCNM) 10 unifies and automates Cisco Nexus and Cisco MDS 9000 Family multitenant infrastructure for data center management across Cisco Nexus 5000, 6000, 7000, and 9000 Series Switches in NX-OS mode using Cisco NX-OS Software as well as across Cisco MDS 9100 and 9300 Series Multilayer Fabric Switches, 9200 Series Multiservice Switches, and 9500 and 9700 Series Multilayer Directors. Data Center Network Manager 10 lets you manage very large numbers of devices while providing ready-to-use management and automation capabilities plus Virtual Extensible LAN (VXLAN) overlay visibility into Cisco Nexus LAN fabrics.",
|
"description": "Cisco Data Center Network Manager (DCNM) 10 unifies and automates Cisco Nexus and Cisco MDS 9000 Family multitenant infrastructure for data center management across Cisco Nexus 5000, 6000, 7000, and 9000 Series Switches in NX-OS mode using Cisco NX-OS Software as well as across Cisco MDS 9100 and 9300 Series Multilayer Fabric Switches, 9200 Series Multiservice Switches, and 9500 and 9700 Series Multilayer Directors. Data Center Network Manager 10 lets you manage very large numbers of devices while providing ready-to-use management and automation capabilities plus Virtual Extensible LAN (VXLAN) overlay visibility into Cisco Nexus LAN fabrics.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "e36183b5-5960-4bcf-bdb9-ca258c28b3e5",
|
||||||
"name": "Cisco Flow Collector for NetFlow",
|
"name": "Cisco Flow Collector for NetFlow",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nAt the heart of the Stealthwatch System is the highly scalable Stealthwatch Flow Collector. The Flow Collector is available as either a physical or a virtual appliance. The Flow Collector VE performs the same functions as its physical counterpart, but in a virtual environment. The Stealthwatch Flow Collector for NetFlow gathers NetFlow, cFlow, J-Flow, Packeteer 2, NetStream, and IPFIX data. To achieve full network visibility with a traditional probe-based approach, you would need to install a probe for each router or switch on your network. This results in many costly hardware installations. Conversely, Stealthwatch's flow-based approach provides you with full network visibility at a fraction of the cost. Each Flow Collector can process data for as many as 1,000,000 hosts from up to 2,000 flow exporters, depending on the Flow Collector model and license restrictions. ",
|
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nAt the heart of the Stealthwatch System is the highly scalable Stealthwatch Flow Collector. The Flow Collector is available as either a physical or a virtual appliance. The Flow Collector VE performs the same functions as its physical counterpart, but in a virtual environment. The Stealthwatch Flow Collector for NetFlow gathers NetFlow, cFlow, J-Flow, Packeteer 2, NetStream, and IPFIX data. To achieve full network visibility with a traditional probe-based approach, you would need to install a probe for each router or switch on your network. This results in many costly hardware installations. Conversely, Stealthwatch's flow-based approach provides you with full network visibility at a fraction of the cost. Each Flow Collector can process data for as many as 1,000,000 hosts from up to 2,000 flow exporters, depending on the Flow Collector model and license restrictions. ",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "1e409568-f8d6-4f94-8804-53039eb7784a",
|
||||||
"name": "Cisco FMCv",
|
"name": "Cisco FMCv",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "This is your administrative nerve center for managing critical Cisco network security solutions. It provides complete and unified management over firewalls, application control, intrusion prevention, URL filtering, and advanced malware protection. Easily go from managing a firewall to controlling applications to investigating and remediating malware outbreaks.",
|
"description": "This is your administrative nerve center for managing critical Cisco network security solutions. It provides complete and unified management over firewalls, application control, intrusion prevention, URL filtering, and advanced malware protection. Easily go from managing a firewall to controlling applications to investigating and remediating malware outbreaks.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "709c2a9b-5dc3-4362-b147-fb848a0df963",
|
||||||
"name": "Cisco Flow Sensor",
|
"name": "Cisco Flow Sensor",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nUsing the same technology as the Stealthwatch Flow Sensor appliance, the Flow Sensor VE is a virtual appliance that provides visibility into virtual environments, generating flow data for areas that are not flow-enabled. ",
|
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nUsing the same technology as the Stealthwatch Flow Sensor appliance, the Flow Sensor VE is a virtual appliance that provides visibility into virtual environments, generating flow data for areas that are not flow-enabled. ",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "adce6f0c-10ae-4f4d-9e00-da833f419eae",
|
||||||
"name": "Cisco FTDv",
|
"name": "Cisco FTDv",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco Firepower Threat Defense Virtual NGFW appliances combine Cisco's proven network firewall with the industry's most effective next-gen IPS and advanced malware protection. All so you can get more visibility, be more flexible, save more, and protect better.",
|
"description": "Cisco Firepower Threat Defense Virtual NGFW appliances combine Cisco's proven network firewall with the industry's most effective next-gen IPS and advanced malware protection. All so you can get more visibility, be more flexible, save more, and protect better.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "3bf492b6-5717-4257-9bfd-b34617c6f133",
|
||||||
"name": "Cisco IOSv",
|
"name": "Cisco IOSv",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco Virtual IOS allows user to run IOS on a standard computer.",
|
"description": "Cisco Virtual IOS allows user to run IOS on a standard computer.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "4368f802-ddec-4863-adbd-a36a6d83cd4c",
|
||||||
"name": "Cisco IOSvL2",
|
"name": "Cisco IOSvL2",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "Cisco Virtual IOS L2 allows user to run a IOS switching image on a standard computer.",
|
"description": "Cisco Virtual IOS L2 allows user to run a IOS switching image on a standard computer.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "78fc5177-c399-4369-a6f8-e9c9b217c2e2",
|
||||||
"name": "Cisco IOS XRv",
|
"name": "Cisco IOS XRv",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "IOS XRv supports the control plane features introduced in Cisco IOS XR.",
|
"description": "IOS XRv supports the control plane features introduced in Cisco IOS XR.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ea678b10-fc52-4079-83de-36769fbd9bc3",
|
||||||
"name": "Cisco IOS XRv 9000",
|
"name": "Cisco IOS XRv 9000",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "IOS XRv 9000 (aka Sunstone) is the 1st VM released running the 64-bit IOS XR operating system as used on the NCS-6xxx platform. This appliance requires 4 vCPUs and 16GB of memory to run!",
|
"description": "IOS XRv 9000 (aka Sunstone) is the 1st VM released running the 64-bit IOS XR operating system as used on the NCS-6xxx platform. This appliance requires 4 vCPUs and 16GB of memory to run!",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "9593db48-558a-4914-bb78-a20605f39c65",
|
||||||
"name": "Cisco IOU L2",
|
"name": "Cisco IOU L2",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "Cisco IOS on UNIX Layer 2 image.",
|
"description": "Cisco IOS on UNIX Layer 2 image.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "87bf6f58-1e5a-4ee2-afe7-715dabffcf18",
|
||||||
"name": "Cisco IOU L3",
|
"name": "Cisco IOU L3",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Cisco IOS on UNIX Layer 3 image.",
|
"description": "Cisco IOS on UNIX Layer 3 image.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "cf5d1f22-953a-434d-a07e-6e17de85acf1",
|
||||||
"name": "Cisco ISE",
|
"name": "Cisco ISE",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "The Cisco ISE platform is a comprehensive, next-generation, contextually-based access control solution. Cisco ISE offers authenticated network access, profiling, posture, guest management, and security group access services along with monitoring, reporting, and troubleshooting capabilities on a single physical or virtual appliance.",
|
"description": "The Cisco ISE platform is a comprehensive, next-generation, contextually-based access control solution. Cisco ISE offers authenticated network access, profiling, posture, guest management, and security group access services along with monitoring, reporting, and troubleshooting capabilities on a single physical or virtual appliance.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "587dd8e4-0c73-465d-bfdc-5cd7ab67029b",
|
||||||
"name": "Cisco NGIPSv",
|
"name": "Cisco NGIPSv",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco Firepower Next-Generation IPS (NGIPS) threat appliances combine superior visibility, embedded security intelligence, automated analysis, and industry-leading threat effectiveness.",
|
"description": "Cisco Firepower Next-Generation IPS (NGIPS) threat appliances combine superior visibility, embedded security intelligence, automated analysis, and industry-leading threat effectiveness.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "6260ec1e-8ab0-40c6-9e35-fbcc88ce935e",
|
||||||
"name": "Cisco NX-OSv",
|
"name": "Cisco NX-OSv",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "NXOSv is a reference platform for an implementation of the Cisco Nexus operating system, based on the Nexus 7000-series platforms, running as a full virtual machine on a hypervisor. This includes NXAPI and MPLS LDP support.",
|
"description": "NXOSv is a reference platform for an implementation of the Cisco Nexus operating system, based on the Nexus 7000-series platforms, running as a full virtual machine on a hypervisor. This includes NXAPI and MPLS LDP support.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "f739d949-136b-4a56-8b0f-d39832e5aa30",
|
||||||
"name": "Cisco NX-OSv 9000",
|
"name": "Cisco NX-OSv 9000",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "The NX-OSv 9000 is a virtual platform that is designed to simulate the control plane aspects of a network element running Cisco Nexus 9000 software. The NX-OSv 9000 shares the same software image running on Cisco Nexus 9000 hardware platform although no specific hardware emulation is implemented. When the software runs as a virtual machine, line card (LC) ASIC provisioning or any interaction from the control plane to hardware ASIC is handled by the NX-OSv 9000 software data plane.\nThe NX-OSv 9000 for the Cisco Nexus 9000 Series provides a useful tool to enable the devops model and rapidly test changes to the infrastructure or to infrastructure automation tools. This enables network simulations in large scale for customers to validate configuration changes on a simulated network prior to applying them on a production network. Some users have also expressed interest in using the simulation system for feature test ,verification, and automation tooling development and test simualtion prior to deployment. NX-OSv 9000 can be used as a programmability vehicle to validate software defined networks (SDNs) and Network Function Virtualization (NFV) based solutions.",
|
"description": "The NX-OSv 9000 is a virtual platform that is designed to simulate the control plane aspects of a network element running Cisco Nexus 9000 software. The NX-OSv 9000 shares the same software image running on Cisco Nexus 9000 hardware platform although no specific hardware emulation is implemented. When the software runs as a virtual machine, line card (LC) ASIC provisioning or any interaction from the control plane to hardware ASIC is handled by the NX-OSv 9000 software data plane.\nThe NX-OSv 9000 for the Cisco Nexus 9000 Series provides a useful tool to enable the devops model and rapidly test changes to the infrastructure or to infrastructure automation tools. This enables network simulations in large scale for customers to validate configuration changes on a simulated network prior to applying them on a production network. Some users have also expressed interest in using the simulation system for feature test ,verification, and automation tooling development and test simualtion prior to deployment. NX-OSv 9000 can be used as a programmability vehicle to validate software defined networks (SDNs) and Network Function Virtualization (NFV) based solutions.",
|
||||||
@ -81,6 +82,13 @@
|
|||||||
"filesize": 1330315264,
|
"filesize": 1330315264,
|
||||||
"download_url": "https://software.cisco.com/download/home/286312239/type/282088129/release/9.2%25281%2529"
|
"download_url": "https://software.cisco.com/download/home/286312239/type/282088129/release/9.2%25281%2529"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"filename": "nxosv-final.7.0.3.I7.9.qcow2",
|
||||||
|
"version": "7.0.3.I7.9",
|
||||||
|
"md5sum": "50678c719f6b822c43dd096dbdf359e8",
|
||||||
|
"filesize": 1003618304,
|
||||||
|
"download_url": "https://software.cisco.com/download/home/286312239/type/282088129/release/7.0(3)I7(9)?i=!pp"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"filename": "nxosv-final.7.0.3.I7.7.qcow2",
|
"filename": "nxosv-final.7.0.3.I7.7.qcow2",
|
||||||
"version": "7.0.3.I7.7",
|
"version": "7.0.3.I7.7",
|
||||||
@ -218,6 +226,13 @@
|
|||||||
"hda_disk_image": "nxosv-final.9.2.1.qcow2"
|
"hda_disk_image": "nxosv-final.9.2.1.qcow2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "7.0.3.I7.9",
|
||||||
|
"images": {
|
||||||
|
"bios_image": "OVMF-20160813.fd",
|
||||||
|
"hda_disk_image": "nxosv-final.7.0.3.I7.9.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "7.0.3.I7.7",
|
"name": "7.0.3.I7.7",
|
||||||
"images": {
|
"images": {
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "903bbc99-6c4a-4bc7-b9b1-eb5f2e3c5470",
|
||||||
"name": "Cisco Stealthwatch Management Console",
|
"name": "Cisco Stealthwatch Management Console",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nAs the control center for the Stealthwatch System, the SMC manages, coordinates, configures, and organizes all of the different components of the system. The SMC client software allows you to access the SMC's user-friendly graphical user interface from any local computer with access to a Web browser. Through the client interface, you can easily access real-time security and network information about critical segments throughout your enterprise. ",
|
"description": "Cisco Stealthwatch is the most comprehensive visibility and network traffic security analytics solution that uses enterprise telemetry from the existing network infrastructure. It provides advanced threat detection, accelerated threat response, and simplified network segmentation using multilayer machine learning and entity modeling. With advanced behavioral analytics, you'll always know who is on your network and what they are doing.\n\nAs the control center for the Stealthwatch System, the SMC manages, coordinates, configures, and organizes all of the different components of the system. The SMC client software allows you to access the SMC's user-friendly graphical user interface from any local computer with access to a Web browser. Through the client interface, you can easily access real-time security and network information about critical segments throughout your enterprise. ",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "e632ff43-fc14-41f8-a293-b6a62f0e1788",
|
||||||
"name": "Cisco vWLC",
|
"name": "Cisco vWLC",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "The Virtual Wireless Controller can cost-effectively manage, secure, and optimize the performance of local and branch wireless networks. Ideal for small and medium-sized businesses, the Virtual Wireless Controller facilitates server consolidation and improves business continuity in the face of outages.",
|
"description": "The Virtual Wireless Controller can cost-effectively manage, secure, and optimize the performance of local and branch wireless networks. Ideal for small and medium-sized businesses, the Virtual Wireless Controller facilitates server consolidation and improves business continuity in the face of outages.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "a9dc537f-3093-42c2-95d9-fca800e59f82",
|
||||||
"name": "Web Security Virtual Appliance",
|
"name": "Web Security Virtual Appliance",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "The Cisco WSA was one of the first secure web gateways to combine leading protections to help organizations address the growing challenges of securing and controlling web traffic. It enables simpler, faster deployment with fewer maintenance requirements, reduced latency, and lower operating costs. \"Set and forget\" technology frees staff after initial automated policy settings go live, and automatic security updates are pushed to network devices every 3 to 5 minutes. Flexible deployment options and integration with your existing security infrastructure help you meet quickly evolving security requirements.",
|
"description": "The Cisco WSA was one of the first secure web gateways to combine leading protections to help organizations address the growing challenges of securing and controlling web traffic. It enables simpler, faster deployment with fewer maintenance requirements, reduced latency, and lower operating costs. \"Set and forget\" technology frees staff after initial automated policy settings go live, and automatic security updates are pushed to network devices every 3 to 5 minutes. Flexible deployment options and integration with your existing security infrastructure help you meet quickly evolving security requirements.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "a013860f-c65d-477d-abfc-d3d98b49e7d6",
|
||||||
"name": "NetScaler VPX",
|
"name": "NetScaler VPX",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Today's enterprises face more demands than ever, from cloud computing to 24/7 availability to increasing security threats. NetScaler ADC, an advanced software-defined application delivery controller, is your networking power player. It provides outstanding delivery of business applications-to any device and any location-with unmatched security, superior L4-7 load balancing, reliable GSLB, and 100 percent uptime. In fact, NetScaler ADC offers up to five times the performance of our closest competitor. Plus our TriScale technology saves you money by allowing your network to scale up or down without additional hardware costs.",
|
"description": "Today's enterprises face more demands than ever, from cloud computing to 24/7 availability to increasing security threats. NetScaler ADC, an advanced software-defined application delivery controller, is your networking power player. It provides outstanding delivery of business applications-to any device and any location-with unmatched security, superior L4-7 load balancing, reliable GSLB, and 100 percent uptime. In fact, NetScaler ADC offers up to five times the performance of our closest competitor. Plus our TriScale technology saves you money by allowing your network to scale up or down without additional hardware costs.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "c731e7d0-5893-4072-a681-998df576a67c",
|
||||||
"name": "ClearOS CE",
|
"name": "ClearOS CE",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "ClearOS is an operating system for your Server, Network, and Gateway systems. It is designed for homes, small to medium businesses, and distributed environments. ClearOS is commonly known as the Next Generation Small Business Server, while including indispensable Gateway and Networking functionality. It delivers a powerful IT solution with an elegant user interface that is completely web-based. Simply put.. ClearOS is the new way of delivering IT.",
|
"description": "ClearOS is an operating system for your Server, Network, and Gateway systems. It is designed for homes, small to medium businesses, and distributed environments. ClearOS is commonly known as the Next Generation Small Business Server, while including indispensable Gateway and Networking functionality. It delivers a powerful IT solution with an elegant user interface that is completely web-based. Simply put.. ClearOS is the new way of delivering IT.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "e5563056-f6dc-4b51-bcff-8b566ae8b0a7",
|
||||||
"name": "CloudRouter",
|
"name": "CloudRouter",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The CloudRouter Project is a collaborative open source project focused on developing a powerful, easy to use router designed for the cloud.\nCompute resources are rapidly migrating from physical infrastructure to a combination of physical, virtual and cloud environments. A similar transition is emerging in the networking space, with network control logic shifting from proprietary hardware-based platforms to open source software-based platforms. CloudRouter is a software-based router distribution designed to run on physical, virtual and cloud environments, supporting software-defined networking infrastructure. It includes the features of traditional hardware routers, as well as support for emerging technologies such as containers and software-defined interconnection. CloudRouter aims to facilitate migration to the cloud without giving up control over network routing and governance.",
|
"description": "The CloudRouter Project is a collaborative open source project focused on developing a powerful, easy to use router designed for the cloud.\nCompute resources are rapidly migrating from physical infrastructure to a combination of physical, virtual and cloud environments. A similar transition is emerging in the networking space, with network control logic shifting from proprietary hardware-based platforms to open source software-based platforms. CloudRouter is a software-based router distribution designed to run on physical, virtual and cloud environments, supporting software-defined networking infrastructure. It includes the features of traditional hardware routers, as well as support for emerging technologies such as containers and software-defined interconnection. CloudRouter aims to facilitate migration to the cloud without giving up control over network routing and governance.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "5a03e6b9-afe3-44f5-ae35-5664c0250b94",
|
||||||
"name": "CoreOS",
|
"name": "CoreOS",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "CoreOS is designed for security, consistency, and reliability. Instead of installing packages via yum or apt, CoreOS uses Linux containers to manage your services at a higher level of abstraction. A single service's code and all dependencies are packaged within a container that can be run on one or many CoreOS machines.",
|
"description": "CoreOS is designed for security, consistency, and reliability. Instead of installing packages via yum or apt, CoreOS uses Linux containers to manage your services at a higher level of abstraction. A single service's code and all dependencies are packaged within a container that can be run on one or many CoreOS machines.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "f1b83421-6c20-4fa7-8292-568fe08874c4",
|
||||||
"name": "Cumulus VX",
|
"name": "Cumulus VX",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "Cumulus VX is a community-supported virtual appliance that enables cloud admins and network engineers to preview and test Cumulus Networks technology at zero cost. You can build sandbox environments to learn Open Networking concepts, prototype network operations and script & develop applications risk-free. With Cumulus VX, you can get started with Open Networking at your pace, on your time, and in your environment!",
|
"description": "Cumulus VX is a community-supported virtual appliance that enables cloud admins and network engineers to preview and test Cumulus Networks technology at zero cost. You can build sandbox environments to learn Open Networking concepts, prototype network operations and script & develop applications risk-free. With Cumulus VX, you can get started with Open Networking at your pace, on your time, and in your environment!",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "ccbd2d81-c588-4bbb-80ac-ba20686b613a",
|
||||||
"name": "DANOS",
|
"name": "DANOS",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The Disaggregated Network Operating System (DANOS) project enables community collaboration across network hardware, forwarding, and operating system layers. DANOS is initially based on AT&T's \"dNOS\" software framework of a more open, cost-effective and flexible alternative to traditional networking equipment. As part of The Linux Foundation, it now incorporates contributions from complementary open source communities in building a standardized distributed Network Operating System (NOS) to speed the adoption and use of white boxes in a service provider's infrastructure.",
|
"description": "The Disaggregated Network Operating System (DANOS) project enables community collaboration across network hardware, forwarding, and operating system layers. DANOS is initially based on AT&T's \"dNOS\" software framework of a more open, cost-effective and flexible alternative to traditional networking equipment. As part of The Linux Foundation, it now incorporates contributions from complementary open source communities in building a standardized distributed Network Operating System (NOS) to speed the adoption and use of white boxes in a service provider's infrastructure.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "8f8df56b-605d-447c-94a4-4848e3ae8392",
|
||||||
"name": "Debian 10 Minimal",
|
"name": "Debian 10 Minimal",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Debian 10 Custom, with automatic disk resize and ssh/nmap",
|
"description": "Debian 10 Custom, with automatic disk resize and ssh/nmap",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "518a5802-266a-4299-b84b-e6cccb5a39ac",
|
||||||
"name": "DEFT Linux",
|
"name": "DEFT Linux",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "DEFT (acronym for Digital Evidence & Forensics Toolkit) is a distribution made for Computer Forensics, with the purpose of running live on systems without tampering or corrupting devices (hard disks, pendrives, etc...) connected to the PC where the boot process takes place.\nThe DEFT system is based on GNU Linux, it can run live (via DVDROM or USB pendrive), installed or run as a Virtual Appliance on VMware or Virtualbox. DEFT employs LXDE as desktop environment and WINE for executing Windows tools under Linux. It features a comfortable mount manager for device management.\nDEFT is paired with DART (acronym for Digital Advanced Response Toolkit), a Forensics System which can be run on Windows and contains the best tools for Forensics and Incident Response. DART features a GUI with logging and integrity check for the instruments here contained.\nBesides all this, the DEFT staff is devoted to implementing and developing applications which are released to Law Enforcement Officers, such as Autopsy 3 for Linux.",
|
"description": "DEFT (acronym for Digital Evidence & Forensics Toolkit) is a distribution made for Computer Forensics, with the purpose of running live on systems without tampering or corrupting devices (hard disks, pendrives, etc...) connected to the PC where the boot process takes place.\nThe DEFT system is based on GNU Linux, it can run live (via DVDROM or USB pendrive), installed or run as a Virtual Appliance on VMware or Virtualbox. DEFT employs LXDE as desktop environment and WINE for executing Windows tools under Linux. It features a comfortable mount manager for device management.\nDEFT is paired with DART (acronym for Digital Advanced Response Toolkit), a Forensics System which can be run on Windows and contains the best tools for Forensics and Incident Response. DART features a GUI with logging and integrity check for the instruments here contained.\nBesides all this, the DEFT staff is devoted to implementing and developing applications which are released to Law Enforcement Officers, such as Autopsy 3 for Linux.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "85441847-4091-4894-9079-802084a1845b",
|
||||||
"name": "Dell OS9",
|
"name": "Dell OS9",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Dell Networking OS9 (formerly FTOS).\nOS9 powers the Dell Networking product portfolio and has been hardened in some of the largest and most demanding environments in the world to meet stringent reliability, scalability and serviceability requirements. \n\nDownload and uncompress zip files from the Dell support site - corresponding to the FTOS/OS9 image name. Please 'Select FTOS for S-Series OS-EMULATOR'. Import the resulting ISO image.",
|
"description": "Dell Networking OS9 (formerly FTOS).\nOS9 powers the Dell Networking product portfolio and has been hardened in some of the largest and most demanding environments in the world to meet stringent reliability, scalability and serviceability requirements. \n\nDownload and uncompress zip files from the Dell support site - corresponding to the FTOS/OS9 image name. Please 'Select FTOS for S-Series OS-EMULATOR'. Import the resulting ISO image.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "f049539d-db46-422f-8d10-ff9b96a2a4ae",
|
||||||
"name": "DNS",
|
"name": "DNS",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "This appliance provides DNS using dnsmasq with the local domain set to \"lab\".",
|
"description": "This appliance provides DNS using dnsmasq with the local domain set to \"lab\".",
|
||||||
|
73
gns3server/appliances/empty-vm.gns3a
Normal file
73
gns3server/appliances/empty-vm.gns3a
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
{
|
||||||
|
"appliance_id": "1cfdf900-7c30-4cb7-8f03-3f61d2581633",
|
||||||
|
"name": "Empty VM",
|
||||||
|
"category": "guest",
|
||||||
|
"description": "An empty VM with empty hard disks 8G, 30G & 100G.",
|
||||||
|
"vendor_name": "GNS3",
|
||||||
|
"vendor_url": "https://gns3.com",
|
||||||
|
"documentation_url": "",
|
||||||
|
"product_name": "QEMU",
|
||||||
|
"product_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/",
|
||||||
|
"registry_version": 4,
|
||||||
|
"status": "experimental",
|
||||||
|
"maintainer": "GNS3 Team",
|
||||||
|
"maintainer_email": "developers@gns3.net",
|
||||||
|
"usage": "Default at first boot the VM will start from the cdrom.",
|
||||||
|
"port_name_format": "eth{0}",
|
||||||
|
"qemu": {
|
||||||
|
"adapter_type": "e1000",
|
||||||
|
"adapters": 1,
|
||||||
|
"ram": 1024,
|
||||||
|
"arch": "x86_64",
|
||||||
|
"console_type": "vnc",
|
||||||
|
"hda_disk_interface": "sata",
|
||||||
|
"boot_priority": "d",
|
||||||
|
"kvm": "allow"
|
||||||
|
},
|
||||||
|
"images": [
|
||||||
|
{
|
||||||
|
"filename": "empty8G.qcow2",
|
||||||
|
"version": "8G",
|
||||||
|
"md5sum": "f1d2c25b6990f99bd05b433ab603bdb4",
|
||||||
|
"filesize": 197120,
|
||||||
|
"download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/",
|
||||||
|
"direct_download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/empty8G.qcow2/download"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"filename": "empty30G.qcow2",
|
||||||
|
"version": "30G",
|
||||||
|
"md5sum": "3411a599e822f2ac6be560a26405821a",
|
||||||
|
"filesize": 197120,
|
||||||
|
"download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/",
|
||||||
|
"direct_download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/empty30G.qcow2/download"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"filename": "empty100G.qcow2",
|
||||||
|
"version": "100G",
|
||||||
|
"md5sum": "1e6409a4523ada212dea2ebc50e50a65",
|
||||||
|
"filesize": 198656,
|
||||||
|
"download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/",
|
||||||
|
"direct_download_url": "https://sourceforge.net/projects/gns-3/files/Empty%20Qemu%20disk/empty100G.qcow2/download"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"versions": [
|
||||||
|
{
|
||||||
|
"name": "8G",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "empty8G.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "30G",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "empty30G.qcow2"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "100G",
|
||||||
|
"images": {
|
||||||
|
"hda_disk_image": "empty100G.qcow2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "0293ded2-0ca3-4052-913f-8c2d872e46ba",
|
||||||
"name": "EXOS VM",
|
"name": "EXOS VM",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "The ExtremeXOS VM is created and maintained by Extreme Networks for users to emulate a network using EXOS switches.",
|
"description": "The ExtremeXOS VM is created and maintained by Extreme Networks for users to emulate a network using EXOS switches.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "3e81eb47-43c4-4676-bbc5-8dda1d7abe08",
|
||||||
"name": "VOSS VM",
|
"name": "VOSS VM",
|
||||||
"category": "multilayer_switch",
|
"category": "multilayer_switch",
|
||||||
"description": "The VOSS VM is a software emulation of a VSP8K switch.",
|
"description": "The VOSS VM is a software emulation of a VSP8K switch.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "4aa73054-4d54-4829-9c00-b16ad50e7a7e",
|
||||||
"name": "F5 BIG-IP LTM VE",
|
"name": "F5 BIG-IP LTM VE",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "The BIG-IP family of products offers the application intelligence that network managers need to ensure applications are fast, secure, and available. All BIG-IP products share a common underlying architecture, F5's Traffic Management Operating System (TMOS), which provides unified intelligence, flexibility, and programmability. Together, BIG-IP's powerful platforms, advanced modules, and centralized management system make up the most comprehensive set of application delivery tools in the industry. BIG-IP Virtual Edition (VE) is a version of the BIG-IP system that runs as a virtual machine in specifically-supported hypervisors. BIG-IP VE emulates a hardware-based BIG-IP system running a VE-compatible version of BIG-IP software.",
|
"description": "The BIG-IP family of products offers the application intelligence that network managers need to ensure applications are fast, secure, and available. All BIG-IP products share a common underlying architecture, F5's Traffic Management Operating System (TMOS), which provides unified intelligence, flexibility, and programmability. Together, BIG-IP's powerful platforms, advanced modules, and centralized management system make up the most comprehensive set of application delivery tools in the industry. BIG-IP Virtual Edition (VE) is a version of the BIG-IP system that runs as a virtual machine in specifically-supported hypervisors. BIG-IP VE emulates a hardware-based BIG-IP system running a VE-compatible version of BIG-IP software.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "799f2414-7341-4f55-8b6d-2b3f6d11b1d8",
|
||||||
"name": "F5 BIG-IQ CM",
|
"name": "F5 BIG-IQ CM",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "When you go from managing a few boxes to managing a few dozen, your processes, logistics, and needs all change. BIG-IQ Centralized Management brings all of your devices together, so you can discover, track, upgrade, and deploy more efficiently. You can also monitor key metrics from one location, saving yourself both time and effort.\n\nCentrally manage up to 200 physical, virtual, or virtual clustered multiprocessing (vCMP) based BIG-IP devices. BIG-IQ Centralized Management also handles licensing for up to 5,000 unmanaged devices, so you can spin BIG-IP virtual editions (VEs) up or down as needed.",
|
"description": "When you go from managing a few boxes to managing a few dozen, your processes, logistics, and needs all change. BIG-IQ Centralized Management brings all of your devices together, so you can discover, track, upgrade, and deploy more efficiently. You can also monitor key metrics from one location, saving yourself both time and effort.\n\nCentrally manage up to 200 physical, virtual, or virtual clustered multiprocessing (vCMP) based BIG-IP devices. BIG-IQ Centralized Management also handles licensing for up to 5,000 unmanaged devices, so you can spin BIG-IP virtual editions (VEs) up or down as needed.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "b2027465-2959-4ef3-ba56-7b2880e4e711",
|
||||||
"name": "Firefox",
|
"name": "Firefox",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "A light Linux based on TinyCore Linux with Firefox preinstalled",
|
"description": "A light Linux based on TinyCore Linux with Firefox preinstalled",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "a1903402-919b-4620-9b07-37902f46a4e3",
|
||||||
"name": "FortiADC Manager",
|
"name": "FortiADC Manager",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiADC Manager allows you to use a web- based user interface to configure remote FortiADC devices. It allows you to simplify and speed up the FortiADC deployment and update process by maintaining configuration templates and policy packages that you can modify and apply as needed.",
|
"description": "FortiADC Manager allows you to use a web- based user interface to configure remote FortiADC devices. It allows you to simplify and speed up the FortiADC deployment and update process by maintaining configuration templates and policy packages that you can modify and apply as needed.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "74e0ff73-7ceb-4871-81f0-b4dd4b35911a",
|
||||||
"name": "FortiADC",
|
"name": "FortiADC",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "Fortinet ADC appliances optimize the availability, user experience, and scalability of enterprise application delivery. They deliver fast, secure, and intelligent acceleration and distribution of even the most demanding enterprise applications.",
|
"description": "Fortinet ADC appliances optimize the availability, user experience, and scalability of enterprise application delivery. They deliver fast, secure, and intelligent acceleration and distribution of even the most demanding enterprise applications.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "4fc11cfb-d600-4dd4-af94-e4b16191be2a",
|
||||||
"name": "FortiAnalyzer",
|
"name": "FortiAnalyzer",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiAnalyzer Network Security Logging, Analysis, and Reporting Appliances securely aggregate log data from Fortinet Security Appliances. A comprehensive suite of easily customable reports allows you to quickly analyze and visualize network threats, inefficiencies and usage.",
|
"description": "FortiAnalyzer Network Security Logging, Analysis, and Reporting Appliances securely aggregate log data from Fortinet Security Appliances. A comprehensive suite of easily customable reports allows you to quickly analyze and visualize network threats, inefficiencies and usage.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "57e289b6-68a4-4911-a916-0d3def89ef74",
|
||||||
"name": "FortiAuthenticator",
|
"name": "FortiAuthenticator",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiAuthenticator user identity management appliances strengthen enterprise security by simplifying and centralizing the management and storage of user identity information.",
|
"description": "FortiAuthenticator user identity management appliances strengthen enterprise security by simplifying and centralizing the management and storage of user identity information.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "75df92b4-69d3-4d5d-91b1-c36efa68d9fd",
|
||||||
"name": "FortiCache",
|
"name": "FortiCache",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiCache VM high performance Web Caching virtual appliances address bandwidth saturation, high latency, and poor performance caused by caching popular internet content locally for carriers, service providers, enterprises and educational networks. FortiCache VM appliances reduce the cost and impact of cached content on the network, while increasing performance and end- user satisfaction by improving the speed of delivery of popular repeated content.",
|
"description": "FortiCache VM high performance Web Caching virtual appliances address bandwidth saturation, high latency, and poor performance caused by caching popular internet content locally for carriers, service providers, enterprises and educational networks. FortiCache VM appliances reduce the cost and impact of cached content on the network, while increasing performance and end- user satisfaction by improving the speed of delivery of popular repeated content.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "2b3da0fb-abe3-4131-92b6-4e7fcb50dba5",
|
||||||
"name": "FortiGate",
|
"name": "FortiGate",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "FortiGate Virtual Appliance offers the same level of advanced threat prevention features like the physical appliances in private, hybrid and public cloud deployment.",
|
"description": "FortiGate Virtual Appliance offers the same level of advanced threat prevention features like the physical appliances in private, hybrid and public cloud deployment.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "4089ee66-e13b-4490-aa51-53cdb969e024",
|
||||||
"name": "FortiMail",
|
"name": "FortiMail",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiMail is a complete Secure Email Gateway offering suitable for any size organization. It provides a single solution to protect against inbound attacks - including advanced malware -, as well as outbound threats and data loss with a wide range of top-rated security capabilities.",
|
"description": "FortiMail is a complete Secure Email Gateway offering suitable for any size organization. It provides a single solution to protect against inbound attacks - including advanced malware -, as well as outbound threats and data loss with a wide range of top-rated security capabilities.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "b9ce377f-6a6c-497a-a12d-444936a575c3",
|
||||||
"name": "FortiManager",
|
"name": "FortiManager",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FortiManager Security Management appliances allow you to centrally manage any number of Fortinet Network Security devices, from several to thousands, including FortiGate, FortiWiFi, and FortiCarrier.",
|
"description": "FortiManager Security Management appliances allow you to centrally manage any number of Fortinet Network Security devices, from several to thousands, including FortiGate, FortiWiFi, and FortiCarrier.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "0f57eb3a-7b1c-47d4-96c4-fe8ed60c9f50",
|
||||||
"name": "FortiProxy",
|
"name": "FortiProxy",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "FortiProxy is a secure web proxy that protects employees against internet-borne attacks by incorporating multiple detection techniques such as web filtering, DNS filtering, data loss prevention, antivirus, intrusion prevention and advanced threat protection. It helps enterprises enforce internet compliance using granular application control.",
|
"description": "FortiProxy is a secure web proxy that protects employees against internet-borne attacks by incorporating multiple detection techniques such as web filtering, DNS filtering, data loss prevention, antivirus, intrusion prevention and advanced threat protection. It helps enterprises enforce internet compliance using granular application control.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "754f4df8-934f-4a55-8d32-5bfd922785d9",
|
||||||
"name": "FortiRecorder",
|
"name": "FortiRecorder",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Surveillance systems can be complicated, expensive, and unreliable. But FortiCamera and FortiRecorder simplify IP video surveillance and there are no license fees. With FortiCams, you can see everything: doors, POS terminals, public areas--whatever you need to keep an eye on. FortiRecorder captures the images for easy monitoring, storage, and retrieval. Just plug in your cameras, connect the FortiRecorder, open a web browser or client application, and you're ready to go. It's easy to navigate and configure with event timelines and profile-driven configuration.",
|
"description": "Surveillance systems can be complicated, expensive, and unreliable. But FortiCamera and FortiRecorder simplify IP video surveillance and there are no license fees. With FortiCams, you can see everything: doors, POS terminals, public areas--whatever you need to keep an eye on. FortiRecorder captures the images for easy monitoring, storage, and retrieval. Just plug in your cameras, connect the FortiRecorder, open a web browser or client application, and you're ready to go. It's easy to navigate and configure with event timelines and profile-driven configuration.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "88252124-93a4-4851-9b0f-b0f264705c1a",
|
||||||
"name": "FortiSandbox",
|
"name": "FortiSandbox",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "Today's threats are increasingly sophisticated and often bypass traditional malware security by masking their malicious activity. A sandbox augments your security architecture by validating threats in a separate, secure environment. FortiSandbox offers a powerful combination of advanced detection, automated mitigation, actionable insight, and flexible deployment to stop targeted attacks and subsequent data loss. It's also a key component of our Advanced Threat Protection solution.",
|
"description": "Today's threats are increasingly sophisticated and often bypass traditional malware security by masking their malicious activity. A sandbox augments your security architecture by validating threats in a separate, secure environment. FortiSandbox offers a powerful combination of advanced detection, automated mitigation, actionable insight, and flexible deployment to stop targeted attacks and subsequent data loss. It's also a key component of our Advanced Threat Protection solution.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "b963c9d0-f73b-4a6c-b876-644ae5dd2779",
|
||||||
"name": "FortiSIEM",
|
"name": "FortiSIEM",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "Breaches to network security continue to occur across all industry verticals, even to the most respected brands. The time it takes to discover, isolate, and remediate the incident continues to be measured in hundreds of days-having material impacts on security and compliance standards. It is no wonder that many organizations are struggling. As recent surveys have shown, enterprises have an average of 32 different vendors' devices in their network, with no automated ability to cross-correlate the data that each is collecting. It is also easy to see why organizations are strapped for the cyber security personnel they need to manage all the data in these complex environments.\n\nFrom its inception, FortiSIEM was built to reduce complexity in managing network and security operations. FortiSIEM provides organizations of all sizes with a comprehensive, holistic, and scalable solution for managing security, performance, and compliance from IoT to the cloud.",
|
"description": "Breaches to network security continue to occur across all industry verticals, even to the most respected brands. The time it takes to discover, isolate, and remediate the incident continues to be measured in hundreds of days-having material impacts on security and compliance standards. It is no wonder that many organizations are struggling. As recent surveys have shown, enterprises have an average of 32 different vendors' devices in their network, with no automated ability to cross-correlate the data that each is collecting. It is also easy to see why organizations are strapped for the cyber security personnel they need to manage all the data in these complex environments.\n\nFrom its inception, FortiSIEM was built to reduce complexity in managing network and security operations. FortiSIEM provides organizations of all sizes with a comprehensive, holistic, and scalable solution for managing security, performance, and compliance from IoT to the cloud.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "62cc83dc-be46-49b3-80e0-9f0d4d644fc9",
|
||||||
"name": "FortiWeb",
|
"name": "FortiWeb",
|
||||||
"category": "firewall",
|
"category": "firewall",
|
||||||
"description": "FortiWeb Web Application Firewalls provide specialized, layered web application threat protection for medium/large enterprises, application service providers, and SaaS providers.",
|
"description": "FortiWeb Web Application Firewalls provide specialized, layered web application threat protection for medium/large enterprises, application service providers, and SaaS providers.",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "691f6552-725f-4dff-a2ba-220f5e3ab6a6",
|
||||||
"name": "freeRouter",
|
"name": "freeRouter",
|
||||||
"category": "router",
|
"category": "router",
|
||||||
"description": "networking swiss army knife - it speaks routing protocols, and (re)encapsulates packets on interfaces",
|
"description": "networking swiss army knife - it speaks routing protocols, and (re)encapsulates packets on interfaces",
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
|
"appliance_id": "0706912e-be44-45b7-9723-d9c3749dd5ef",
|
||||||
"name": "FreeBSD",
|
"name": "FreeBSD",
|
||||||
"category": "guest",
|
"category": "guest",
|
||||||
"description": "FreeBSD is an advanced computer operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.",
|
"description": "FreeBSD is an advanced computer operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.",
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user