Fix a save button bug on system setting page (#13830)

Signed-off-by: AllForNothing <sshijun@vmware.com>
This commit is contained in:
Will Sun 2020-12-23 13:00:45 +08:00 committed by GitHub
parent c660727877
commit 28734d7ac4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 21 additions and 32 deletions

View File

@ -129,7 +129,7 @@ export class NewRobotComponent implements OnInit, OnDestroy {
.pipe(finalize(() => this.loadingSystemConfig = false)) .pipe(finalize(() => this.loadingSystemConfig = false))
.subscribe(res => { .subscribe(res => {
if (res && res.robot_token_duration && res.robot_token_duration.value) { if (res && res.robot_token_duration && res.robot_token_duration.value) {
this.systemRobot.duration = Math.floor(res.robot_token_duration.value / MINUETS_ONE_DAY); this.systemRobot.duration = res.robot_token_duration.value;
this.systemExpirationDays = this.systemRobot.duration; this.systemExpirationDays = this.systemRobot.duration;
} }
}); });

View File

@ -141,7 +141,7 @@ export class Configuration {
this.email_insecure = new BoolValueItem(false, true); this.email_insecure = new BoolValueItem(false, true);
this.token_expiration = new NumberValueItem(30, true); this.token_expiration = new NumberValueItem(30, true);
this.robot_name_prefix = new StringValueItem("", true); this.robot_name_prefix = new StringValueItem("", true);
this.robot_token_duration = new NumberValueItem(30 * (60 * 24), true); this.robot_token_duration = new NumberValueItem(30, true);
this.cfg_expiration = new NumberValueItem(30, true); this.cfg_expiration = new NumberValueItem(30, true);
this.verify_remote_cert = new BoolValueItem(false, true); this.verify_remote_cert = new BoolValueItem(false, true);
this.scan_all_policy = new ComplexValueItem({ this.scan_all_policy = new ComplexValueItem({

View File

@ -27,7 +27,7 @@
</clr-tooltip> </clr-tooltip>
</label> </label>
<input clrInput name="tokenExpiration" type="text" #tokenExpirationInput="ngModel" <input clrInput name="tokenExpiration" type="text" #tokenExpirationInput="ngModel"
[(ngModel)]="systemSettings.token_expiration.value" required pattern="^[1-9]{1}[0-9]*$" [(ngModel)]="tokenExpirationValue" required pattern="^[1-9]{1}[0-9]*$"
id="tokenExpiration" size="20" [disabled]="!editable" /> id="tokenExpiration" size="20" [disabled]="!editable" />
<clr-control-error>{{'TOOLTIP.NUMBER_REQUIRED' | translate}}</clr-control-error> <clr-control-error>{{'TOOLTIP.NUMBER_REQUIRED' | translate}}</clr-control-error>
@ -58,12 +58,12 @@
</clr-tooltip> </clr-tooltip>
</label> </label>
<input clrInput name="robotTokenExpiration" type="text" #robotTokenExpirationInput="ngModel" <input clrInput name="robotTokenExpiration" type="text" #robotTokenExpirationInput="ngModel"
(ngModelChange)="changeToken($event)" [(ngModel)]="robotTokenExpiration" required [(ngModel)]="robotTokenExpirationValue" required
pattern="^[1-9]{1}[0-9]*$" id="robotTokenExpiration" size="20" [disabled]="!robotExpirationEditable" /> pattern="^[1-9]{1}[0-9]*$" id="robotTokenExpiration" size="20" [disabled]="!robotExpirationEditable" />
<clr-control-error>{{'ROBOT_ACCOUNT.NUMBER_REQUIRED' | translate}}</clr-control-error> <clr-control-error>{{'ROBOT_ACCOUNT.NUMBER_REQUIRED' | translate}}</clr-control-error>
</clr-input-container> </clr-input-container>
<label *ngIf="canDownloadCert" for="certDownloadLink" <label *ngIf="canDownloadCert"
class="clr-control-label cert-down-label mt-1">{{'CONFIG.ROOT_CERT' | translate}} class="clr-control-label cert-down-label mt-1">{{'CONFIG.ROOT_CERT' | translate}}
<clr-tooltip> <clr-tooltip>
<clr-icon clrTooltipTrigger shape="info-circle" size="24"></clr-icon> <clr-icon clrTooltipTrigger shape="info-circle" size="24"></clr-icon>
@ -90,7 +90,7 @@
<div class="clr-form-control d-f"> <div class="clr-form-control d-f">
<label for="systemAllowlist" <label
class="clr-control-label">{{'CVE_ALLOWLIST.DEPLOYMENT_SECURITY'|translate}}</label> class="clr-control-label">{{'CVE_ALLOWLIST.DEPLOYMENT_SECURITY'|translate}}</label>
<div class="form-content"> <div class="form-content">
<div class="font-size-13"> <div class="font-size-13">
@ -142,8 +142,7 @@
</div> </div>
<div class="clr-col padding-top-8"> <div class="clr-col padding-top-8">
<div class="clr-row expire-data"> <div class="clr-row expire-data">
<label class="bottom-line clr-col-4" <label class="bottom-line clr-col-4">{{'CVE_ALLOWLIST.EXPIRES_AT'|translate}}</label>
for="expires">{{'CVE_ALLOWLIST.EXPIRES_AT'|translate}}</label>
<div> <div>
<input #dateInput placeholder="{{'CVE_ALLOWLIST.NEVER_EXPIRES'|translate}}" readonly <input #dateInput placeholder="{{'CVE_ALLOWLIST.NEVER_EXPIRES'|translate}}" readonly
type="date" [(clrDate)]="expiresDate" newFormLayout="true"> type="date" [(clrDate)]="expiresDate" newFormLayout="true">

View File

@ -25,8 +25,6 @@ import {
import {forkJoin} from "rxjs"; import {forkJoin} from "rxjs";
const fakePass = 'aWpLOSYkIzJTTU4wMDkx'; const fakePass = 'aWpLOSYkIzJTTU4wMDkx';
const ONE_HOUR_MINUTES: number = 60;
const ONE_DAY_MINUTES: number = 24 * ONE_HOUR_MINUTES;
const ONE_THOUSAND: number = 1000; const ONE_THOUSAND: number = 1000;
const CVE_DETAIL_PRE_URL = `https://nvd.nist.gov/vuln/detail/`; const CVE_DETAIL_PRE_URL = `https://nvd.nist.gov/vuln/detail/`;
const TARGET_BLANK = "_blank"; const TARGET_BLANK = "_blank";
@ -82,6 +80,20 @@ export class SystemSettingsComponent implements OnChanges, OnInit {
this.systemSettings.robot_token_duration.editable; this.systemSettings.robot_token_duration.editable;
} }
get tokenExpirationValue() {
return this.systemSettings.token_expiration.value;
}
set tokenExpirationValue(v) {
// convert string to number
this.systemSettings.token_expiration.value = +v;
}
get robotTokenExpirationValue() {
return this.systemSettings.robot_token_duration.value;
}
set robotTokenExpirationValue(v) {
// convert string to number
this.systemSettings.robot_token_duration.value = +v;
}
robotNamePrefixEditable(): boolean { robotNamePrefixEditable(): boolean {
return this.systemSettings && return this.systemSettings &&
this.systemSettings.robot_name_prefix && this.systemSettings.robot_name_prefix &&
@ -217,7 +229,6 @@ export class SystemSettingsComponent implements OnChanges, OnInit {
ack.state === ConfirmationState.CONFIRMED) { ack.state === ConfirmationState.CONFIRMED) {
let changes = this.getChanges(); let changes = this.getChanges();
this.reset(changes); this.reset(changes);
this.initRobotToken();
if (!compareValue(this.systemAllowlistOrigin, this.systemAllowlist)) { if (!compareValue(this.systemAllowlistOrigin, this.systemAllowlist)) {
this.systemAllowlist = clone(this.systemAllowlistOrigin); this.systemAllowlist = clone(this.systemAllowlistOrigin);
} }
@ -262,7 +273,6 @@ export class SystemSettingsComponent implements OnChanges, OnInit {
} }
ngOnInit() { ngOnInit() {
this.initRobotToken();
this.getSystemAllowlist(); this.getSystemAllowlist();
this.getSystemInfo(); this.getSystemInfo();
} }
@ -292,26 +302,6 @@ export class SystemSettingsComponent implements OnChanges, OnInit {
} }
); );
} }
private initRobotToken(): void {
if (this.config &&
this.config.robot_token_duration) {
let robotExpiration = this.config.robot_token_duration.value;
this.robotTokenExpiration = Math.floor(robotExpiration / ONE_DAY_MINUTES) + '';
}
}
changeToken(v: string) {
if (!v || v === "") {
return;
}
if (!(this.config &&
this.config.robot_token_duration)) {
return;
}
this.config.robot_token_duration.value = +v * ONE_DAY_MINUTES;
}
deleteItem(index: number) { deleteItem(index: number) {
this.systemAllowlist.items.splice(index, 1); this.systemAllowlist.items.splice(index, 1);
} }