Package Exports
- @memberjunction/ai-engine-base
- @memberjunction/ai-engine-base/dist/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@memberjunction/ai-engine-base) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
@memberjunction/ai-engine-base
Base AI Engine package for MemberJunction. Provides a comprehensive metadata cache for all AI-related entities -- models, vendors, prompts, agents, configurations, modalities, permissions, and more. This package extends BaseEngine to load and cache AI metadata in a single batch, making it available on both server and client without duplicating data loading logic.
Architecture
graph TD
subgraph Dependencies
CORE["@memberjunction/core<br/>BaseEngine"]
style CORE fill:#2d6a9f,stroke:#1a4971,color:#fff
CE["@memberjunction/core-entities"]
style CE fill:#2d6a9f,stroke:#1a4971,color:#fff
ACP["@memberjunction/ai-core-plus<br/>Extended Entities"]
style ACP fill:#2d6a9f,stroke:#1a4971,color:#fff
end
AIB["AIEngineBase<br/>Singleton Metadata Cache"]
style AIB fill:#2d8659,stroke:#1a5c3a,color:#fff
subgraph "Cached Metadata"
M["Models & Model Types"]
style M fill:#7c5295,stroke:#563a6b,color:#fff
V["Vendors & Model Vendors"]
style V fill:#7c5295,stroke:#563a6b,color:#fff
P["Prompts, Categories & Types"]
style P fill:#7c5295,stroke:#563a6b,color:#fff
A["Agents, Types & Relationships"]
style A fill:#7c5295,stroke:#563a6b,color:#fff
CFG["Configurations & Params"]
style CFG fill:#b8762f,stroke:#8a5722,color:#fff
MOD["Modalities & Limits"]
style MOD fill:#b8762f,stroke:#8a5722,color:#fff
PERM["Permissions & Credentials"]
style PERM fill:#b8762f,stroke:#8a5722,color:#fff
end
CORE --> AIB
CE --> AIB
ACP --> AIB
AIB --> M
AIB --> V
AIB --> P
AIB --> A
AIB --> CFG
AIB --> MOD
AIB --> PERM
SRV["AIEngine (Server)"]
style SRV fill:#2d6a9f,stroke:#1a4971,color:#fff
AIB --> SRVInstallation
npm install @memberjunction/ai-engine-baseKey Exports
AIEngineBase (Singleton)
The core class that loads and caches all AI metadata. Access via AIEngineBase.Instance.
import { AIEngineBase } from '@memberjunction/ai-engine-base';
// Initialize (typically at app startup)
await AIEngineBase.Instance.Config(false, contextUser);
// Access cached metadata
const models = AIEngineBase.Instance.Models;
const agents = AIEngineBase.Instance.Agents;
const prompts = AIEngineBase.Instance.Prompts;Cached Entity Collections
| Property | Entity | Description |
|---|---|---|
Models |
AI Models | All registered AI models with extended properties |
ModelTypes |
AI Model Types | Model type categories (LLM, Embeddings, etc.) |
Vendors |
MJ: AI Vendors | AI service providers |
ModelVendors |
MJ: AI Model Vendors | Model-vendor associations |
Prompts |
AI Prompts | All prompt definitions with category associations |
PromptModels |
MJ: AI Prompt Models | Prompt-model associations |
PromptTypes |
AI Prompt Types | Prompt type categories |
PromptCategories |
AI Prompt Categories | Hierarchical prompt organization |
Agents |
AI Agents | All agent definitions with actions and notes |
AgentTypes |
MJ: AI Agent Types | Agent type definitions |
AgentActions |
AI Agent Actions | Actions associated with agents |
AgentPrompts |
MJ: AI Agent Prompts | Prompts associated with agents |
AgentSteps |
MJ: AI Agent Steps | Flow agent step definitions |
AgentStepPaths |
MJ: AI Agent Step Paths | Transitions between flow steps |
AgentRelationships |
MJ: AI Agent Relationships | Sub-agent relationships |
AgentPermissions |
MJ: AI Agent Permissions | User/role permission grants |
AgentConfigurations |
MJ: AI Agent Configurations | Semantic presets (Fast, High Quality) |
Configurations |
MJ: AI Configurations | Global AI configurations with inheritance |
ConfigurationParams |
MJ: AI Configuration Params | Key-value parameters for configurations |
ModelCosts |
MJ: AI Model Costs | Cost tracking per model/vendor |
ModelPriceTypes |
MJ: AI Model Price Types | Price type definitions |
ModelPriceUnitTypes |
MJ: AI Model Price Unit Types | Unit type definitions |
CredentialBindings |
MJ: AI Credential Bindings | Credential bindings for vendors/models |
Modalities |
MJ: AI Modalities | Input/output modality definitions |
AgentModalities |
MJ: AI Agent Modalities | Agent modality support |
ModelModalities |
MJ: AI Model Modalities | Model modality support |
VectorDatabases |
Vector Databases | Vector database configurations |
ArtifactTypes |
MJ: Artifact Types | Artifact type definitions |
Convenience Methods
// Get the highest-power model of a given type
const bestLLM = await AIEngineBase.Instance.GetHighestPowerLLM('OpenAI', contextUser);
const bestEmbedding = await AIEngineBase.Instance.GetHighestPowerModel('OpenAI', 'Embeddings', contextUser);
// Get agent by name
const agent = AIEngineBase.Instance.GetAgentByName('Customer Support Agent');
// Get sub-agents (children + relationships)
const subAgents = AIEngineBase.Instance.GetSubAgents(agentId, 'Active');
// Configuration presets
const presets = AIEngineBase.Instance.GetAgentConfigurationPresets(agentId);
const defaultPreset = AIEngineBase.Instance.GetDefaultAgentConfigurationPreset(agentId);Configuration Inheritance
Configurations support parent-child inheritance chains:
// Get the full inheritance chain (child -> parent -> grandparent)
const chain = AIEngineBase.Instance.GetConfigurationChain(configId);
// Get parameters with inheritance (child overrides parent)
const params = AIEngineBase.Instance.GetConfigurationParamsWithInheritance(configId);Model Cost Tracking
// Get active cost for a model/vendor combination
const cost = AIEngineBase.Instance.GetActiveModelCost(modelId, vendorId, 'Realtime');Credential Bindings
// Get credential bindings for a vendor
const bindings = AIEngineBase.Instance.GetCredentialBindingsForTarget('Vendor', vendorId);
// Check if bindings exist
const hasBindings = AIEngineBase.Instance.HasCredentialBindings('ModelVendor', modelVendorId);Modality System
The modality system tracks which input/output types (Text, Image, Audio, Video, File) agents and models support.
// Check if an agent supports image input
const supportsImages = AIEngineBase.Instance.AgentSupportsModality(agentId, 'Image', 'Input');
// Check if agent accepts any attachments
const supportsAttachments = AIEngineBase.Instance.AgentSupportsAttachments(agentId);
// Get aggregated attachment limits for UI configuration
const limits = AIEngineBase.Instance.GetAgentAttachmentLimits(agentId, modelId);
// limits.enabled, limits.maxAttachments, limits.maxAttachmentSizeBytes, limits.acceptedFileTypesAgent Permission Helper
// Check individual permissions
const canView = await AIEngineBase.Instance.CanUserViewAgent(agentId, user);
const canRun = await AIEngineBase.Instance.CanUserRunAgent(agentId, user);
// Get all permissions at once
const perms = await AIEngineBase.Instance.GetUserAgentPermissions(agentId, user);
// perms.canView, perms.canRun, perms.canEdit, perms.canDelete, perms.isOwner
// Get all accessible agents for a user
const agents = await AIEngineBase.Instance.GetAccessibleAgents(user, 'run');Additional Exports
| Export | Purpose |
|---|---|
ModalityLimits |
Resolved limits for a specific modality (size, count, dimension, formats) |
AgentAttachmentLimits |
Aggregated attachment limits for UI components |
PriceUnitTypes |
Price unit type utilities |
AIAgentPermissionHelper |
Static helper for agent permission checks |
EffectiveAgentPermissions |
Complete permission set for a user/agent combination |
AICredentialBindingEntityExtended |
Extended credential binding entity |
Dependencies
@memberjunction/core-- BaseEngine, Metadata, RunView@memberjunction/core-entities-- Generated entity classes@memberjunction/ai-- Core AI abstractions@memberjunction/ai-core-plus-- Extended entity classes@memberjunction/global-- Class factory@memberjunction/templates-base-types-- Template engine integration