Skip to content

Commit

Permalink
Merge branch 'main' into feat-manual-enrichment
Browse files Browse the repository at this point in the history
# Conflicts:
#	keep-ui/app/alerts/alerts.tsx
  • Loading branch information
35C4n0r committed Nov 20, 2024
2 parents 5a8c432 + 499abad commit 1a5c47a
Show file tree
Hide file tree
Showing 109 changed files with 995 additions and 575 deletions.
19 changes: 13 additions & 6 deletions docs/providers/documentation/appdynamics-provider.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -7,19 +7,26 @@ description: "AppDynamics provider allows you to get AppDynamics `alerts/actions
## Authentication Parameters
The AppDynamics provider requires the following authentication parameter:

- `AppDynamics Username`: Required. This is your AppDynamics account username.
- `AppDynamics Password`: This is the password associated with your AppDynamics Username.
- `AppDynamics Access Token`: Required if username/password is not provided for Bearer token authentication.
- `AppDynamics Username`: Required for Basic Auth authentication. This is your AppDynamics account username.
- `AppDynamics Password`: Required for Basic Auth authentication. This is the password associated with your AppDynamics Username.
- `AppDynamics Account Name`: This is your account's name.
- `App Id`: The Id of the Application in which you would like to install the webhook.
- `Host`: This is the hostname of the AppDynamics instance you wish to connect to. It identifies the AppDynamics server that the API will interact with.

## Connecting with the Provider
1. Ensure you have a AppDynamics account with the necessary [permissions](https://docs.appdynamics.com/accounts/en/cisco-appdynamics-on-premises-user-management/roles-and-permissions). The basic permissions required are `Account Owner` or `Administrator`. Alternatively you can create an account (instructions)[https://docs.appdynamics.com/accounts/en/global-account-administration/access-management/manage-user-accounts]

### Basic Auth authentication

Obtain AppDynamics Username and Password:
1. Ensure you have a AppDynamics account with the necessary [permissions](https://docs.appdynamics.com/accounts/en/cisco-appdynamics-on-premises-user-management/roles-and-permissions). The basic permissions required are `Account Owner` or `Administrator`. Alternatively you can create an account (instructions)[https://docs.appdynamics.com/accounts/en/global-account-administration/access-management/manage-user-accounts]
2. Find your account name [here](https://accounts.appdynamics.com/overview).
3. Determine the Host [here](https://accounts.appdynamics.com/overview).
4. Get the appId of the Appdynamics instance in which you wish to install the webhook into.
1. Find your account name [here](https://accounts.appdynamics.com/overview).

OR create Access Token:
1. Follow instructions [here](https://docs.appdynamics.com/appd/23.x/latest/en/extend-appdynamics/appdynamics-apis/api-clients)

1. Determine the Host [here](https://accounts.appdynamics.com/overview).
2. Get the appId of the Appdynamics instance in which you wish to install the webhook into.

## Webhook Integration Modifications

Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/ai/ai.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
"use client";
import { Card, List, ListItem, Title, Subtitle } from "@tremor/react";
import { useAIStats, usePollAILogs } from "utils/hooks/useAI";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";
import { toast } from "react-toastify";
import { useEffect, useState, useRef, FormEvent } from "react";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/ViewAlertModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import Modal from "@/components/ui/Modal"; // Ensure this path matches your proj
import { Button, Icon, Switch, Text } from "@tremor/react";
import { toast } from "react-toastify";
import { useApiUrl } from "utils/hooks/useConfig";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { XMarkIcon } from "@heroicons/react/24/outline";
import "./ViewAlertModal.css";
import React, { useState } from "react";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/[id]/page.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import AlertsPage from "../alerts.client";
import AlertsPage from "../alerts";

type PageProps = {
params: { id: string };
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-assign-ticket-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { Button, TextInput, Text } from "@tremor/react";
import { PlusIcon } from "@heroicons/react/20/solid";
import { useForm, Controller, SubmitHandler } from "react-hook-form";
import { Providers } from "./../providers/providers";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";
import { AlertDto } from "./models";
import Modal from "@/components/ui/Modal";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-associate-incident-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import Modal from "@/components/ui/Modal";
import { Button, Divider, Title } from "@tremor/react";
import Select from "@/components/ui/Select";
import { CreateOrUpdateIncidentForm } from "@/features/create-or-update-incident";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { FormEvent, useCallback, useEffect, useState } from "react";
import { toast } from "react-toastify";
import { useApiUrl } from "utils/hooks/useConfig";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-change-status-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import Select, {
import { useState } from "react";
import { AlertDto, Status } from "./models";
import { useApiUrl } from "utils/hooks/useConfig";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { toast } from "react-toastify";
import {
CheckCircleIcon,
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-create-incident-ai-modal.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React, { useState } from "react";
import Modal from "@/components/ui/Modal";
import { Callout, Button, Title, Card } from "@tremor/react";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { toast } from "react-toastify";
import Loading from "../loading";
import { AlertDto } from "./models";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-dismiss-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import "react-quill/dist/quill.snow.css";
import { AlertDto } from "./models";
import { format, set, isSameDay, isAfter, addMinutes } from "date-fns";
import { useApiUrl } from "utils/hooks/useConfig";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { usePresets } from "utils/hooks/usePresets";
import { useAlerts } from "utils/hooks/useAlerts";
import { toast } from "react-toastify";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-menu.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import {
} from "@heroicons/react/24/outline";
import { IoNotificationsOffOutline } from "react-icons/io5";

import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";
import Link from "next/link";
import { ProviderMethod } from "app/providers/providers";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-note-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ const ReactQuill =
import "react-quill/dist/quill.snow.css";
import { Button } from "@tremor/react";
import { useApiUrl } from "utils/hooks/useConfig";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { AlertDto } from "./models";
import Modal from "@/components/ui/Modal";

Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-presets.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import Modal from "@/components/ui/Modal";
import { Button, Subtitle, TextInput, Switch, Text } from "@tremor/react";
import { useApiUrl } from "utils/hooks/useConfig";
import { toast } from "react-toastify";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { usePresets } from "utils/hooks/usePresets";
import { useTags } from "utils/hooks/useTags";
import { useRouter } from "next/navigation";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-push-alert-to-server-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
FieldValues,
} from "react-hook-form";
import Modal from "@/components/ui/Modal";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";
import { useProviders } from "utils/hooks/useProviders";
import ImageWithFallback from "@/components/ImageWithFallback";
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-run-workflow-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { AlertDto } from "./models";
import Modal from "@/components/ui/Modal";
import { useWorkflows } from "utils/hooks/useWorkflows";
import { useState } from "react";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";
import { toast } from "react-toastify";
import { useRouter } from "next/navigation";
Expand Down
6 changes: 3 additions & 3 deletions keep-ui/app/alerts/alert-tab-modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useState } from "react";
import Modal from "@/components/ui/Modal";
import { Button, TextInput } from "@tremor/react";
import { AlertsRulesBuilder } from "app/alerts/alerts-rules-builder";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
import { useApiUrl } from "utils/hooks/useConfig";

interface AlertTabModalProps {
Expand Down Expand Up @@ -114,8 +114,8 @@ const AlertTabModal = ({
!newTabName
? "Tab name is required"
: !newTabFilter
? "Tab filter is required (notice you need to click 'enter' to apply the filter)"
: ""
? "Tab filter is required (notice you need to click 'enter' to apply the filter)"
: ""
}
>
Add Tab
Expand Down
11 changes: 10 additions & 1 deletion keep-ui/app/alerts/alert-table-alert-facets.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import {
AddFacetModal,
} from "./alert-table-facet-dynamic";
import { PlusIcon } from "@heroicons/react/24/outline";
import { usePathname } from "next/navigation";

export const AlertFacets: React.FC<AlertFacetsProps> = ({
alerts,
Expand All @@ -26,7 +27,9 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
onDelete,
className,
table,
showSkeleton,
}) => {
const pathname = usePathname();
const timeRangeFilter = table
.getState()
.columnFilters.find((filter) => filter.id === "lastReceived");
Expand All @@ -35,7 +38,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
| { start: Date; end: Date; isFromCalendar: boolean }
| undefined;

const presetName = window.location.pathname.split("/").pop() || "default";
const presetName = pathname?.split("/").pop() || "default";

const [isModalOpen, setIsModalOpen] = useLocalStorage<boolean>(
`addFacetModalOpen-${presetName}`,
Expand Down Expand Up @@ -207,6 +210,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
}
facetKey="severity"
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
<Facet
name="Status"
Expand All @@ -216,6 +220,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
}
facetKey="status"
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
<Facet
name="Source"
Expand All @@ -225,6 +230,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
}
facetKey="source"
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
<Facet
name="Assignee"
Expand All @@ -234,6 +240,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
}
facetKey="assignee"
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
<Facet
name="Dismissed"
Expand All @@ -243,6 +250,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
}
facetKey="dismissed"
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
<Facet
name="Incident Related"
Expand All @@ -252,6 +260,7 @@ export const AlertFacets: React.FC<AlertFacetsProps> = ({
handleSelect("incident", value, exclusive, isAllOnly)
}
facetFilters={facetFilters}
showSkeleton={showSkeleton}
/>
{/* Dynamic facets */}
{dynamicFacets.map((facet) => (
Expand Down
2 changes: 2 additions & 0 deletions keep-ui/app/alerts/alert-table-facet-types.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ export interface FacetProps {
facetKey: string;
facetFilters: FacetFilters;
showIcon?: boolean;
showSkeleton?: boolean;
}

export interface AlertFacetsProps {
Expand All @@ -44,4 +45,5 @@ export interface AlertFacetsProps {
onDelete: (facetKey: string) => void;
className?: string;
table: Table<AlertDto>;
showSkeleton?: boolean;
}
18 changes: 16 additions & 2 deletions keep-ui/app/alerts/alert-table-facet.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ import { ChevronDownIcon, ChevronRightIcon } from "@heroicons/react/20/solid";
import { FacetProps } from "./alert-table-facet-types";
import { FacetValue } from "./alert-table-facet-value";
import { useLocalStorage } from "utils/hooks/useLocalStorage";
import { usePathname } from "next/navigation";
import Skeleton from "react-loading-skeleton";

export const Facet: React.FC<FacetProps> = ({
name,
Expand All @@ -12,9 +14,11 @@ export const Facet: React.FC<FacetProps> = ({
facetKey,
facetFilters,
showIcon = true,
showSkeleton,
}) => {
const pathname = usePathname();
// Get preset name from URL
const presetName = window.location.pathname.split("/").pop() || "default";
const presetName = pathname?.split("/").pop() || "default";

// Store open/close state in localStorage with a unique key per preset and facet
const [isOpen, setIsOpen] = useLocalStorage<boolean>(
Expand Down Expand Up @@ -60,7 +64,17 @@ export const Facet: React.FC<FacetProps> = ({
</div>
)}
<div className="max-h-60 overflow-y-auto">
{values.length > 0 ? (
{showSkeleton ? (
Array.from({ length: 3 }).map((_, index) => (
<div
key={`skeleton-${index}`}
className="flex items-center px-2 py-1 gap-2"
>
<Skeleton containerClassName="h-4 w-4" />
<Skeleton containerClassName="h-4 flex-1" />
</div>
))
) : values.length > 0 ? (
filteredValues.map((value) => (
<FacetValue
key={value.label}
Expand Down
2 changes: 1 addition & 1 deletion keep-ui/app/alerts/alert-table-utils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -192,7 +192,7 @@ export const useAlertTableCols = (
? [
columnHelper.display({
id: "checkbox",
size: 10,
size: 46,
header: (context) => (
<AlertTableCheckbox
checked={context.table.getIsAllRowsSelected()}
Expand Down
19 changes: 5 additions & 14 deletions keep-ui/app/alerts/alert-table.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -250,10 +250,10 @@ export function AlertTable({
return acc.concat(alertId);
}, []);

// show skeleton if no alerts are loaded
let showSkeleton = table.getFilteredRowModel().rows.length === 0;
// if showSkeleton and not loading, show empty state
let showEmptyState = !isAsyncLoading && showSkeleton;
let showSkeleton =
table.getFilteredRowModel().rows.length === 0 && isAsyncLoading;
let showEmptyState =
table.getFilteredRowModel().rows.length === 0 && !isAsyncLoading;

const handleRowClick = (alert: AlertDto) => {
// if presetName is alert-history, do not open sidebar
Expand Down Expand Up @@ -303,21 +303,12 @@ export function AlertTable({
setDynamicFacets={setDynamicFacets}
onDelete={handleFacetDelete}
table={table}
showSkeleton={showSkeleton}
/>
</div>
<div className="flex flex-col gap-4 min-w-0">
<Card className="flex-grow h-full flex flex-col p-0">
<div className="flex-grow">
{isAsyncLoading && (
<Callout
title="Getting your alerts..."
icon={CircleStackIcon}
color="gray"
className="m-5"
>
Alerts will show up in this table as they are added to Keep...
</Callout>
)}
{/* For dynamic preset, add alert tabs*/}
{!presetStatic && (
<AlertTabs
Expand Down
14 changes: 3 additions & 11 deletions keep-ui/app/alerts/alert-tabs.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,11 @@
import { FormEventHandler, useState } from "react";
import {
Button,
TextInput,
Tab,
TabGroup,
TabList,
TabPanel,
TabPanels,
} from "@tremor/react";
import { useState } from "react";
import { Tab, TabGroup, TabList, TabPanel, TabPanels } from "@tremor/react";
import { AlertDto } from "./models";
import AlertTabModal from "./alert-tab-modal";
import { evalWithContext } from "./alerts-rules-builder";
import { XMarkIcon } from "@heroicons/react/24/outline";
import { useApiUrl } from "utils/hooks/useConfig";
import { useSession } from "next-auth/react";
import { useHydratedSession as useSession } from "@/shared/lib/hooks/useHydratedSession";
interface Tab {
id?: string;
name: string;
Expand Down
Loading

0 comments on commit 1a5c47a

Please sign in to comment.