NeuroLink supports multiple AI providers with flexible authentication methods. This guide covers complete setup for all supported providers.
- OpenAI - GPT-4o, GPT-4o-mini, GPT-4-turbo
- Amazon Bedrock - Claude 3.7 Sonnet, Claude 3.5 Sonnet, Claude 3 Haiku
- Amazon SageMaker - Custom models deployed on SageMaker endpoints
- Google Vertex AI - Gemini 3 Flash/Pro (preview), Gemini 2.5 Flash, Claude 4.0 Sonnet
- Google AI Studio - Gemini 1.5 Pro, Gemini 2.0 Flash, Gemini 1.5 Flash
- Anthropic - Claude 4.5 Opus/Sonnet/Haiku, Claude 4.0 Opus/Sonnet, Claude 3.7 Sonnet
- Azure OpenAI - GPT-4, GPT-3.5-Turbo
- LiteLLM - 100+ models from all providers via proxy server
- Hugging Face - 100,000+ open source models including DialoGPT, GPT-2, GPT-Neo
- Ollama - Local AI models including Llama 2, Code Llama, Mistral, Vicuna
- Mistral AI - Mistral Tiny, Small, Medium, and Large models
Important Notes:
- Model Availability: Specific models may not be available in all regions or require special access
- Cost Variations: Pricing differs significantly between providers and models (e.g., Claude 3.5 Sonnet vs GPT-4o)
- Rate Limits: Each provider has different rate limits and quota restrictions
- Local vs Cloud: Ollama (local) has no per-request cost but requires hardware resources
- Enterprise Tiers: AWS Bedrock, Google Vertex AI, and Azure typically offer enterprise pricing
Best Practices:
- Use
new NeuroLink()with automatic provider selection for cost-optimized routing - Monitor usage through built-in analytics to track costs
- Consider local models (Ollama) for development and testing
- Check provider documentation for current pricing and availability
All providers support corporate proxy environments automatically. Simply set environment variables:
export HTTPS_PROXY=http://your-corporate-proxy:port
export HTTP_PROXY=http://your-corporate-proxy:portNo code changes required - NeuroLink automatically detects and uses proxy settings.
For detailed proxy setup → See Enterprise & Proxy Setup Guide
export OPENAI_API_KEY="sk-your-openai-api-key"export OPENAI_MODEL="gpt-4o" # Default model to usegpt-4o(default) - Latest multimodal modelgpt-4o-mini- Cost-effective variantgpt-4-turbo- High-performance model
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain machine learning" },
provider: "openai",
model: "gpt-4o",
temperature: 0.7,
maxTokens: 500,
timeout: "30s", // Optional: Override default 30s timeout
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
OPENAI_TIMEOUT='45s'(optional)
For Anthropic Claude models in Bedrock, you MUST use the full inference profile ARN, not simple model names:
# ✅ CORRECT: Use full inference profile ARN
export BEDROCK_MODEL="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0"
# ❌ WRONG: Simple model names cause "not authorized to invoke this API" errors
# export BEDROCK_MODEL="anthropic.claude-3-sonnet-20240229-v1:0"export AWS_ACCESS_KEY_ID="your-access-key"
export AWS_SECRET_ACCESS_KEY="your-secret-key"
export AWS_REGION="us-east-2"For temporary credentials (common in development environments):
export AWS_SESSION_TOKEN="your-session-token" # Required for temporary credentialsReplace <account_id> with your AWS account ID:
# Claude 3.7 Sonnet (Latest - Recommended)
BEDROCK_MODEL="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0"
# Claude 3.5 Sonnet
BEDROCK_MODEL="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-5-sonnet-20241022-v2:0"
# Claude 3 Haiku
BEDROCK_MODEL="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-haiku-20240307-v1:0"- Cross-Region Access: Faster access across AWS regions
- Better Performance: Optimized routing and response times
- Higher Availability: Improved model availability and reliability
- Different Permissions: Separate permission model from base models
# Required AWS credentials
export AWS_ACCESS_KEY_ID="your-access-key"
export AWS_SECRET_ACCESS_KEY="your-secret-key"
export AWS_REGION="us-east-2"
# Optional: Session token for temporary credentials
export AWS_SESSION_TOKEN="your-session-token"
# Required: Inference profile ARN (not simple model name)
export BEDROCK_MODEL="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0"
# Alternative environment variable names (backward compatibility)
export BEDROCK_MODEL_ID="arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0"import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Write a haiku about AI" },
provider: "bedrock",
temperature: 0.8,
maxTokens: 100,
timeout: "45s", // Optional: Override default 45s timeout
});- Default Timeout: 45 seconds (longer due to cold starts)
- Supported Formats: Milliseconds (
45000), human-readable ('45s','1m','2m') - Environment Variable:
BEDROCK_TIMEOUT='1m'(optional)
To use AWS Bedrock, ensure your AWS account has:
- Bedrock Service Access: Enable Bedrock in your AWS region
- Model Access: Request access to Anthropic Claude models
- IAM Permissions: Your credentials need
bedrock:InvokeModelpermissions - Inference Profile Access: Access to the specific inference profiles
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"bedrock:InvokeModel",
"bedrock:InvokeModelWithResponseStream"
],
"Resource": ["arn:aws:bedrock:*:*:inference-profile/us.anthropic.*"]
}
]
}Amazon SageMaker allows you to use your own custom models deployed on SageMaker endpoints. This provider is perfect for:
- Custom Model Hosting - Deploy your fine-tuned models
- Enterprise Compliance - Full control over model infrastructure
- Cost Optimization - Pay only for inference usage
- Performance - Dedicated compute resources
export AWS_ACCESS_KEY_ID="your-access-key"
export AWS_SECRET_ACCESS_KEY="your-secret-key"
export AWS_REGION="us-east-1" # Your SageMaker region# Required: Your SageMaker endpoint name
export SAGEMAKER_DEFAULT_ENDPOINT="your-endpoint-name"
# Optional: Timeout and retry settings
export SAGEMAKER_TIMEOUT="30000" # 30 seconds (default)
export SAGEMAKER_MAX_RETRIES="3" # Retry attempts (default)# Optional: Model-specific settings
export SAGEMAKER_MODEL="custom-model-name" # Model identifier
export SAGEMAKER_MODEL_TYPE="custom" # Model type
export SAGEMAKER_CONTENT_TYPE="application/json"
export SAGEMAKER_ACCEPT="application/json"export AWS_SESSION_TOKEN="your-session-token" # For temporary credentials# AWS Credentials
export AWS_ACCESS_KEY_ID="AKIAIOSFODNN7EXAMPLE"
export AWS_SECRET_ACCESS_KEY="wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY"
export AWS_REGION="us-east-1"
# SageMaker Settings
export SAGEMAKER_DEFAULT_ENDPOINT="my-model-endpoint-2024"
export SAGEMAKER_TIMEOUT="45000"
export SAGEMAKER_MAX_RETRIES="5"# Test SageMaker endpoint
npx @juspay/neurolink sagemaker test my-endpoint
# Generate text with SageMaker
npx @juspay/neurolink generate "Analyze this data" --provider sagemaker
# Interactive setup
npx @juspay/neurolink sagemaker setup# Check SageMaker configuration
npx @juspay/neurolink sagemaker status
# Validate connection
npx @juspay/neurolink sagemaker validate
# Show current configuration
npx @juspay/neurolink sagemaker config
# Performance benchmark
npx @juspay/neurolink sagemaker benchmark my-endpoint
# List available endpoints (requires AWS CLI)
npx @juspay/neurolink sagemaker list-endpointsConfigure request timeouts for SageMaker endpoints:
export SAGEMAKER_TIMEOUT="60000" # 60 seconds for large models- SageMaker Endpoint: Deploy a model to SageMaker and get the endpoint name
- AWS IAM Permissions: Ensure your credentials have
sagemaker:InvokeEndpointpermission - Endpoint Status: Endpoint must be in "InService" status
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": ["sagemaker:InvokeEndpoint"],
"Resource": "arn:aws:sagemaker:*:*:endpoint/*"
}
]
}| Variable | Required | Default | Description |
|---|---|---|---|
AWS_ACCESS_KEY_ID |
✅ | - | AWS access key |
AWS_SECRET_ACCESS_KEY |
✅ | - | AWS secret key |
AWS_REGION |
✅ | us-east-1 | AWS region |
SAGEMAKER_DEFAULT_ENDPOINT |
✅ | - | SageMaker endpoint name |
SAGEMAKER_TIMEOUT |
❌ | 30000 | Request timeout (ms) |
SAGEMAKER_MAX_RETRIES |
❌ | 3 | Retry attempts |
AWS_SESSION_TOKEN |
❌ | - | For temporary credentials |
For comprehensive SageMaker setup, advanced features, and production deployment: 📖 Complete SageMaker Integration Guide - Includes:
- Model deployment examples
- Cost optimization strategies
- Enterprise security patterns
- Multi-model endpoint management
- Performance testing and monitoring
- Troubleshooting and debugging
NeuroLink supports three authentication methods for Google Vertex AI to accommodate different deployment environments:
Best for production environments where you can store service account files securely.
export GOOGLE_APPLICATION_CREDENTIALS="/path/to/service-account.json"
export GOOGLE_VERTEX_PROJECT="your-project-id"
export GOOGLE_VERTEX_LOCATION="us-central1"Setup Steps:
- Create a service account in Google Cloud Console
- Download the service account JSON file
- Set the file path in
GOOGLE_APPLICATION_CREDENTIALS
Best for containerized environments where file storage is limited.
export GOOGLE_SERVICE_ACCOUNT_KEY='{"type":"service_account","project_id":"your-project",...}'
export GOOGLE_VERTEX_PROJECT="your-project-id"
export GOOGLE_VERTEX_LOCATION="us-central1"Setup Steps:
- Copy the entire contents of your service account JSON file
- Set it as a single-line string in
GOOGLE_SERVICE_ACCOUNT_KEY - NeuroLink will automatically create a temporary file for authentication
Best for CI/CD pipelines where individual secrets are managed separately.
export GOOGLE_AUTH_CLIENT_EMAIL="service-account@project.iam.gserviceaccount.com"
export GOOGLE_AUTH_PRIVATE_KEY="-----BEGIN PRIVATE KEY-----\nMIIE..."
export GOOGLE_VERTEX_PROJECT="your-project-id"
export GOOGLE_VERTEX_LOCATION="us-central1"Setup Steps:
- Extract
client_emailandprivate_keyfrom your service account JSON - Set them as individual environment variables
- NeuroLink will automatically assemble them into a temporary service account file
NeuroLink automatically detects and uses the best available authentication method in this order:
- File Path (
GOOGLE_APPLICATION_CREDENTIALS) - if file exists - JSON String (
GOOGLE_SERVICE_ACCOUNT_KEY) - if provided - Individual Variables (
GOOGLE_AUTH_CLIENT_EMAIL+GOOGLE_AUTH_PRIVATE_KEY) - if both provided
# Required for all methods
export GOOGLE_VERTEX_PROJECT="your-gcp-project-id"
# Optional
export GOOGLE_VERTEX_LOCATION="us-east5" # Default: us-east5
export VERTEX_MODEL_ID="claude-sonnet-4@20250514" # Default model
# Choose ONE authentication method:
# Method 1: Service Account File
export GOOGLE_APPLICATION_CREDENTIALS="/path/to/service-account.json"
# Method 2: Service Account JSON String
export GOOGLE_SERVICE_ACCOUNT_KEY='{"type":"service_account","project_id":"your-project","private_key_id":"...","private_key":"-----BEGIN PRIVATE KEY-----\n...","client_email":"...","client_id":"...","auth_uri":"https://accounts.google.com/o/oauth2/auth","token_uri":"https://oauth2.googleapis.com/token","auth_provider_x509_cert_url":"https://www.googleapis.com/oauth2/v1/certs","client_x509_cert_url":"..."}'
# Method 3: Individual Environment Variables
export GOOGLE_AUTH_CLIENT_EMAIL="service-account@your-project.iam.gserviceaccount.com"
export GOOGLE_AUTH_PRIVATE_KEY="-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQC...\n-----END PRIVATE KEY-----"import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain quantum computing" },
provider: "vertex",
model: "gemini-2.5-flash",
temperature: 0.6,
maxTokens: 800,
timeout: "1m", // Optional: Override default 60s timeout
});- Default Timeout: 60 seconds (longer due to GCP initialization)
- Supported Formats: Milliseconds (
60000), human-readable ('60s','1m','2m') - Environment Variable:
VERTEX_TIMEOUT='90s'(optional)
Gemini 3 (Preview):
gemini-3-flash-preview- Latest Gemini 3 Flash with extended thinking supportgemini-3-pro-preview- Latest Gemini 3 Pro with extended thinking support
Gemini 2.x:
gemini-2.5-flash(default) - Fast, efficient model
Anthropic Models:
claude-sonnet-4@20250514- High-quality reasoning (Anthropic via Vertex AI)
Video Generation:
veo-3.1/veo-3.1-generate-001- Video generation from image + text prompt (8-second videos with audio)
Video Generation: Use
output.mode: "video"with Veo 3.1 to generate videos. See Video Generation Guide.
PPT Generation: Use
output.mode: "ppt"with supported providers (Vertex AI, Google AI, OpenAI, Anthropic, Azure OpenAI, or Bedrock) and compatible text models to generate PowerPoint presentations. See PPT Generation Guide.
Gemini 3 models support extended thinking (also known as "thinking mode"), which allows the model to reason more deeply before providing responses. This is particularly useful for complex reasoning tasks, math problems, and multi-step analysis.
# Required: Google Vertex AI credentials (same as above)
export GOOGLE_VERTEX_PROJECT="your-project-id"
export GOOGLE_VERTEX_LOCATION="us-central1"
# Gemini 3 model selection
export VERTEX_MODEL_ID="gemini-3-flash-preview" # or gemini-3-pro-previewConfigure thinking level to control how much reasoning the model performs:
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Enable extended thinking with thinkingLevel configuration
const result = await neurolink.generate({
input: { text: "Solve this complex math problem step by step: ..." },
provider: "vertex",
model: "gemini-3-flash-preview",
temperature: 0.7,
maxTokens: 4000,
// Gemini 3 extended thinking configuration
thinkingLevel: "medium", // Options: "minimal", "low", "medium", "high"
});| Level | Description | Best For |
|---|---|---|
minimal |
No extended thinking, fastest responses | Simple queries, quick answers |
low |
Brief reasoning before responding | Moderate complexity tasks |
medium |
Balanced reasoning depth (recommended) | Most use cases |
high |
Deep reasoning, thorough analysis | Complex math, multi-step problems |
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Complex reasoning task with high thinking level
const result = await neurolink.generate({
input: {
text: "Analyze the following business scenario and provide strategic recommendations...",
},
provider: "vertex",
model: "gemini-3-pro-preview",
thinkingLevel: "high",
maxTokens: 8000,
timeout: "2m", // Extended timeout for deep thinking
});
console.log(result.content);# Generate with Gemini 3 Flash
npx @juspay/neurolink generate "Explain quantum computing" --provider vertex --model gemini-3-flash-preview
# Stream with Gemini 3 Pro
npx @juspay/neurolink stream "Write a detailed analysis" --provider vertex --model gemini-3-pro-previewNeuroLink provides first-class support for Claude Sonnet 4 through Google Vertex AI. This configuration has been thoroughly tested and verified working.
# ✅ VERIFIED WORKING CONFIGURATION
export GOOGLE_VERTEX_PROJECT="your-project-id"
export GOOGLE_VERTEX_LOCATION="us-east5"
export GOOGLE_AUTH_CLIENT_EMAIL="service-account@your-project.iam.gserviceaccount.com"
export GOOGLE_AUTH_PRIVATE_KEY="-----BEGIN PRIVATE KEY-----
[Your private key content here]
-----END PRIVATE KEY-----"- Generation Response: ~2.6 seconds
- Health Check: Working status detection
- Streaming: Fully functional
- Tool Integration: Ready for MCP tools
# Generation test
node dist/cli/index.js generate "test" --provider vertex --model claude-sonnet-4@20250514
# Streaming test
node dist/cli/index.js stream "Write a short poem" --provider vertex --model claude-sonnet-4@20250514
# Health check
node dist/cli/index.js status
# Expected: vertex: ✅ Working (2599ms)To use Google Vertex AI, ensure your Google Cloud project has:
- Vertex AI API Enabled: Enable the Vertex AI API in your project
- Service Account: Create a service account with Vertex AI permissions
- Model Access: Ensure access to the models you want to use
- Billing Enabled: Vertex AI requires an active billing account
Your service account needs these IAM roles:
Vertex AI UserorVertex AI AdminService Account Token Creator(if using impersonation)
Google AI Studio provides direct access to Google's Gemini models with a simple API key authentication.
export GOOGLE_AI_API_KEY="AIza-your-google-ai-api-key"export GOOGLE_AI_MODEL="gemini-2.5-pro" # Default model to usegemini-2.5-pro- Comprehensive, detailed responses for complex tasksgemini-2.5-flash(recommended) - Fast, efficient responses for most tasks
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain the future of AI" },
provider: "google-ai",
model: "gemini-2.5-flash",
temperature: 0.7,
maxTokens: 1000,
timeout: "30s", // Optional: Override default 30s timeout
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
GOOGLE_AI_TIMEOUT='45s'(optional)
- Visit Google AI Studio: Go to aistudio.google.com
- Sign In: Use your Google account credentials
- Create API Key:
- Navigate to the API Keys section
- Click Create API Key
- Copy the generated key (starts with
AIza)
- Set Environment: Add to your
.envfile or export directly
| Feature | Google AI Studio | Google Vertex AI |
|---|---|---|
| Setup Complexity | 🟢 Simple (API key only) | 🟡 Complex (Service account) |
| Authentication | API key | Service account JSON |
| Free Tier | ✅ Generous free limits | ❌ Pay-per-use only |
| Enterprise Features | ❌ Limited | ✅ Full enterprise support |
| Model Selection | 🎯 Latest Gemini models | 🔄 Broader model catalog |
| Best For | Prototyping, small projects | Production, enterprise apps |
# Required: API key from Google AI Studio (choose one)
export GOOGLE_AI_API_KEY="AIza-your-google-ai-api-key"
# OR
export GOOGLE_GENERATIVE_AI_API_KEY="AIza-your-google-ai-api-key"
# Optional: Default model selection
export GOOGLE_AI_MODEL="gemini-2.5-pro"Google AI Studio includes generous free tier limits:
- Free Tier: 15 requests per minute, 1,500 requests per day
- Paid Usage: Higher limits available with billing enabled
- Model-Specific: Different models may have different rate limits
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
try {
const result = await neurolink.generate({
input: { text: "Generate a creative story" },
provider: "google-ai",
temperature: 0.8,
maxTokens: 500,
});
console.log(result.content);
} catch (error) {
if (error.message.includes("API_KEY_INVALID")) {
console.error(
"Invalid Google AI API key. Check your GOOGLE_AI_API_KEY environment variable.",
);
} else if (error.message.includes("QUOTA_EXCEEDED")) {
console.error("Rate limit exceeded. Wait before making more requests.");
} else {
console.error("Google AI Studio error:", error.message);
}
}- API Key Security: Treat API keys as sensitive credentials
- Environment Variables: Never commit API keys to version control
- Rate Limiting: Implement client-side rate limiting for production apps
- Monitoring: Monitor usage to avoid unexpected charges
LiteLLM provides access to 100+ models through a unified proxy server, allowing you to use any AI provider through a single interface.
- Install LiteLLM:
pip install litellm- Start LiteLLM proxy server:
# Basic usage
litellm --port 4000
# With configuration file (recommended)
litellm --config litellm_config.yaml --port 4000export LITELLM_BASE_URL="http://localhost:4000"
export LITELLM_API_KEY="sk-anything" # Optional, any value worksexport LITELLM_MODEL="openai/gpt-4o-mini" # Default model to useLiteLLM uses the provider/model format:
# OpenAI models
openai/gpt-4o
openai/gpt-4o-mini
openai/gpt-4
# Anthropic models
anthropic/claude-3-5-sonnet
anthropic/claude-3-haiku
# Google models
google/gemini-2.0-flash
vertex_ai/gemini-pro
# Mistral models
mistral/mistral-large
mistral/mixtral-8x7b
# And many more...Create litellm_config.yaml for advanced configuration:
model_list:
- model_name: openai/gpt-4o
litellm_params:
model: gpt-4o
api_key: os.environ/OPENAI_API_KEY
- model_name: anthropic/claude-3-5-sonnet
litellm_params:
model: claude-3-5-sonnet-20241022
api_key: os.environ/ANTHROPIC_API_KEY
- model_name: google/gemini-2.0-flash
litellm_params:
model: gemini-2.0-flash
api_key: os.environ/GOOGLE_AI_API_KEYimport { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Use LiteLLM provider with specific model
const result = await neurolink.generate({
input: { text: "Explain quantum computing" },
provider: "litellm",
model: "openai/gpt-4o",
temperature: 0.7,
});
console.log(result.content);- Cost Tracking: Built-in usage and cost monitoring
- Load Balancing: Automatic failover between providers
- Rate Limiting: Built-in rate limiting and retry logic
- Caching: Optional response caching for efficiency
- Deployment: Run LiteLLM proxy as a separate service
- Security: Configure authentication for production environments
- Scaling: Use Docker/Kubernetes for high-availability deployments
- Monitoring: Enable logging and metrics collection
export HUGGINGFACE_API_KEY="hf_your_token_here"export HUGGINGFACE_MODEL="microsoft/DialoGPT-medium" # Default modelHugging Face hosts 100,000+ models. Choose based on:
- Task: text-generation, conversational, code
- Size: Larger models = better quality but slower
- License: Check model licenses for commercial use
- Free tier: Limited requests
- PRO tier: Higher limits
- Handle 503 errors (model loading) with retry logic
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain machine learning" },
provider: "huggingface",
model: "gpt2",
temperature: 0.8,
maxTokens: 200,
timeout: "45s", // Optional: Override default 30s timeout
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
HUGGINGFACE_TIMEOUT='45s'(optional) - Note: Model loading may take additional time on first request
microsoft/DialoGPT-medium(default) - Conversational AIgpt2- Classic GPT-2distilgpt2- Lightweight GPT-2EleutherAI/gpt-neo-2.7B- Large open modelbigscience/bloom-560m- Multilingual model
- Create Account: Visit huggingface.co
- Generate Token: Go to Settings → Access Tokens
- Create Token: Click "New token" with "read" scope
- Set Environment: Export token as
HUGGINGFACE_API_KEY
Ollama must be installed and running locally.
-
macOS:
brew install ollama # or curl -fsSL https://ollama.ai/install.sh | sh
-
Linux:
curl -fsSL https://ollama.ai/install.sh | sh -
Windows: Download from ollama.ai
# List models
ollama list
# Pull new model
ollama pull llama2
# Remove model
ollama rm llama2- 100% Local: No data leaves your machine
- No API Keys: No authentication required
- Offline Capable: Works without internet
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Write a poem about privacy" },
provider: "ollama",
model: "llama2",
temperature: 0.7,
maxTokens: 300,
timeout: "10m", // Optional: Override default 5m timeout
});- Default Timeout: 5 minutes (longer for local model processing)
- Supported Formats: Milliseconds (
300000), human-readable ('5m','10m','30m') - Environment Variable:
OLLAMA_TIMEOUT='10m'(optional) - Note: Local models may need longer timeouts for complex prompts
llama2(default) - Meta's Llama 2codellama- Code-specialized Llamamistral- Mistral 7Bvicuna- Fine-tuned Llamaphi- Microsoft's small model
# Optional: Custom Ollama server URL
export OLLAMA_BASE_URL="http://localhost:11434"
# Optional: Default model
export OLLAMA_MODEL="llama2"# Set memory limit
OLLAMA_MAX_MEMORY=8GB ollama serve
# Use specific GPU
OLLAMA_CUDA_DEVICE=0 ollama serveOpenRouter provides access to 300+ AI models from 60+ providers through a single unified API with automatic failover and cost optimization.
export OPENROUTER_API_KEY="sk-or-v1-your-api-key"# Attribution for OpenRouter dashboard
export OPENROUTER_REFERER="https://yourapp.com"
export OPENROUTER_APP_NAME="Your App Name"
# Default model
export OPENROUTER_MODEL="anthropic/claude-3-5-sonnet"OpenRouter supports 300+ models including:
anthropic/claude-3-5-sonnet(default) - Best overall qualityopenai/gpt-4o- Excellent code generationgoogle/gemini-2.0-flash- Fast and cost-effectivemeta-llama/llama-3.1-70b-instruct- Best open source
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain quantum computing" },
provider: "openrouter",
model: "anthropic/claude-3-5-sonnet",
temperature: 0.7,
maxTokens: 500,
});For comprehensive OpenRouter setup including model selection, cost optimization, and best practices, see the OpenRouter Provider Guide.
export MISTRAL_API_KEY="your_mistral_api_key"- GDPR compliant
- Data processed in Europe
- No training on user data
- mistral-tiny: Fast responses, basic tasks
- mistral-small: Balanced choice (default)
- mistral-medium: Complex reasoning
- mistral-large: Maximum capability
Mistral offers competitive pricing:
- Tiny: $0.14 / 1M tokens
- Small: $0.6 / 1M tokens
- Medium: $2.5 / 1M tokens
- Large: $8 / 1M tokens
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Translate to French: Hello world" },
provider: "mistral",
model: "mistral-small",
temperature: 0.3,
maxTokens: 100,
timeout: "30s", // Optional: Override default 30s timeout
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
MISTRAL_TIMEOUT='45s'(optional)
- Create Account: Visit mistral.ai
- Get API Key: Navigate to API Keys section
- Generate Key: Create new API key
- Add Billing: Set up payment method
# Required: API key
export MISTRAL_API_KEY="your_mistral_api_key"
# Optional: Default model
export MISTRAL_MODEL="mistral-small"
# Optional: Custom endpoint
export MISTRAL_ENDPOINT="https://api.mistral.ai"Mistral models excel at multilingual tasks:
- English, French, Spanish, German, Italian
- Code generation in multiple programming languages
- Translation between supported languages
Direct access to Anthropic's Claude models. Supports both API key and OAuth (Claude subscription) authentication.
# Option 1: API key authentication
export ANTHROPIC_API_KEY="sk-ant-api03-your-key-here"
# Option 2: OAuth authentication (Claude Pro/Max subscribers)
neurolink auth login anthropicexport ANTHROPIC_MODEL="claude-3-5-sonnet-20241022" # Default modelclaude-opus-4-5-20251101- Claude 4.5 Opus (most capable)claude-sonnet-4-5-20250929- Claude 4.5 Sonnetclaude-haiku-4-5-20251001- Claude 4.5 Haiku (fastest)claude-opus-4-1-20250805- Claude 4.1 Opusclaude-opus-4-20250514- Claude 4.0 Opusclaude-sonnet-4-20250514- Claude 4.0 Sonnetclaude-3-7-sonnet-20250219- Claude 3.7 Sonnet
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain quantum computing" },
provider: "anthropic",
model: "claude-3-5-sonnet-20241022",
temperature: 0.7,
maxTokens: 1000,
timeout: "30s",
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
ANTHROPIC_TIMEOUT='45s'(optional)
- API Key: Visit console.anthropic.com, navigate to API Keys, and export as
ANTHROPIC_API_KEY - OAuth (Subscription): Run
neurolink auth login anthropicto authenticate with your Claude Pro/Max subscription
For comprehensive Anthropic setup including OAuth configuration, subscription tiers, and advanced options, see the Detailed Anthropic Provider Guide and the Claude Subscription Guide.
Azure OpenAI provides enterprise-grade access to OpenAI models through Microsoft Azure.
export AZURE_OPENAI_API_KEY="your-azure-openai-key"
export AZURE_OPENAI_ENDPOINT="https://your-resource.openai.azure.com/"
export AZURE_OPENAI_DEPLOYMENT_ID="your-deployment-name"export AZURE_OPENAI_API_VERSION="2024-02-15-preview" # API versionAzure OpenAI supports deployment of:
gpt-4o- Latest multimodal modelgpt-4- Advanced reasoninggpt-4-turbo- Optimized performancegpt-3.5-turbo- Cost-effective
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Explain machine learning" },
provider: "azure",
temperature: 0.7,
maxTokens: 500,
timeout: "30s",
});- Default Timeout: 30 seconds
- Supported Formats: Milliseconds (
30000), human-readable ('30s','1m','5m') - Environment Variable:
AZURE_TIMEOUT='45s'(optional)
- Azure Subscription: Active Azure subscription
- Azure OpenAI Resource: Create Azure OpenAI resource in Azure Portal
- Model Deployment: Deploy a model to get deployment ID
- API Key: Get API key from resource's Keys and Endpoint section
| Variable | Required | Description |
|---|---|---|
AZURE_OPENAI_API_KEY |
✅ | Azure OpenAI API key |
AZURE_OPENAI_ENDPOINT |
✅ | Resource endpoint URL |
AZURE_OPENAI_DEPLOYMENT_ID |
✅ | Model deployment name |
AZURE_OPENAI_API_VERSION |
❌ | API version (default: latest) |
Connect to any OpenAI-compatible API endpoint (LocalAI, vLLM, Ollama with OpenAI compatibility, etc.)
export OPENAI_COMPATIBLE_BASE_URL="http://localhost:8080/v1"
export OPENAI_COMPATIBLE_API_KEY="optional-api-key" # Some servers don't require thisexport OPENAI_COMPATIBLE_MODEL="your-model-name"import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
const result = await neurolink.generate({
input: { text: "Hello from custom endpoint" },
provider: "openai-compatible",
model: "your-model",
temperature: 0.7,
maxTokens: 500,
});This works with any server implementing the OpenAI API:
- LocalAI - Local AI server
- vLLM - High-performance inference server
- Ollama (with
OLLAMA_OPENAI_COMPAT=1) - Text Generation WebUI
- Custom inference servers
# Required: Base URL of your OpenAI-compatible server
export OPENAI_COMPATIBLE_BASE_URL="http://localhost:8080/v1"
# Optional: API key (if your server requires one)
export OPENAI_COMPATIBLE_API_KEY="your-api-key-if-needed"
# Optional: Default model name
export OPENAI_COMPATIBLE_MODEL="your-model-name"Redis integration for distributed conversation memory and session state.
export REDIS_URL="redis://localhost:6379"export REDIS_PASSWORD="your-redis-password" # If authentication enabled
export REDIS_DB="0" # Database number (default: 0)
export REDIS_KEY_PREFIX="neurolink:" # Key prefix for namespacing# Connection settings
export REDIS_HOST="localhost"
export REDIS_PORT="6379"
export REDIS_TLS="false" # Set to "true" for TLS connections
# Pool settings
export REDIS_MAX_RETRIES="3"
export REDIS_RETRY_DELAY="1000" # milliseconds
export REDIS_CONNECTION_TIMEOUT="5000" # millisecondsimport { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink({
memory: {
type: "redis",
url: process.env.REDIS_URL,
},
});
const result = await neurolink.generate({
input: { text: "Remember this conversation" },
sessionId: "user-123", // Session stored in Redis
});For managed Redis (Redis Cloud, AWS ElastiCache, etc.):
export REDIS_URL="rediss://username:password@your-redis-host:6380"# Start Redis in Docker
docker run -d -p 6379:6379 redis:latest
# Set environment
export REDIS_URL="redis://localhost:6379"- Distributed Memory: Share conversation state across instances
- Session Persistence: Conversations survive application restarts
- Export/Import: Export full session history as JSON
- Multi-tenant: Isolate conversations by session ID
- Scalability: Handle thousands of concurrent conversations
| Variable | Required | Default | Description |
|---|---|---|---|
REDIS_URL |
Recommended | - | Full Redis connection URL |
REDIS_HOST |
Alternative | localhost | Redis host |
REDIS_PORT |
Alternative | 6379 | Redis port |
REDIS_PASSWORD |
If auth enabled | - | Redis password |
REDIS_DB |
❌ | 0 | Database number |
REDIS_KEY_PREFIX |
❌ | neurolink: | Key prefix |
Create a .env file in your project root:
# NeuroLink Environment Configuration
# OpenAI
OPENAI_API_KEY=sk-your-openai-key-here
OPENAI_MODEL=gpt-4o
# Amazon Bedrock
AWS_ACCESS_KEY_ID=your-aws-access-key
AWS_SECRET_ACCESS_KEY=your-aws-secret-key
AWS_REGION=us-east-2
AWS_SESSION_TOKEN=your-session-token # Optional: for temporary credentials
BEDROCK_MODEL=arn:aws:bedrock:us-east-2:<account_id>:inference-profile/us.anthropic.claude-3-7-sonnet-20250219-v1:0
# Google Vertex AI (choose one method)
# Method 1: File path
GOOGLE_APPLICATION_CREDENTIALS=/path/to/your/service-account.json
# Method 2: JSON string (uncomment to use)
# GOOGLE_SERVICE_ACCOUNT_KEY={"type":"service_account","project_id":"your-project",...}
# Method 3: Individual variables (uncomment to use)
# GOOGLE_AUTH_CLIENT_EMAIL=service-account@your-project.iam.gserviceaccount.com
# GOOGLE_AUTH_PRIVATE_KEY="-----BEGIN PRIVATE KEY-----\nYOUR_PRIVATE_KEY_HERE\n-----END PRIVATE KEY-----"
# Required for all Google Vertex AI methods
GOOGLE_VERTEX_PROJECT=your-gcp-project-id
GOOGLE_VERTEX_LOCATION=us-east5
VERTEX_MODEL_ID=claude-sonnet-4@20250514
# Alternative: Gemini 3 models with extended thinking support
# VERTEX_MODEL_ID=gemini-3-flash-preview
# VERTEX_MODEL_ID=gemini-3-pro-preview
# Google AI Studio
GOOGLE_AI_API_KEY=AIza-your-googleAiStudio-key
GOOGLE_AI_MODEL=gemini-2.5-pro
# Anthropic
ANTHROPIC_API_KEY=sk-ant-api03-your-key
# Azure OpenAI
AZURE_OPENAI_API_KEY=your-azure-key
AZURE_OPENAI_ENDPOINT="https://your-resource.openai.azure.com/"
AZURE_OPENAI_DEPLOYMENT_ID=your-deployment-name
# Hugging Face
HUGGINGFACE_API_KEY=hf_your_token_here
HUGGINGFACE_MODEL=microsoft/DialoGPT-medium # Optional
# Ollama (Local AI)
OLLAMA_BASE_URL=http://localhost:11434 # Optional
OLLAMA_MODEL=llama2 # Optional
# Mistral AI
MISTRAL_API_KEY=your_mistral_api_key
MISTRAL_MODEL=mistral-small # Optional
# Application Settings
DEFAULT_PROVIDER=auto
NEUROLINK_DEBUG=falseNeuroLink automatically selects the best available provider when no provider is specified:
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Automatically selects best available provider
const result = await neurolink.generate({
input: { text: "Hello, world!" },
});The default priority order (most reliable first):
- OpenAI - Most reliable, fastest setup
- Anthropic - High quality, simple setup
- Google AI Studio - Free tier, easy setup
- Azure OpenAI - Enterprise reliable
- Google Vertex AI - Good performance, multiple auth methods
- Mistral AI - European compliance, competitive pricing
- Hugging Face - Open source variety
- Amazon Bedrock - High quality, requires careful setup
- Ollama - Local only, no fallback
import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Explicitly specify provider and model
const result = await neurolink.generate({
input: { text: "Hello" },
provider: "bedrock",
model: "anthropic.claude-3-sonnet-20240229-v1:0",
});import { NeuroLink } from "@juspay/neurolink";
const neurolink = new NeuroLink();
// Different providers for different environments
const result = await neurolink.generate({
input: { text: "Hello" },
provider: process.env.NODE_ENV === "production" ? "bedrock" : "openai",
model: process.env.NODE_ENV === "production" ? undefined : "gpt-4o-mini",
});# Test all providers
npx @juspay/neurolink status --verbose
# Expected output:
# 🔍 Checking AI provider status...
# ✅ openai: ✅ Working (234ms)
# ❌ bedrock: ❌ Invalid credentials - The security token included in the request is expired
# ⚪ vertex: ⚪ Not configured - Missing environment variablesimport { NeuroLink } from "@juspay/neurolink";
async function testProviders() {
const providers = [
"openai",
"bedrock",
"vertex",
"anthropic",
"azure",
"google-ai",
"huggingface",
"ollama",
"mistral",
];
const neurolink = new NeuroLink();
for (const providerName of providers) {
try {
const start = Date.now();
const result = await neurolink.generate({
input: { text: "Test" },
provider: providerName,
maxTokens: 10,
});
console.log(`✅ ${providerName}: Working (${Date.now() - start}ms)`);
} catch (error) {
console.log(`❌ ${providerName}: ${error.message}`);
}
}
}
testProviders();Error: Cannot find API key for OpenAI provider
Solution: Set OPENAI_API_KEY environment variable
Your account is not authorized to invoke this API operation
Solutions:
- Use full inference profile ARN (not simple model name)
- Check AWS account has Bedrock access
- Verify IAM permissions include
bedrock:InvokeModel - Ensure model access is enabled in your AWS region
Cannot find package '@google-cloud/vertexai'
Solution: Install peer dependency: npm install @google-cloud/vertexai
Authentication failed
Solutions:
- Verify service account JSON is valid
- Check project ID is correct
- Ensure Vertex AI API is enabled
- Verify service account has proper permissions
- Never commit API keys to version control
- Use different keys for development/staging/production
- Rotate keys regularly
- Use minimal permissions for service accounts
- Use IAM roles instead of access keys when possible
- Enable CloudTrail for audit logging
- Use VPC endpoints for additional security
- Implement resource-based policies
- Use service account keys with minimal permissions
- Enable audit logging
- Use VPC Service Controls for additional isolation
- Rotate service account keys regularly
- Use environment-specific configurations
- Implement rate limiting in your applications
- Monitor usage and costs
- Use HTTPS for all API communications