Add capability checking to secret engine buttons.
This commit is contained in:
parent
df796d3506
commit
5b0b0496be
|
@ -2,6 +2,7 @@ import { Component, JSX, render } from "preact";
|
||||||
import { DoesNotExistError } from "../../../types/internalErrors";
|
import { DoesNotExistError } from "../../../types/internalErrors";
|
||||||
import { Page } from "../../../types/Page";
|
import { Page } from "../../../types/Page";
|
||||||
import { SecretTitleElement } from "../SecretTitleElement";
|
import { SecretTitleElement } from "../SecretTitleElement";
|
||||||
|
import { getCapabilitiesPath } from "../../../api/sys/getCapabilities";
|
||||||
import { getSecrets } from "../../../api/kv/getSecrets";
|
import { getSecrets } from "../../../api/kv/getSecrets";
|
||||||
import { setErrorText } from "../../../pageUtils";
|
import { setErrorText } from "../../../pageUtils";
|
||||||
import i18next from "i18next";
|
import i18next from "i18next";
|
||||||
|
@ -124,18 +125,22 @@ export class KeyValueViewPage extends Page {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
async render(): Promise<void> {
|
async render(): Promise<void> {
|
||||||
|
const caps = (await getCapabilitiesPath("/sys/mounts/" + this.state.baseMount)).capabilities;
|
||||||
|
|
||||||
render(
|
render(
|
||||||
<>
|
<>
|
||||||
<p>
|
<p>
|
||||||
<button
|
{caps.includes("create") && (
|
||||||
class="uk-button uk-button-primary"
|
<button
|
||||||
onClick={async () => {
|
class="uk-button uk-button-primary"
|
||||||
await this.router.changePage("KEY_VALUE_NEW_SECRET");
|
onClick={async () => {
|
||||||
}}
|
await this.router.changePage("KEY_VALUE_NEW_SECRET");
|
||||||
>
|
}}
|
||||||
{i18next.t("kv_view_new_btn")}
|
>
|
||||||
</button>
|
{i18next.t("kv_view_new_btn")}
|
||||||
{this.state.secretPath.length == 0 && (
|
</button>
|
||||||
|
)}
|
||||||
|
{this.state.secretPath.length == 0 && caps.includes("delete") && (
|
||||||
<button
|
<button
|
||||||
class="uk-button uk-button-danger"
|
class="uk-button uk-button-danger"
|
||||||
onClick={async () => {
|
onClick={async () => {
|
||||||
|
|
|
@ -79,25 +79,32 @@ export class TOTPViewPage extends Page {
|
||||||
|
|
||||||
async render(): Promise<void> {
|
async render(): Promise<void> {
|
||||||
this.state.secretItem = "";
|
this.state.secretItem = "";
|
||||||
|
|
||||||
|
const caps = (await getCapabilitiesPath("/sys/mounts/" + this.state.baseMount)).capabilities;
|
||||||
|
|
||||||
render(
|
render(
|
||||||
<div>
|
<div>
|
||||||
<p>
|
<p>
|
||||||
<button
|
{caps.includes("create") && (
|
||||||
class="uk-button uk-button-primary"
|
<button
|
||||||
onClick={async () => {
|
class="uk-button uk-button-primary"
|
||||||
await this.router.changePage("TOTP_NEW");
|
onClick={async () => {
|
||||||
}}
|
await this.router.changePage("TOTP_NEW");
|
||||||
>
|
}}
|
||||||
{i18next.t("totp_view_new_btn")}
|
>
|
||||||
</button>
|
{i18next.t("totp_view_new_btn")}
|
||||||
<button
|
</button>
|
||||||
class="uk-button uk-button-danger"
|
)}
|
||||||
onClick={async () => {
|
{caps.includes("delete") && (
|
||||||
await this.router.changePage("DELETE_SECRET_ENGINE");
|
<button
|
||||||
}}
|
class="uk-button uk-button-danger"
|
||||||
>
|
onClick={async () => {
|
||||||
{i18next.t("totp_view_delete_btn")}
|
await this.router.changePage("DELETE_SECRET_ENGINE");
|
||||||
</button>
|
}}
|
||||||
|
>
|
||||||
|
{i18next.t("totp_view_delete_btn")}
|
||||||
|
</button>
|
||||||
|
)}
|
||||||
</p>
|
</p>
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import { Component, JSX, render } from "preact";
|
import { Component, JSX, render } from "preact";
|
||||||
import { Page } from "../../../types/Page";
|
import { Page } from "../../../types/Page";
|
||||||
import { SecretTitleElement } from "../SecretTitleElement";
|
import { SecretTitleElement } from "../SecretTitleElement";
|
||||||
|
import { getCapabilitiesPath } from "../../../api/sys/getCapabilities";
|
||||||
import { getTransitKeys } from "../../../api/transit/getTransitKeys";
|
import { getTransitKeys } from "../../../api/transit/getTransitKeys";
|
||||||
import i18next from "i18next";
|
import i18next from "i18next";
|
||||||
|
|
||||||
|
@ -79,25 +80,32 @@ export class TransitViewPage extends Page {
|
||||||
|
|
||||||
async render(): Promise<void> {
|
async render(): Promise<void> {
|
||||||
this.state.secretItem = "";
|
this.state.secretItem = "";
|
||||||
|
|
||||||
|
const caps = (await getCapabilitiesPath("/sys/mounts/" + this.state.baseMount)).capabilities;
|
||||||
|
|
||||||
render(
|
render(
|
||||||
<>
|
<>
|
||||||
<p>
|
<p>
|
||||||
<button
|
{caps.includes("create") && (
|
||||||
class="uk-button uk-button-primary"
|
<button
|
||||||
onClick={async () => {
|
class="uk-button uk-button-primary"
|
||||||
await this.router.changePage("TRANSIT_NEW_KEY");
|
onClick={async () => {
|
||||||
}}
|
await this.router.changePage("TRANSIT_NEW_KEY");
|
||||||
>
|
}}
|
||||||
{i18next.t("transit_view_new_btn")}
|
>
|
||||||
</button>
|
{i18next.t("transit_view_new_btn")}
|
||||||
<button
|
</button>
|
||||||
class="uk-button uk-button-danger"
|
)}
|
||||||
onClick={async () => {
|
{caps.includes("delete") && (
|
||||||
await this.router.changePage("DELETE_SECRET_ENGINE");
|
<button
|
||||||
}}
|
class="uk-button uk-button-danger"
|
||||||
>
|
onClick={async () => {
|
||||||
{i18next.t("transit_view_delete_btn")}
|
await this.router.changePage("DELETE_SECRET_ENGINE");
|
||||||
</button>
|
}}
|
||||||
|
>
|
||||||
|
{i18next.t("transit_view_delete_btn")}
|
||||||
|
</button>
|
||||||
|
)}
|
||||||
</p>
|
</p>
|
||||||
<TransitViewListItem page={this} />
|
<TransitViewListItem page={this} />
|
||||||
</>,
|
</>,
|
||||||
|
|
Loading…
Reference in a new issue