Add basic permissions checking logic to frontend

This commit is contained in:
Dane Everitt 2020-03-28 17:25:04 -07:00
parent 7e0ac2c311
commit ab4c4e7e9e
No known key found for this signature in database
GPG key ID: EEA66103B3D71F53
4 changed files with 81 additions and 11 deletions

View file

@ -10,18 +10,30 @@ export type ServerStatus = 'offline' | 'starting' | 'stopping' | 'running';
interface ServerDataStore {
data?: Server;
permissions: string[];
getServer: Thunk<ServerDataStore, string, {}, ServerStore, Promise<void>>;
setServer: Action<ServerDataStore, Server>;
setPermissions: Action<ServerDataStore, string[]>;
}
const server: ServerDataStore = {
permissions: [],
getServer: thunk(async (actions, payload) => {
const server = await getServer(payload);
const [server, permissions] = await getServer(payload);
actions.setServer(server);
actions.setPermissions(permissions);
}),
setServer: action((state, payload) => {
state.data = payload;
}),
setPermissions: action((state, payload) => {
state.permissions = payload;
}),
};
interface ServerStatusStore {
@ -75,9 +87,9 @@ export const ServerContext = createContextStore<ServerStore>({
subusers,
clearServerState: action(state => {
state.server.data = undefined;
state.server.permissions = [];
state.databases.items = [];
state.subusers.data = [];
state.files.directory = '/';
state.files.contents = [];