mirror of
https://github.com/openziti/zrok.git
synced 2025-06-25 12:12:32 +02:00
mode releaseAccess logic into ReleaseAccessModal (#822)
This commit is contained in:
parent
a6bd6828fe
commit
7df7141ac8
@ -25,24 +25,6 @@ const AccessPanel = ({ access }: AccessPanelProps) => {
|
|||||||
setReleaseAccessOpen(false);
|
setReleaseAccessOpen(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
const releaseAccess = () => {
|
|
||||||
if(detail && detail.token) {
|
|
||||||
let cfg = new Configuration({
|
|
||||||
headers: {
|
|
||||||
"X-TOKEN": user.token
|
|
||||||
}
|
|
||||||
});
|
|
||||||
let shareApi = new ShareApi(cfg);
|
|
||||||
shareApi.unaccess({body: {frontendToken: detail.token, envZId: access.data.envZId as string, shrToken: detail.shrToken}})
|
|
||||||
.then(d => {
|
|
||||||
setReleaseAccessOpen(false);
|
|
||||||
})
|
|
||||||
.catch(e => {
|
|
||||||
console.log("releaseAccess", e);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
let cfg = new Configuration({
|
let cfg = new Configuration({
|
||||||
headers: {
|
headers: {
|
||||||
@ -98,7 +80,7 @@ const AccessPanel = ({ access }: AccessPanelProps) => {
|
|||||||
</Grid2>
|
</Grid2>
|
||||||
</Grid2>
|
</Grid2>
|
||||||
</Typography>
|
</Typography>
|
||||||
<ReleaseAccessModal close={closeReleaseAccess} isOpen={releaseAccessOpen} detail={detail} action={releaseAccess} />
|
<ReleaseAccessModal close={closeReleaseAccess} isOpen={releaseAccessOpen} user={user} access={access} detail={detail} />
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,19 @@
|
|||||||
import {Frontend} from "./api";
|
import {Configuration, Frontend, ShareApi} from "./api";
|
||||||
import {useEffect, useRef, useState} from "react";
|
import {useEffect, useRef, useState} from "react";
|
||||||
import {Box, Button, Checkbox, FormControlLabel, Grid2, Modal, Typography} from "@mui/material";
|
import {Box, Button, Checkbox, FormControlLabel, Grid2, Modal, Typography} from "@mui/material";
|
||||||
import {modalStyle} from "./styling/theme.ts";
|
import {modalStyle} from "./styling/theme.ts";
|
||||||
|
import {User} from "./model/user.ts";
|
||||||
|
import {Node} from "@xyflow/react";
|
||||||
|
|
||||||
interface ReleaseAccessProps {
|
interface ReleaseAccessProps {
|
||||||
close: () => void;
|
close: () => void;
|
||||||
isOpen: boolean;
|
isOpen: boolean;
|
||||||
|
user: User;
|
||||||
|
access: Node;
|
||||||
detail: Frontend;
|
detail: Frontend;
|
||||||
action: () => void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const ReleaseAccessModal = ({ close, isOpen, detail, action }: ReleaseAccessProps) => {
|
const ReleaseAccessModal = ({ close, isOpen, user, access, detail }: ReleaseAccessProps) => {
|
||||||
const [feToken, setFeToken] = useState<String>("");
|
const [feToken, setFeToken] = useState<String>("");
|
||||||
const [checked, setChecked] = useState<boolean>(false);
|
const [checked, setChecked] = useState<boolean>(false);
|
||||||
const checkedRef = useRef<boolean>(checked);
|
const checkedRef = useRef<boolean>(checked);
|
||||||
@ -29,6 +32,26 @@ const ReleaseAccessModal = ({ close, isOpen, detail, action }: ReleaseAccessProp
|
|||||||
}
|
}
|
||||||
}, [detail]);
|
}, [detail]);
|
||||||
|
|
||||||
|
const releaseAccess = () => {
|
||||||
|
if(detail && detail.token) {
|
||||||
|
let cfg = new Configuration({
|
||||||
|
headers: {
|
||||||
|
"X-TOKEN": user.token
|
||||||
|
}
|
||||||
|
});
|
||||||
|
let shareApi = new ShareApi(cfg);
|
||||||
|
shareApi.unaccess({body: {frontendToken: detail.token, envZId: access.data.envZId as string, shrToken: detail.shrToken}})
|
||||||
|
.then(d => {
|
||||||
|
close();
|
||||||
|
})
|
||||||
|
.catch(e => {
|
||||||
|
e.response.json().then(ex => {
|
||||||
|
console.log("releaseAccess", ex.message);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Modal open={isOpen} onClose={close}>
|
<Modal open={isOpen} onClose={close}>
|
||||||
<Box sx={{ ...modalStyle }}>
|
<Box sx={{ ...modalStyle }}>
|
||||||
@ -42,7 +65,7 @@ const ReleaseAccessModal = ({ close, isOpen, detail, action }: ReleaseAccessProp
|
|||||||
<FormControlLabel control={<Checkbox checked={checked} onChange={toggleChecked} />} label={<p>I confirm the release of <code>{feToken}</code></p>} sx={{ mt: 2 }} />
|
<FormControlLabel control={<Checkbox checked={checked} onChange={toggleChecked} />} label={<p>I confirm the release of <code>{feToken}</code></p>} sx={{ mt: 2 }} />
|
||||||
</Grid2>
|
</Grid2>
|
||||||
<Grid2 container sx={{ flexGrow: 1 }} alignItems="center">
|
<Grid2 container sx={{ flexGrow: 1 }} alignItems="center">
|
||||||
<Button color="error" variant="contained" disabled={!checked} onClick={action}>Release</Button>
|
<Button color="error" variant="contained" disabled={!checked} onClick={releaseAccess}>Release</Button>
|
||||||
</Grid2>
|
</Grid2>
|
||||||
</Box>
|
</Box>
|
||||||
</Modal>
|
</Modal>
|
||||||
|
@ -49,7 +49,7 @@ const ReleaseEnvironmentModal = ({ close, isOpen, user, environment, detail }: R
|
|||||||
.catch(e => {
|
.catch(e => {
|
||||||
e.response.json().then(ex => {
|
e.response.json().then(ex => {
|
||||||
console.log("releaseEnvironment", ex.message);
|
console.log("releaseEnvironment", ex.message);
|
||||||
})
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,9 @@ const ReleaseShareModal = ({ close, isOpen, user, share, detail }: ReleaseShareP
|
|||||||
close();
|
close();
|
||||||
})
|
})
|
||||||
.catch(e => {
|
.catch(e => {
|
||||||
console.log("releaseShare", e);
|
e.response.json().then(ex => {
|
||||||
|
console.log("releaseShare", ex.message);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user