mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-01-14 00:39:48 +00:00
Auxiliary console support for IOS, Docker and Qemu templates/nodes
This commit is contained in:
parent
040447ffdf
commit
c9c043b726
@ -14,6 +14,7 @@ export class Properties {
|
|||||||
headless: boolean;
|
headless: boolean;
|
||||||
linked_clone: boolean;
|
linked_clone: boolean;
|
||||||
on_close: string;
|
on_close: string;
|
||||||
|
aux_type: boolean;
|
||||||
aux: number;
|
aux: number;
|
||||||
ram: number;
|
ram: number;
|
||||||
nvram: number;
|
nvram: number;
|
||||||
|
@ -87,6 +87,18 @@
|
|||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-step>
|
</mat-step>
|
||||||
|
|
||||||
|
<mat-step label="Auxiliary console type" [completed]="dockerTemplate.aux_type">
|
||||||
|
<mat-select
|
||||||
|
placeholder="Auxiliary console type"
|
||||||
|
[ngModelOptions]="{ standalone: true }"
|
||||||
|
[(ngModel)]="dockerTemplate.aux_type"
|
||||||
|
>
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-step>
|
||||||
|
|
||||||
<mat-step label="Environment">
|
<mat-step label="Environment">
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<textarea matInput type="text" [(ngModel)]="dockerTemplate.environment"></textarea>
|
<textarea matInput type="text" [(ngModel)]="dockerTemplate.environment"></textarea>
|
||||||
|
@ -22,6 +22,7 @@ export class AddDockerTemplateComponent implements OnInit {
|
|||||||
controller:Controller ;
|
controller:Controller ;
|
||||||
dockerTemplate: DockerTemplate;
|
dockerTemplate: DockerTemplate;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
|
auxConsoleTypes: string[] = [];
|
||||||
isRemoteComputerChosen: boolean = false;
|
isRemoteComputerChosen: boolean = false;
|
||||||
dockerImages: DockerImage[] = [];
|
dockerImages: DockerImage[] = [];
|
||||||
selectedImage: DockerImage;
|
selectedImage: DockerImage;
|
||||||
@ -64,6 +65,7 @@ export class AddDockerTemplateComponent implements OnInit {
|
|||||||
this.controller = controller;
|
this.controller = controller;
|
||||||
|
|
||||||
this.consoleTypes = this.configurationService.getConsoleTypes();
|
this.consoleTypes = this.configurationService.getConsoleTypes();
|
||||||
|
this.auxConsoleTypes = this.configurationService.getAuxConsoleTypes();
|
||||||
|
|
||||||
this.templateMocksService.getDockerTemplate().subscribe((dockerTemplate: DockerTemplate) => {
|
this.templateMocksService.getDockerTemplate().subscribe((dockerTemplate: DockerTemplate) => {
|
||||||
this.dockerTemplate = dockerTemplate;
|
this.dockerTemplate = dockerTemplate;
|
||||||
|
@ -86,6 +86,17 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select
|
||||||
|
[ngModelOptions]="{ standalone: true }"
|
||||||
|
placeholder="Auxiliary console type"
|
||||||
|
[(ngModel)]="dockerTemplate.aux_type"
|
||||||
|
>
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [ngModelOptions]="{ standalone: true }" [(ngModel)]="dockerTemplate.console_auto_start">
|
<mat-checkbox [ngModelOptions]="{ standalone: true }" [(ngModel)]="dockerTemplate.console_auto_start">
|
||||||
Auto start console
|
Auto start console
|
||||||
</mat-checkbox>
|
</mat-checkbox>
|
||||||
|
@ -21,6 +21,7 @@ export class DockerTemplateDetailsComponent implements OnInit {
|
|||||||
isSymbolSelectionOpened: boolean = false;
|
isSymbolSelectionOpened: boolean = false;
|
||||||
|
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
|
auxConsoleTypes: string[] = [];
|
||||||
consoleResolutions: string[] = [];
|
consoleResolutions: string[] = [];
|
||||||
categories = [];
|
categories = [];
|
||||||
adapters: CustomAdapter[] = [];
|
adapters: CustomAdapter[] = [];
|
||||||
@ -60,6 +61,7 @@ export class DockerTemplateDetailsComponent implements OnInit {
|
|||||||
|
|
||||||
getConfiguration() {
|
getConfiguration() {
|
||||||
this.consoleTypes = this.configurationService.getConsoleTypes();
|
this.consoleTypes = this.configurationService.getConsoleTypes();
|
||||||
|
this.auxConsoleTypes = this.configurationService.getAuxConsoleTypes();
|
||||||
this.categories = this.configurationService.getCategories();
|
this.categories = this.configurationService.getCategories();
|
||||||
this.consoleResolutions = this.configurationService.getConsoleResolutions();
|
this.consoleResolutions = this.configurationService.getConsoleResolutions();
|
||||||
}
|
}
|
||||||
|
@ -31,8 +31,10 @@
|
|||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
<mat-label>Platform - {{ iosTemplate.platform }}</mat-label
|
<mat-label>Platform - {{ iosTemplate.platform }}</mat-label
|
||||||
><br /><br />
|
><br /><br />
|
||||||
|
<div *ngIf="iosTemplate.chassis">
|
||||||
<mat-label>Chassis - {{ iosTemplate.chassis }}</mat-label
|
<mat-label>Chassis - {{ iosTemplate.chassis }}</mat-label
|
||||||
><br /><br />
|
><br /><br />
|
||||||
|
</div>
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input
|
<input
|
||||||
matInput
|
matInput
|
||||||
@ -89,6 +91,13 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select placeholder="Auxiliary console type" [(ngModel)]="iosTemplate.aux_type">
|
||||||
|
<mat-option *ngFor="let type of consoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [(ngModel)]="iosTemplate.console_auto_start"> Auto start console </mat-checkbox>
|
<mat-checkbox [(ngModel)]="iosTemplate.console_auto_start"> Auto start console </mat-checkbox>
|
||||||
</mat-expansion-panel>
|
</mat-expansion-panel>
|
||||||
<mat-expansion-panel>
|
<mat-expansion-panel>
|
||||||
|
@ -66,6 +66,20 @@
|
|||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
</mat-step>
|
</mat-step>
|
||||||
|
|
||||||
|
<mat-step label="Auxiliary console type" [completed]="qemuTemplate.aux_type">
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<mat-select
|
||||||
|
placeholder="Auxiliary console type"
|
||||||
|
[(ngModel)]="qemuTemplate.aux_type"
|
||||||
|
[ngModelOptions]="{ standalone: true }"
|
||||||
|
>
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
|
</mat-step>
|
||||||
|
|
||||||
<mat-step label="Disk image">
|
<mat-step label="Disk image">
|
||||||
<form [formGroup]="diskForm">
|
<form [formGroup]="diskForm">
|
||||||
<mat-radio-group class="radio-group">
|
<mat-radio-group class="radio-group">
|
||||||
|
@ -29,6 +29,7 @@ export class AddQemuVmTemplateComponent implements OnInit {
|
|||||||
selectedPlatform: string;
|
selectedPlatform: string;
|
||||||
ramMemory: number;
|
ramMemory: number;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
|
auxConsoleTypes: string[] = [];
|
||||||
newImageSelected: boolean = false;
|
newImageSelected: boolean = false;
|
||||||
qemuImages: QemuImage[] = [];
|
qemuImages: QemuImage[] = [];
|
||||||
selectedImage: QemuImage;
|
selectedImage: QemuImage;
|
||||||
@ -113,6 +114,7 @@ export class AddQemuVmTemplateComponent implements OnInit {
|
|||||||
this.selectPlatform = this.configurationService.getPlatform();
|
this.selectPlatform = this.configurationService.getPlatform();
|
||||||
this.selectedPlatform = this.selectPlatform[0];
|
this.selectedPlatform = this.selectPlatform[0];
|
||||||
this.consoleTypes = this.configurationService.getConsoleTypes();
|
this.consoleTypes = this.configurationService.getConsoleTypes();
|
||||||
|
this.auxConsoleTypes = this.configurationService.getAuxConsoleTypes();
|
||||||
});
|
});
|
||||||
|
|
||||||
this.uploadServiceService.currentCancelItemDetails.subscribe((isCancel) => {
|
this.uploadServiceService.currentCancelItemDetails.subscribe((isCancel) => {
|
||||||
|
@ -90,6 +90,13 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select placeholder="Auxiliary console type" [(ngModel)]="qemuTemplate.aux_type">
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [(ngModel)]="qemuTemplate.console_auto_start"> Auto start console </mat-checkbox>
|
<mat-checkbox [(ngModel)]="qemuTemplate.console_auto_start"> Auto start console </mat-checkbox>
|
||||||
</mat-expansion-panel>
|
</mat-expansion-panel>
|
||||||
<mat-expansion-panel>
|
<mat-expansion-panel>
|
||||||
|
@ -21,6 +21,7 @@ export class QemuVmTemplateDetailsComponent implements OnInit {
|
|||||||
qemuTemplate: QemuTemplate;
|
qemuTemplate: QemuTemplate;
|
||||||
isSymbolSelectionOpened: boolean = false;
|
isSymbolSelectionOpened: boolean = false;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
|
auxConsoleTypes: string[] = [];
|
||||||
diskInterfaces: string[] = [];
|
diskInterfaces: string[] = [];
|
||||||
networkTypes = [];
|
networkTypes = [];
|
||||||
bootPriorities = [];
|
bootPriorities = [];
|
||||||
@ -72,6 +73,7 @@ export class QemuVmTemplateDetailsComponent implements OnInit {
|
|||||||
|
|
||||||
getConfiguration() {
|
getConfiguration() {
|
||||||
this.consoleTypes = this.configurationService.getConsoleTypes();
|
this.consoleTypes = this.configurationService.getConsoleTypes();
|
||||||
|
this.auxConsoleTypes = this.configurationService.getAuxConsoleTypes();
|
||||||
this.diskInterfaces = this.configurationService.getDiskInterfaces();
|
this.diskInterfaces = this.configurationService.getDiskInterfaces();
|
||||||
this.networkTypes = this.configurationService.getNetworkTypes();
|
this.networkTypes = this.configurationService.getNetworkTypes();
|
||||||
this.bootPriorities = this.configurationService.getBootPriorities();
|
this.bootPriorities = this.configurationService.getBootPriorities();
|
||||||
|
@ -56,6 +56,17 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select
|
||||||
|
[ngModelOptions]="{ standalone: true }"
|
||||||
|
placeholder="Auxiliary console type"
|
||||||
|
[(ngModel)]="node.aux_type"
|
||||||
|
>
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [ngModelOptions]="{ standalone: true }" [(ngModel)]="node.console_auto_start">
|
<mat-checkbox [ngModelOptions]="{ standalone: true }" [(ngModel)]="node.console_auto_start">
|
||||||
Auto start console
|
Auto start console
|
||||||
</mat-checkbox>
|
</mat-checkbox>
|
||||||
|
@ -21,6 +21,7 @@ export class ConfiguratorDialogDockerComponent implements OnInit {
|
|||||||
name: string;
|
name: string;
|
||||||
generalSettingsForm: UntypedFormGroup;
|
generalSettingsForm: UntypedFormGroup;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
|
auxConsoleTypes: string[] = [];
|
||||||
consoleResolutions: string[] = ['2560x1440', '1920x1080', '1680x1050', '1440x900', '1366x768', '1280x1024', '1280x800', '1024x768', '800x600', '640x480'];
|
consoleResolutions: string[] = ['2560x1440', '1920x1080', '1680x1050', '1440x900', '1366x768', '1280x1024', '1280x800', '1024x768', '800x600', '640x480'];
|
||||||
private conf = {
|
private conf = {
|
||||||
autoFocus: false,
|
autoFocus: false,
|
||||||
@ -60,6 +61,7 @@ export class ConfiguratorDialogDockerComponent implements OnInit {
|
|||||||
|
|
||||||
getConfiguration() {
|
getConfiguration() {
|
||||||
this.consoleTypes = this.dockerConfigurationService.getConsoleTypes();
|
this.consoleTypes = this.dockerConfigurationService.getConsoleTypes();
|
||||||
|
this.auxConsoleTypes = this.dockerConfigurationService.getAuxConsoleTypes();
|
||||||
}
|
}
|
||||||
|
|
||||||
configureCustomAdapters() {
|
configureCustomAdapters() {
|
||||||
|
@ -19,6 +19,13 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select placeholder="Auxiliary console type" [(ngModel)]="node.aux_type">
|
||||||
|
<mat-option *ngFor="let type of consoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [(ngModel)]="node.console_auto_start"> Auto start console </mat-checkbox><br />
|
<mat-checkbox [(ngModel)]="node.console_auto_start"> Auto start console </mat-checkbox><br />
|
||||||
</mat-tab>
|
</mat-tab>
|
||||||
|
|
||||||
|
@ -54,6 +54,13 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select placeholder="Auxiliary console type" [(ngModel)]="node.aux_type">
|
||||||
|
<mat-option *ngFor="let type of auxConsoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-checkbox [(ngModel)]="node.properties.console_auto_start"> Auto start console </mat-checkbox>
|
<mat-checkbox [(ngModel)]="node.properties.console_auto_start"> Auto start console </mat-checkbox>
|
||||||
</mat-tab>
|
</mat-tab>
|
||||||
<mat-tab label="HDD">
|
<mat-tab label="HDD">
|
||||||
|
@ -10,6 +10,7 @@ export class DockerTemplate {
|
|||||||
console_http_port: number;
|
console_http_port: number;
|
||||||
console_resolution: string;
|
console_resolution: string;
|
||||||
console_type: string;
|
console_type: string;
|
||||||
|
aux_type: string;
|
||||||
custom_adapters: CustomAdapter[];
|
custom_adapters: CustomAdapter[];
|
||||||
default_name_format: string;
|
default_name_format: string;
|
||||||
environment: string;
|
environment: string;
|
||||||
|
@ -6,6 +6,7 @@ export class IosTemplate {
|
|||||||
compute_id: string;
|
compute_id: string;
|
||||||
console_auto_start: boolean;
|
console_auto_start: boolean;
|
||||||
console_type: string;
|
console_type: string;
|
||||||
|
aux_type: string;
|
||||||
default_name_format: string;
|
default_name_format: string;
|
||||||
disk0: number;
|
disk0: number;
|
||||||
disk1: number;
|
disk1: number;
|
||||||
|
@ -11,6 +11,7 @@ export class QemuTemplate {
|
|||||||
compute_id: string;
|
compute_id: string;
|
||||||
console_auto_start: boolean;
|
console_auto_start: boolean;
|
||||||
console_type: string;
|
console_type: string;
|
||||||
|
aux_type: string;
|
||||||
cpu_throttling: number;
|
cpu_throttling: number;
|
||||||
cpus: number;
|
cpus: number;
|
||||||
custom_adapters: CustomAdapter[];
|
custom_adapters: CustomAdapter[];
|
||||||
|
@ -6,6 +6,10 @@ export class DockerConfigurationService {
|
|||||||
return ['telnet', 'vnc', 'http', 'https', 'none'];
|
return ['telnet', 'vnc', 'http', 'https', 'none'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getAuxConsoleTypes() {
|
||||||
|
return ['telnet', 'none'];
|
||||||
|
}
|
||||||
|
|
||||||
getCategories() {
|
getCategories() {
|
||||||
let categories = [
|
let categories = [
|
||||||
['Default', 'guest'],
|
['Default', 'guest'],
|
||||||
|
@ -39,6 +39,10 @@ export class QemuConfigurationService {
|
|||||||
return ['telnet', 'vnc', 'spice', 'spice+agent', 'none'];
|
return ['telnet', 'vnc', 'spice', 'spice+agent', 'none'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getAuxConsoleTypes() {
|
||||||
|
return ['telnet', 'none'];
|
||||||
|
}
|
||||||
|
|
||||||
getDiskInterfaces() {
|
getDiskInterfaces() {
|
||||||
return ['ide', 'sata', 'scsi', 'sd', 'mtd', 'floppy', 'pflash', 'virtio', 'nvme', 'none'];
|
return ['ide', 'sata', 'scsi', 'sd', 'mtd', 'floppy', 'pflash', 'virtio', 'nvme', 'none'];
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,7 @@ describe('QemuService', () => {
|
|||||||
compute_id: 'local',
|
compute_id: 'local',
|
||||||
console_auto_start: false,
|
console_auto_start: false,
|
||||||
console_type: 'telnet',
|
console_type: 'telnet',
|
||||||
|
aux_type: 'none',
|
||||||
cpu_throttling: 0,
|
cpu_throttling: 0,
|
||||||
cpus: 1,
|
cpus: 1,
|
||||||
custom_adapters: [],
|
custom_adapters: [],
|
||||||
@ -102,6 +103,7 @@ describe('QemuService', () => {
|
|||||||
compute_id: 'local',
|
compute_id: 'local',
|
||||||
console_auto_start: false,
|
console_auto_start: false,
|
||||||
console_type: 'telnet',
|
console_type: 'telnet',
|
||||||
|
aux_type: 'none',
|
||||||
cpu_throttling: 0,
|
cpu_throttling: 0,
|
||||||
cpus: 1,
|
cpus: 1,
|
||||||
custom_adapters: [],
|
custom_adapters: [],
|
||||||
|
@ -27,6 +27,7 @@ export class TemplateMocksService {
|
|||||||
compute_id: 'local',
|
compute_id: 'local',
|
||||||
console_auto_start: false,
|
console_auto_start: false,
|
||||||
console_type: 'telnet',
|
console_type: 'telnet',
|
||||||
|
aux_type: 'none',
|
||||||
cpu_throttling: 0,
|
cpu_throttling: 0,
|
||||||
cpus: 1,
|
cpus: 1,
|
||||||
custom_adapters: [],
|
custom_adapters: [],
|
||||||
@ -172,6 +173,7 @@ export class TemplateMocksService {
|
|||||||
compute_id: 'local',
|
compute_id: 'local',
|
||||||
console_auto_start: false,
|
console_auto_start: false,
|
||||||
console_type: 'telnet',
|
console_type: 'telnet',
|
||||||
|
aux_type: 'none',
|
||||||
default_name_format: 'R{0}',
|
default_name_format: 'R{0}',
|
||||||
disk0: 0,
|
disk0: 0,
|
||||||
disk1: 0,
|
disk1: 0,
|
||||||
@ -239,6 +241,7 @@ export class TemplateMocksService {
|
|||||||
console_http_port: 80,
|
console_http_port: 80,
|
||||||
console_resolution: '1024x768',
|
console_resolution: '1024x768',
|
||||||
console_type: 'telnet',
|
console_type: 'telnet',
|
||||||
|
aux_type: 'none',
|
||||||
custom_adapters: [],
|
custom_adapters: [],
|
||||||
default_name_format: '{name}-{0}',
|
default_name_format: '{name}-{0}',
|
||||||
environment: '',
|
environment: '',
|
||||||
|
Loading…
Reference in New Issue
Block a user