Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
8598122
Feature: Add permissions display to Feast UI lineage visualization
devin-ai-integration[bot] May 3, 2025
8d947de
Format code with Prettier
devin-ai-integration[bot] May 4, 2025
fc1ea5c
Fix TypeScript errors in getEntityPermissions function
devin-ai-integration[bot] May 4, 2025
52a6e0c
Add permissions for zipcode_features, zipcode_source, and model_v1
devin-ai-integration[bot] May 4, 2025
15eeab0
Add permissions page and display permissions on feature service page
devin-ai-integration[bot] May 4, 2025
74f5448
Add mock permissions data for development
devin-ai-integration[bot] May 4, 2025
bf21399
Add permissions display to feature view pages
devin-ai-integration[bot] May 4, 2025
d550f4e
Add permissions display to entity pages
devin-ai-integration[bot] May 4, 2025
3211d58
Add permissions display to data source pages
devin-ai-integration[bot] May 4, 2025
5ed769f
Fix permissions implementation with separate apply_permissions.py script
devin-ai-integration[bot] May 4, 2025
f6c9624
Fix: Comment out NPM_TOKEN requirement in .npmrc for easier local dev…
devin-ai-integration[bot] May 4, 2025
f476a69
Fix: Add permissions display to features page and fix icon loading er…
devin-ai-integration[bot] May 4, 2025
2e15860
Update: EUI package to fix icon loading errors
devin-ai-integration[bot] May 4, 2025
ca8292b
Fix: Remove theme import to resolve icon loading errors
devin-ai-integration[bot] May 4, 2025
7f48e99
Fix: Update package dependencies to resolve icon loading errors
devin-ai-integration[bot] May 4, 2025
4fded55
Add Home | Lineage link and update permission utils
devin-ai-integration[bot] May 4, 2025
faed8d8
Add RAG project with feature views and permissions
devin-ai-integration[bot] May 4, 2025
8a38cfd
Update feature_store.yaml for RAG project
devin-ai-integration[bot] May 4, 2025
0c0d27d
Update: Move Home and Lineage links to sidebar navigation
devin-ai-integration[bot] May 4, 2025
6f5fd5e
Update: Remove Home | Lineage links from top of page
devin-ai-integration[bot] May 4, 2025
0b80676
Add: RAG data files for document embeddings and metadata
devin-ai-integration[bot] May 4, 2025
6d0d655
Fix: Update sidebar navigation to show Home | Lineage as a single item
devin-ai-integration[bot] May 4, 2025
2c3b195
Fix: Update Home | Lineage navigation to appear as a single line with…
devin-ai-integration[bot] May 4, 2025
e966f07
Fix: Update sidebar navigation to fix React Hook error
devin-ai-integration[bot] May 4, 2025
ccdf949
Fix: Update Lineage link to use feature service demo tab URL format
devin-ai-integration[bot] May 4, 2025
88c50de
Fix: Update Lineage link to properly redirect to the lineage tab
devin-ai-integration[bot] May 4, 2025
f211d2a
Update: Add data files to .gitignore
devin-ai-integration[bot] May 4, 2025
3c84796
Update: Move Lineage to its own page under Resources in sidebar
devin-ai-integration[bot] May 4, 2025
859b957
Update: Remove Home hyperlink and Lineage tab from home page
devin-ai-integration[bot] May 4, 2025
c7dfb24
Format: Run yarn format to ensure code follows project standards
devin-ai-integration[bot] May 4, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Format code with Prettier
Co-Authored-By: Francisco Javier Arceo <arceofrancisco@gmail.com>
  • Loading branch information
commit 8d947dea28e051d6f29046bc579e333903c7f5a6
93 changes: 57 additions & 36 deletions ui/src/components/RegistryVisualization.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,21 @@ import {
} from "reactflow";
import "reactflow/dist/style.css";
import dagre from "dagre";
import { EuiPanel, EuiTitle, EuiSpacer, EuiLoadingSpinner, EuiToolTip } from "@elastic/eui";
import {
EuiPanel,
EuiTitle,
EuiSpacer,
EuiLoadingSpinner,
EuiToolTip,
} from "@elastic/eui";
import { FEAST_FCO_TYPES } from "../parsers/types";
import { EntityRelation } from "../parsers/parseEntityRelationships";
import { feast } from "../protos";
import { useTheme } from "../contexts/ThemeContext";
import { formatPermissions, getEntityPermissions } from "../utils/permissionUtils";
import {
formatPermissions,
getEntityPermissions,
} from "../utils/permissionUtils";

const edgeAnimationStyle = `
@keyframes dashdraw {
Expand Down Expand Up @@ -132,8 +141,8 @@ const CustomNode = ({ data }: { data: NodeData }) => {
navigate(path);
};

const permissionsTooltipContent = hasPermissions
? formatPermissions(data.permissions)
const permissionsTooltipContent = hasPermissions
? formatPermissions(data.permissions)
: "No permissions set";

return (
Expand Down Expand Up @@ -472,7 +481,7 @@ const Legend = () => {
const registryToFlow = (
objects: feast.core.Registry,
relationships: EntityRelation[],
permissions?: any[]
permissions?: any[],
) => {
const nodes: Node[] = [];
const edges: Edge[] = [];
Expand All @@ -485,11 +494,13 @@ const registryToFlow = (
label: fs.spec?.name,
type: FEAST_FCO_TYPES.featureService,
metadata: fs,
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureService,
fs.spec?.name
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureService,
fs.spec?.name,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand All @@ -503,11 +514,13 @@ const registryToFlow = (
label: fv.spec?.name,
type: FEAST_FCO_TYPES.featureView,
metadata: fv,
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
fv.spec?.name
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
fv.spec?.name,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand All @@ -521,11 +534,13 @@ const registryToFlow = (
label: odfv.spec?.name,
type: FEAST_FCO_TYPES.featureView,
metadata: odfv,
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
odfv.spec?.name
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
odfv.spec?.name,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand All @@ -539,11 +554,13 @@ const registryToFlow = (
label: sfv.spec?.name,
type: FEAST_FCO_TYPES.featureView,
metadata: sfv,
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
sfv.spec?.name
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.featureView,
sfv.spec?.name,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand All @@ -557,11 +574,13 @@ const registryToFlow = (
label: entity.spec?.name,
type: FEAST_FCO_TYPES.entity,
metadata: entity,
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.entity,
entity.spec?.name
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.entity,
entity.spec?.name,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand Down Expand Up @@ -592,11 +611,13 @@ const registryToFlow = (
label: dsName,
type: FEAST_FCO_TYPES.dataSource,
metadata: { name: dsName },
permissions: permissions ? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.dataSource,
dsName
) : [],
permissions: permissions
? getEntityPermissions(
permissions,
FEAST_FCO_TYPES.dataSource,
dsName,
)
: [],
},
position: { x: 0, y: 0 },
});
Expand Down Expand Up @@ -732,7 +753,7 @@ const RegistryVisualization: React.FC<RegistryVisualizationProps> = ({
const { nodes: initialNodes, edges: initialEdges } = registryToFlow(
registryData,
validRelationships,
permissions
permissions,
);

const { nodes: layoutedNodes, edges: layoutedEdges } =
Expand Down
5 changes: 4 additions & 1 deletion ui/src/components/RegistryVisualizationTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,10 @@ const RegistryVisualizationTab = () => {
indirectRelationships={data.indirectRelationships}
permissions={
selectedPermissionAction
? filterPermissionsByAction(data.permissions, selectedPermissionAction)
? filterPermissionsByAction(
data.permissions,
selectedPermissionAction,
)
: data.permissions
}
filterNode={
Expand Down
8 changes: 4 additions & 4 deletions ui/src/utils/permissionUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,15 @@ import { feast } from "../protos";
export const getEntityPermissions = (
permissions: any[] | undefined,
entityType: FEAST_FCO_TYPES,
entityName: string
entityName: string,
): any[] => {
if (!permissions || permissions.length === 0) {
return [];
}

return permissions.filter((permission) => {
const matchesType = permission.spec?.types?.includes(
getPermissionType(entityType)
getPermissionType(entityType),
);

const matchesName =
Expand Down Expand Up @@ -96,15 +96,15 @@ const getActionName = (action: number): string => {
*/
export const filterPermissionsByAction = (
permissions: any[] | undefined,
action: string
action: string,
): any[] => {
if (!permissions || permissions.length === 0) {
return [];
}

return permissions.filter((permission) => {
return permission.spec?.actions?.some(
(a: number) => getActionName(a) === action
(a: number) => getActionName(a) === action,
);
});
};