mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-01-04 20:14:13 +00:00
Merge pull request #1370 from GNS3/bugfixRemovedQemuCode/1363
Bugfix removed qemu code/1363
This commit is contained in:
commit
cb48ea2715
@ -32,10 +32,6 @@ export class MockedQemuService {
|
|||||||
return of(qemuTemplate);
|
return of(qemuTemplate);
|
||||||
}
|
}
|
||||||
|
|
||||||
public getBinaries(controller:Controller ) {
|
|
||||||
return of([]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public getImages(controller:Controller ) {
|
public getImages(controller:Controller ) {
|
||||||
return of([]);
|
return of([]);
|
||||||
}
|
}
|
||||||
@ -105,10 +101,6 @@ xdescribe('AddQemuVmTemplateComponent', () => {
|
|||||||
component.memoryForm.controls['ramMemory'].setValue(0);
|
component.memoryForm.controls['ramMemory'].setValue(0);
|
||||||
component.diskForm.controls['fileName'].setValue('file name');
|
component.diskForm.controls['fileName'].setValue('file name');
|
||||||
component.chosenImage = 'path';
|
component.chosenImage = 'path';
|
||||||
component.selectedBinary = {
|
|
||||||
path: 'path',
|
|
||||||
version: 'version',
|
|
||||||
};
|
|
||||||
component.newImageSelected = true;
|
component.newImageSelected = true;
|
||||||
component.controller = { id: 1 } as Controller ;
|
component.controller = { id: 1 } as Controller ;
|
||||||
|
|
||||||
@ -124,10 +116,6 @@ xdescribe('AddQemuVmTemplateComponent', () => {
|
|||||||
component.memoryForm.controls['ramMemory'].setValue(0);
|
component.memoryForm.controls['ramMemory'].setValue(0);
|
||||||
component.diskForm.controls['fileName'].setValue('file name');
|
component.diskForm.controls['fileName'].setValue('file name');
|
||||||
component.chosenImage = 'path';
|
component.chosenImage = 'path';
|
||||||
component.selectedBinary = {
|
|
||||||
path: 'path',
|
|
||||||
version: 'version',
|
|
||||||
};
|
|
||||||
component.newImageSelected = true;
|
component.newImageSelected = true;
|
||||||
component.controller = { id: 1 } as Controller ;
|
component.controller = { id: 1 } as Controller ;
|
||||||
|
|
||||||
@ -142,10 +130,6 @@ xdescribe('AddQemuVmTemplateComponent', () => {
|
|||||||
component.memoryForm.controls['binary'].setValue('binary');
|
component.memoryForm.controls['binary'].setValue('binary');
|
||||||
component.diskForm.controls['fileName'].setValue('file name');
|
component.diskForm.controls['fileName'].setValue('file name');
|
||||||
component.chosenImage = 'path';
|
component.chosenImage = 'path';
|
||||||
component.selectedBinary = {
|
|
||||||
path: 'path',
|
|
||||||
version: 'version',
|
|
||||||
};
|
|
||||||
component.newImageSelected = true;
|
component.newImageSelected = true;
|
||||||
component.controller = { id: 1 } as Controller ;
|
component.controller = { id: 1 } as Controller ;
|
||||||
|
|
||||||
|
@ -25,10 +25,8 @@ import { ToasterService } from '../../../../services/toaster.service';
|
|||||||
})
|
})
|
||||||
export class AddQemuVmTemplateComponent implements OnInit {
|
export class AddQemuVmTemplateComponent implements OnInit {
|
||||||
controller:Controller ;
|
controller:Controller ;
|
||||||
qemuBinaries: QemuBinary[] = [];
|
|
||||||
selectPlatform: string[] = [];
|
selectPlatform: string[] = [];
|
||||||
selectedPlatform: string;
|
selectedPlatform: string;
|
||||||
selectedBinary: QemuBinary;
|
|
||||||
ramMemory: number;
|
ramMemory: number;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
newImageSelected: boolean = false;
|
newImageSelected: boolean = false;
|
||||||
@ -108,19 +106,12 @@ export class AddQemuVmTemplateComponent implements OnInit {
|
|||||||
this.qemuTemplate = qemuTemplate;
|
this.qemuTemplate = qemuTemplate;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
this.qemuService.getBinaries(this.controller).subscribe((qemuBinaries: QemuBinary[]) => {
|
|
||||||
this.qemuBinaries = qemuBinaries;
|
|
||||||
if (this.qemuBinaries[0]) this.selectedBinary = this.qemuBinaries[0];
|
|
||||||
});
|
|
||||||
|
|
||||||
this.qemuService.getImages(this.controller).subscribe((qemuImages: QemuImage[]) => {
|
this.qemuService.getImages(this.controller).subscribe((qemuImages: QemuImage[]) => {
|
||||||
this.qemuImages = qemuImages;
|
this.qemuImages = qemuImages;
|
||||||
});
|
});
|
||||||
|
|
||||||
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();
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -175,9 +166,7 @@ export class AddQemuVmTemplateComponent implements OnInit {
|
|||||||
addTemplate() {
|
addTemplate() {
|
||||||
if (!this.nameForm.invalid && !this.memoryForm.invalid && (this.selectedImage || this.chosenImage)) {
|
if (!this.nameForm.invalid && !this.memoryForm.invalid && (this.selectedImage || this.chosenImage)) {
|
||||||
this.qemuTemplate.ram = +this.memoryForm.get('ramMemory').value;
|
this.qemuTemplate.ram = +this.memoryForm.get('ramMemory').value;
|
||||||
this.qemuTemplate.qemu_path = this.selectedBinary.path;
|
|
||||||
this.qemuTemplate.platform = this.selectedPlatform;
|
this.qemuTemplate.platform = this.selectedPlatform;
|
||||||
|
|
||||||
if (this.newImageSelected) {
|
if (this.newImageSelected) {
|
||||||
this.qemuTemplate.hda_disk_image = this.diskForm.get('fileName').value;
|
this.qemuTemplate.hda_disk_image = this.diskForm.get('fileName').value;
|
||||||
} else {
|
} else {
|
||||||
|
@ -16,7 +16,6 @@ import { ToasterService } from '../../../../services/toaster.service';
|
|||||||
})
|
})
|
||||||
export class CopyQemuVmTemplateComponent implements OnInit {
|
export class CopyQemuVmTemplateComponent implements OnInit {
|
||||||
controller:Controller ;
|
controller:Controller ;
|
||||||
qemuBinaries: QemuBinary[] = [];
|
|
||||||
templateName: string = '';
|
templateName: string = '';
|
||||||
qemuTemplate: QemuTemplate;
|
qemuTemplate: QemuTemplate;
|
||||||
nameForm: FormGroup;
|
nameForm: FormGroup;
|
||||||
|
@ -54,6 +54,13 @@
|
|||||||
</mat-option>
|
</mat-option>
|
||||||
</mat-select>
|
</mat-select>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<mat-select placeholder="Platform" [(ngModel)]="qemuTemplate.platform">
|
||||||
|
<mat-option *ngFor="let platform of selectPlatform" [value]="platform">
|
||||||
|
{{ platform }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input matInput type="number" [(ngModel)]="qemuTemplate.ram" placeholder="RAM" />
|
<input matInput type="number" [(ngModel)]="qemuTemplate.ram" placeholder="RAM" />
|
||||||
<span matSuffix>MB</span>
|
<span matSuffix>MB</span>
|
||||||
@ -61,13 +68,7 @@
|
|||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input matInput type="number" [(ngModel)]="qemuTemplate.cpus" placeholder="vCPUs" />
|
<input matInput type="number" [(ngModel)]="qemuTemplate.cpus" placeholder="vCPUs" />
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
<mat-form-field class="form-field">
|
|
||||||
<mat-select placeholder="Qemu binary" [(ngModel)]="qemuTemplate.qemu_path">
|
|
||||||
<mat-option *ngFor="let binary of binaries" [value]="binary.path">
|
|
||||||
{{ binary.path }}
|
|
||||||
</mat-option>
|
|
||||||
</mat-select>
|
|
||||||
</mat-form-field>
|
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<mat-select placeholder="Boot priority" [(ngModel)]="qemuTemplate.boot_priority">
|
<mat-select placeholder="Boot priority" [(ngModel)]="qemuTemplate.boot_priority">
|
||||||
<mat-option *ngFor="let priority of bootPriorities" [value]="priority[1]">
|
<mat-option *ngFor="let priority of bootPriorities" [value]="priority[1]">
|
||||||
|
@ -31,9 +31,6 @@ export class MockedQemuService {
|
|||||||
return of(qemuTemplate);
|
return of(qemuTemplate);
|
||||||
}
|
}
|
||||||
|
|
||||||
public getBinaries(controller:Controller ) {
|
|
||||||
return of([]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public getImages(controller:Controller ) {
|
public getImages(controller:Controller ) {
|
||||||
return of([]);
|
return of([]);
|
||||||
|
@ -27,11 +27,13 @@ export class QemuVmTemplateDetailsComponent implements OnInit {
|
|||||||
onCloseOptions = [];
|
onCloseOptions = [];
|
||||||
categories = [];
|
categories = [];
|
||||||
priorities: string[] = [];
|
priorities: string[] = [];
|
||||||
binaries: QemuBinary[] = [];
|
|
||||||
activateCpuThrottling: boolean = true;
|
activateCpuThrottling: boolean = true;
|
||||||
isConfiguratorOpened: boolean = false;
|
isConfiguratorOpened: boolean = false;
|
||||||
displayedColumns: string[] = ['adapter_number', 'port_name', 'adapter_type', 'actions'];
|
displayedColumns: string[] = ['adapter_number', 'port_name', 'adapter_type', 'actions'];
|
||||||
generalSettingsForm: FormGroup;
|
generalSettingsForm: FormGroup;
|
||||||
|
selectPlatform: string[] = [];
|
||||||
|
selectedPlatform: string;
|
||||||
|
|
||||||
|
|
||||||
@ViewChild('customAdaptersConfigurator')
|
@ViewChild('customAdaptersConfigurator')
|
||||||
customAdaptersConfigurator: CustomAdaptersComponent;
|
customAdaptersConfigurator: CustomAdaptersComponent;
|
||||||
@ -62,12 +64,10 @@ export class QemuVmTemplateDetailsComponent implements OnInit {
|
|||||||
this.qemuService.getTemplate(this.controller, template_id).subscribe((qemuTemplate: QemuTemplate) => {
|
this.qemuService.getTemplate(this.controller, template_id).subscribe((qemuTemplate: QemuTemplate) => {
|
||||||
this.qemuTemplate = qemuTemplate;
|
this.qemuTemplate = qemuTemplate;
|
||||||
this.fillCustomAdapters();
|
this.fillCustomAdapters();
|
||||||
|
|
||||||
this.qemuService.getBinaries(controller).subscribe((qemuBinaries: QemuBinary[]) => {
|
|
||||||
this.binaries = qemuBinaries;
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.selectPlatform = this.configurationService.getPlatform();
|
||||||
}
|
}
|
||||||
|
|
||||||
getConfiguration() {
|
getConfiguration() {
|
||||||
|
@ -1,7 +1,20 @@
|
|||||||
<div class="content" [ngClass]="{ shadowed: isSymbolSelectionOpened }">
|
<div class="content" [ngClass]="{ shadowed: isSymbolSelectionOpened }">
|
||||||
<div class="default-header">
|
<div class="default-header">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<h1 class="col">VPCS device configuration</h1>
|
<div class="col col-md-1">
|
||||||
|
<button
|
||||||
|
class="top-button"
|
||||||
|
*ngIf="controller"
|
||||||
|
class="cancel-button"
|
||||||
|
mat-button
|
||||||
|
(click)="goBack()"
|
||||||
|
>
|
||||||
|
<mat-icon>arrow_back</mat-icon>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="col col-md-11">
|
||||||
|
<h1 class="col">VPCS device configuration</h1>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="default-content" *ngIf="vpcsTemplate">
|
<div class="default-content" *ngIf="vpcsTemplate">
|
||||||
|
@ -131,19 +131,6 @@
|
|||||||
|
|
||||||
<mat-card [hidden]="!(!isLinuxPlatform || applianceToInstall.dynamips)">
|
<mat-card [hidden]="!(!isLinuxPlatform || applianceToInstall.dynamips)">
|
||||||
<div *ngIf="applianceToInstall.qemu">
|
<div *ngIf="applianceToInstall.qemu">
|
||||||
<div>
|
|
||||||
Qemu binary<br />
|
|
||||||
<mat-select
|
|
||||||
class="selection-group"
|
|
||||||
placeholder="Qemu binary"
|
|
||||||
[(ngModel)]="selectedBinary"
|
|
||||||
[ngModelOptions]="{ standalone: true }"
|
|
||||||
>
|
|
||||||
<mat-option *ngFor="let binary of qemuBinaries" [value]="binary">
|
|
||||||
{{ binary.path }}
|
|
||||||
</mat-option>
|
|
||||||
</mat-select>
|
|
||||||
</div>
|
|
||||||
<div>
|
<div>
|
||||||
Install required files
|
Install required files
|
||||||
<button
|
<button
|
||||||
|
@ -65,8 +65,6 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
public isLinuxPlatform = false;
|
public isLinuxPlatform = false;
|
||||||
private isLocalComputerChosen = false;
|
private isLocalComputerChosen = false;
|
||||||
|
|
||||||
public qemuBinaries: QemuBinary[] = [];
|
|
||||||
public selectedBinary: QemuBinary;
|
|
||||||
|
|
||||||
public categories: string[] = ['all categories', 'router', 'multilayer_switch', 'guest', 'firewall'];
|
public categories: string[] = ['all categories', 'router', 'multilayer_switch', 'guest', 'firewall'];
|
||||||
public category: string = 'all categories';
|
public category: string = 'all categories';
|
||||||
@ -126,10 +124,6 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
this.qemuService.getBinaries(this.controller).subscribe((binaries) => {
|
|
||||||
this.qemuBinaries = binaries;
|
|
||||||
});
|
|
||||||
|
|
||||||
this.qemuService.getImages(this.controller).subscribe((qemuImages) => {
|
this.qemuService.getImages(this.controller).subscribe((qemuImages) => {
|
||||||
this.qemuImages = qemuImages;
|
this.qemuImages = qemuImages;
|
||||||
});
|
});
|
||||||
@ -336,30 +330,6 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
this.applianceToInstall = object;
|
this.applianceToInstall = object;
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
this.stepper.next();
|
this.stepper.next();
|
||||||
if (this.applianceToInstall.qemu) {
|
|
||||||
setTimeout(() => {
|
|
||||||
if (this.qemuBinaries.length) {
|
|
||||||
if (this.applianceToInstall.qemu.arch === 'x86_64') {
|
|
||||||
let filtered_binaries = this.qemuBinaries.filter((n) => n.path.includes('qemu-system-x86_64'));
|
|
||||||
if (filtered_binaries.length) {
|
|
||||||
this.selectedBinary = filtered_binaries[0];
|
|
||||||
}
|
|
||||||
} else if (this.applianceToInstall.qemu.arch === 'i386') {
|
|
||||||
let filtered_binaries = this.qemuBinaries.filter((n) => n.path.includes('qemu-system-i386'));
|
|
||||||
if (filtered_binaries.length) {
|
|
||||||
this.selectedBinary = filtered_binaries[0];
|
|
||||||
}
|
|
||||||
} else if (this.applianceToInstall.qemu.arch === 'x86_64') {
|
|
||||||
let filtered_binaries = this.qemuBinaries.filter((n) => n.path.includes('qemu-system-arm'));
|
|
||||||
if (filtered_binaries.length) {
|
|
||||||
this.selectedBinary = filtered_binaries[0];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this.selectedBinary = this.qemuBinaries[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, 100);
|
|
||||||
}
|
|
||||||
}, 100);
|
}, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -642,11 +612,6 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this.selectedBinary) {
|
|
||||||
this.toasterService.error('Please select QEMU binary first');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let qemuTemplate: QemuTemplate = new QemuTemplate();
|
let qemuTemplate: QemuTemplate = new QemuTemplate();
|
||||||
qemuTemplate.ram = this.applianceToInstall.qemu.ram;
|
qemuTemplate.ram = this.applianceToInstall.qemu.ram;
|
||||||
qemuTemplate.adapters = this.applianceToInstall.qemu.adapters;
|
qemuTemplate.adapters = this.applianceToInstall.qemu.adapters;
|
||||||
@ -662,13 +627,13 @@ export class NewTemplateDialogComponent implements OnInit {
|
|||||||
qemuTemplate.first_port_name = this.applianceToInstall.first_port_name;
|
qemuTemplate.first_port_name = this.applianceToInstall.first_port_name;
|
||||||
qemuTemplate.port_name_format = this.applianceToInstall.port_name_format;
|
qemuTemplate.port_name_format = this.applianceToInstall.port_name_format;
|
||||||
qemuTemplate.symbol = this.applianceToInstall.symbol;
|
qemuTemplate.symbol = this.applianceToInstall.symbol;
|
||||||
qemuTemplate.qemu_path = this.selectedBinary.path;
|
|
||||||
qemuTemplate.compute_id = 'local';
|
qemuTemplate.compute_id = 'local';
|
||||||
qemuTemplate.template_id = uuid();
|
qemuTemplate.template_id = uuid();
|
||||||
qemuTemplate.hda_disk_image = version.images.hda_disk_image;
|
qemuTemplate.hda_disk_image = version.images.hda_disk_image;
|
||||||
qemuTemplate.hdb_disk_image = version.images.hdb_disk_image;
|
qemuTemplate.hdb_disk_image = version.images.hdb_disk_image;
|
||||||
qemuTemplate.template_type = 'qemu';
|
qemuTemplate.template_type = 'qemu';
|
||||||
qemuTemplate.usage = this.applianceToInstall.usage;
|
qemuTemplate.usage = this.applianceToInstall.usage;
|
||||||
|
qemuTemplate.platform = this.applianceToInstall.qemu.arch;
|
||||||
|
|
||||||
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
const dialogRef = this.dialog.open(TemplateNameDialogComponent, {
|
||||||
width: '400px',
|
width: '400px',
|
||||||
|
@ -40,56 +40,57 @@
|
|||||||
</mat-tab>
|
</mat-tab>
|
||||||
|
|
||||||
<mat-tab label="Miscellaneous">
|
<mat-tab label="Miscellaneous">
|
||||||
<form [formGroup]="generalSettingsForm">
|
<form [formGroup]="generalSettingsForm">
|
||||||
<mat-form-field class="form-field">
|
|
||||||
<input
|
|
||||||
matInput type="text"
|
|
||||||
[(ngModel)]="node.name"
|
|
||||||
formControlName="name"
|
|
||||||
placeholder="Name">
|
|
||||||
</mat-form-field>
|
|
||||||
</form>
|
|
||||||
<mat-form-field class="select">
|
|
||||||
<mat-select
|
|
||||||
placeholder="Console type"
|
|
||||||
[(ngModel)]="node.console_type">
|
|
||||||
<mat-option *ngFor="let type of consoleTypes" [value]="type">
|
|
||||||
{{type}}
|
|
||||||
</mat-option>
|
|
||||||
</mat-select>
|
|
||||||
</mat-form-field>
|
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input
|
<input matInput type="text" [(ngModel)]="node.name" formControlName="name" placeholder="Name" />
|
||||||
matInput type="text"
|
|
||||||
[(ngModel)]="node.properties.remote_console_host"
|
|
||||||
placeholder="Console host">
|
|
||||||
</mat-form-field>
|
|
||||||
<mat-form-field class="form-field">
|
|
||||||
<input
|
|
||||||
matInput type="text"
|
|
||||||
[(ngModel)]="node.properties.remote_console_port"
|
|
||||||
placeholder="Console port">
|
|
||||||
</mat-form-field>
|
|
||||||
<mat-form-field class="form-field">
|
|
||||||
<input
|
|
||||||
matInput type="text"
|
|
||||||
[(ngModel)]="node.properties.remote_console_http_path"
|
|
||||||
placeholder="Console HTTP path">
|
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
</form>
|
||||||
|
<mat-form-field class="select">
|
||||||
|
<mat-select placeholder="Console type" [(ngModel)]="node.console_type">
|
||||||
|
<mat-option *ngFor="let type of consoleTypes" [value]="type">
|
||||||
|
{{ type }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<input
|
||||||
|
matInput
|
||||||
|
type="text"
|
||||||
|
[(ngModel)]="node.properties.remote_console_host"
|
||||||
|
placeholder="Console host"
|
||||||
|
/>
|
||||||
|
</mat-form-field>
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<input
|
||||||
|
matInput
|
||||||
|
type="text"
|
||||||
|
[(ngModel)]="node.properties.remote_console_port"
|
||||||
|
placeholder="Console port"
|
||||||
|
/>
|
||||||
|
</mat-form-field>
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<input
|
||||||
|
matInput
|
||||||
|
type="text"
|
||||||
|
[(ngModel)]="node.properties.remote_console_http_path"
|
||||||
|
placeholder="Console HTTP path"
|
||||||
|
/>
|
||||||
|
</mat-form-field>
|
||||||
</mat-tab>
|
</mat-tab>
|
||||||
|
|
||||||
<mat-tab label="Usage">
|
<mat-tab label="Usage">
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<textarea matInput type="text" [(ngModel)]="node.properties.usage"></textarea>
|
<textarea matInput type="text" [(ngModel)]="node.properties.usage"></textarea>
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
</mat-tab>
|
</mat-tab>
|
||||||
</mat-tab-group>
|
</mat-tab-group>
|
||||||
</mat-card><div>
|
</mat-card>
|
||||||
|
<div></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
|
|
||||||
<div mat-dialog-actions>
|
<div mat-dialog-actions>
|
||||||
<button mat-button (click)="onCancelClick()" color="accent">Cancel</button>
|
<button mat-button (click)="onCancelClick()" color="accent">Cancel</button>
|
||||||
<button mat-button (click)="onSaveClick()" tabindex="2" mat-raised-button color="primary">Apply</button>
|
<button mat-button (click)="onSaveClick()" tabindex="2" mat-raised-button color="primary">Apply</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -21,7 +21,6 @@ export class ConfiguratorDialogCloudComponent implements OnInit {
|
|||||||
name: string;
|
name: string;
|
||||||
generalSettingsForm: FormGroup;
|
generalSettingsForm: FormGroup;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
binaries: QemuBinary[] = [];
|
|
||||||
onCloseOptions = [];
|
onCloseOptions = [];
|
||||||
bootPriorities = [];
|
bootPriorities = [];
|
||||||
diskInterfaces: string[] = [];
|
diskInterfaces: string[] = [];
|
||||||
|
@ -11,6 +11,13 @@
|
|||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input matInput type="text" formControlName="name" [(ngModel)]="node.name" placeholder="Name" />
|
<input matInput type="text" formControlName="name" [(ngModel)]="node.name" placeholder="Name" />
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
|
<mat-form-field class="form-field">
|
||||||
|
<mat-select placeholder="Platform" [(ngModel)]="node.properties.platform" [ngModelOptions]="{ standalone: true }">
|
||||||
|
<mat-option *ngFor="let platform of selectPlatform" [value]="platform">
|
||||||
|
{{ platform }}
|
||||||
|
</mat-option>
|
||||||
|
</mat-select>
|
||||||
|
</mat-form-field>
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input
|
<input
|
||||||
matInput
|
matInput
|
||||||
@ -25,13 +32,7 @@
|
|||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<input matInput type="number" [(ngModel)]="node.properties.cpus" placeholder="vCPUs" />
|
<input matInput type="number" [(ngModel)]="node.properties.cpus" placeholder="vCPUs" />
|
||||||
</mat-form-field>
|
</mat-form-field>
|
||||||
<mat-form-field class="form-field">
|
|
||||||
<mat-select placeholder="Qemu binary" [(ngModel)]="node.properties.qemu_path">
|
|
||||||
<mat-option *ngFor="let binary of binaries" [value]="binary.path">
|
|
||||||
{{ binary.path }}
|
|
||||||
</mat-option>
|
|
||||||
</mat-select>
|
|
||||||
</mat-form-field>
|
|
||||||
<mat-form-field class="form-field">
|
<mat-form-field class="form-field">
|
||||||
<mat-select placeholder="Boot priority" [(ngModel)]="node.properties.boot_priority">
|
<mat-select placeholder="Boot priority" [(ngModel)]="node.properties.boot_priority">
|
||||||
<mat-option *ngFor="let priority of bootPriorities" [value]="priority[1]">
|
<mat-option *ngFor="let priority of bootPriorities" [value]="priority[1]">
|
||||||
|
@ -23,7 +23,6 @@ export class ConfiguratorDialogQemuComponent implements OnInit {
|
|||||||
name: string;
|
name: string;
|
||||||
generalSettingsForm: FormGroup;
|
generalSettingsForm: FormGroup;
|
||||||
consoleTypes: string[] = [];
|
consoleTypes: string[] = [];
|
||||||
binaries: QemuBinary[] = [];
|
|
||||||
onCloseOptions = [];
|
onCloseOptions = [];
|
||||||
bootPriorities = [];
|
bootPriorities = [];
|
||||||
diskInterfaces: string[] = [];
|
diskInterfaces: string[] = [];
|
||||||
@ -31,6 +30,7 @@ export class ConfiguratorDialogQemuComponent implements OnInit {
|
|||||||
displayedColumns: string[] = ['adapter_number', 'port_name', 'adapter_type', 'actions'];
|
displayedColumns: string[] = ['adapter_number', 'port_name', 'adapter_type', 'actions'];
|
||||||
networkTypes = [];
|
networkTypes = [];
|
||||||
qemuImages: QemuImage[] = [];
|
qemuImages: QemuImage[] = [];
|
||||||
|
selectPlatform: string[] = [];
|
||||||
|
|
||||||
private conf = {
|
private conf = {
|
||||||
autoFocus: false,
|
autoFocus: false,
|
||||||
@ -63,13 +63,11 @@ export class ConfiguratorDialogQemuComponent implements OnInit {
|
|||||||
this.getConfiguration();
|
this.getConfiguration();
|
||||||
});
|
});
|
||||||
|
|
||||||
this.qemuService.getBinaries(this.controller).subscribe((qemuBinaries: QemuBinary[]) => {
|
|
||||||
this.binaries = qemuBinaries;
|
|
||||||
});
|
|
||||||
|
|
||||||
this.qemuService.getImages(this.controller).subscribe((qemuImages: QemuImage[]) => {
|
this.qemuService.getImages(this.controller).subscribe((qemuImages: QemuImage[]) => {
|
||||||
this.qemuImages = qemuImages;
|
this.qemuImages = qemuImages;
|
||||||
});
|
});
|
||||||
|
this.selectPlatform = this.qemuConfigurationService.getPlatform();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
openQemuImageCreator() {
|
openQemuImageCreator() {
|
||||||
|
@ -23,9 +23,6 @@ export class QemuService {
|
|||||||
return `${controller.protocol}//${controller.host}:${controller.port}/images/upload/${filename}`;
|
return `${controller.protocol}//${controller.host}:${controller.port}/images/upload/${filename}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
getBinaries(controller:Controller ): Observable<QemuBinary[]> {
|
|
||||||
return this.httpController.get<QemuBinary[]>(controller, '/computes/local/qemu/binaries') as Observable<QemuBinary[]>;
|
|
||||||
}
|
|
||||||
|
|
||||||
getImages(controller:Controller ): Observable<any> {
|
getImages(controller:Controller ): Observable<any> {
|
||||||
return this.httpController.get<QemuImage[]>(controller, '/images?image_type=qemu') as Observable<QemuImage[]>;
|
return this.httpController.get<QemuImage[]>(controller, '/images?image_type=qemu') as Observable<QemuImage[]>;
|
||||||
|
Loading…
Reference in New Issue
Block a user