Merge pull request #9864 from Budibase/fix/audit-log-fixes

Audit logs fixes
This commit is contained in:
Michael Drury 2023-03-02 15:08:20 +00:00 committed by GitHub
commit ae28523732
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 40 additions and 19 deletions

View File

@ -1,6 +1,6 @@
import { getAppClient } from "../redis/init" import { getAppClient } from "../redis/init"
import { doWithDB, DocumentType } from "../db" import { doWithDB, DocumentType } from "../db"
import { Database } from "@budibase/types" import { Database, App } from "@budibase/types"
const AppState = { const AppState = {
INVALID: "invalid", INVALID: "invalid",
@ -65,7 +65,7 @@ export async function getAppMetadata(appId: string) {
if (isInvalid(metadata)) { if (isInvalid(metadata)) {
throw { status: 404, message: "No app metadata found" } throw { status: 404, message: "No app metadata found" }
} }
return metadata return metadata as App
} }
/** /**

View File

@ -8,7 +8,7 @@ import {
HostInfo, HostInfo,
} from "@budibase/types" } from "@budibase/types"
import { EventProcessor } from "./types" import { EventProcessor } from "./types"
import { getAppId, doInTenant } from "../../context" import { getAppId, doInTenant, getTenantId } from "../../context"
import BullQueue from "bull" import BullQueue from "bull"
import { createQueue, JobQueue } from "../../queue" import { createQueue, JobQueue } from "../../queue"
import { isAudited } from "../../utils" import { isAudited } from "../../utils"
@ -74,7 +74,7 @@ export default class AuditLogsProcessor implements EventProcessor {
appId: getAppId(), appId: getAppId(),
hostInfo: identity.hostInfo, hostInfo: identity.hostInfo,
}, },
tenantId: identity.tenantId!, tenantId: getTenantId(),
}) })
} }
} }

View File

@ -15,6 +15,7 @@
export let sort = false export let sort = false
export let autoWidth = false export let autoWidth = false
export let fetchTerm = null export let fetchTerm = null
export let useFetch = false
export let customPopoverHeight export let customPopoverHeight
const dispatch = createEventDispatcher() const dispatch = createEventDispatcher()
@ -86,6 +87,7 @@
isPlaceholder={!value?.length} isPlaceholder={!value?.length}
{autocomplete} {autocomplete}
bind:fetchTerm bind:fetchTerm
{useFetch}
{isOptionSelected} {isOptionSelected}
{getOptionLabel} {getOptionLabel}
{getOptionValue} {getOptionValue}

View File

@ -33,6 +33,7 @@
export let autocomplete = false export let autocomplete = false
export let sort = false export let sort = false
export let fetchTerm = null export let fetchTerm = null
export let useFetch = false
export let customPopoverHeight export let customPopoverHeight
export let align = "left" export let align = "left"
export let footer = null export let footer = null
@ -150,9 +151,9 @@
> >
{#if autocomplete} {#if autocomplete}
<Search <Search
value={fetchTerm ? fetchTerm : searchTerm} value={useFetch ? fetchTerm : searchTerm}
on:change={event => on:change={event =>
fetchTerm ? (fetchTerm = event.detail) : (searchTerm = event.detail)} useFetch ? (fetchTerm = event.detail) : (searchTerm = event.detail)}
{disabled} {disabled}
placeholder="Search" placeholder="Search"
/> />

View File

@ -17,6 +17,7 @@
export let autoWidth = false export let autoWidth = false
export let autocomplete = false export let autocomplete = false
export let fetchTerm = null export let fetchTerm = null
export let useFetch = false
export let customPopoverHeight export let customPopoverHeight
const dispatch = createEventDispatcher() const dispatch = createEventDispatcher()
@ -41,6 +42,7 @@
{autocomplete} {autocomplete}
{customPopoverHeight} {customPopoverHeight}
bind:fetchTerm bind:fetchTerm
{useFetch}
on:change={onChange} on:change={onChange}
on:click on:click
/> />

View File

@ -12,18 +12,20 @@
} }
</script> </script>
<div {#if row?.user?.email}
class="container" <div
on:mouseover={() => (showTooltip = true)} class="container"
on:focus={() => (showTooltip = true)} on:mouseover={() => (showTooltip = true)}
on:mouseleave={() => (showTooltip = false)} on:focus={() => (showTooltip = true)}
> on:mouseleave={() => (showTooltip = false)}
<Avatar size="M" initials={getInitials(row?.user)} /> >
</div> <Avatar size="M" initials={getInitials(row.user)} />
{#if showTooltip}
<div class="tooltip">
<Tooltip textWrapping text={row?.user.email} direction="bottom" />
</div> </div>
{#if showTooltip}
<div class="tooltip">
<Tooltip textWrapping text={row.user.email} direction="bottom" />
</div>
{/if}
{/if} {/if}
<style> <style>

View File

@ -257,6 +257,7 @@
<div class="select"> <div class="select">
<Multiselect <Multiselect
bind:fetchTerm={userSearchTerm} bind:fetchTerm={userSearchTerm}
useFetch
placeholder="All users" placeholder="All users"
label="Users" label="Users"
autocomplete autocomplete

View File

@ -26,9 +26,16 @@ export enum AuditLogResourceStatus {
DELETED = "deleted", DELETED = "deleted",
} }
export type DeletedResourceInfo = {
_id: string
status: AuditLogResourceStatus
email?: string
name?: string
}
export interface AuditLogEnriched { export interface AuditLogEnriched {
app?: App | { _id: string; status: AuditLogResourceStatus } app?: App | DeletedResourceInfo
user: User | { _id: string; status: AuditLogResourceStatus } user: User | DeletedResourceInfo
event: Event event: Event
timestamp: string timestamp: string
name: string name: string

View File

@ -3,6 +3,11 @@ import { Event } from "../../sdk"
export const AuditLogSystemUser = "SYSTEM" export const AuditLogSystemUser = "SYSTEM"
export type FallbackInfo = {
appName?: string
email?: string
}
export interface AuditLogDoc extends Document { export interface AuditLogDoc extends Document {
appId?: string appId?: string
event: Event event: Event
@ -10,4 +15,5 @@ export interface AuditLogDoc extends Document {
timestamp: string timestamp: string
metadata: any metadata: any
name: string name: string
fallback?: FallbackInfo
} }