Skip to content

Client Portal API

The Client Portal API provides endpoints for client-facing features including matter management, document access, signature requests, and AI-powered intake processing.

Authentication

All Client Portal API endpoints require authentication via session cookies or API tokens.

// Session-based authentication (web interface)
const response = await fetch('/api/client-portal/matters', {
credentials: 'include'
});
// Token-based authentication (mobile/API)
const response = await fetch('/api/client-portal/matters', {
headers: {
'Authorization': 'Bearer your-api-token'
}
});

Matters Management

List Client Matters

GET
`/api/client-portal/matters`

Retrieve all matters associated with the authenticated client.

Response:

{
"success": true,
"matters": [
{
"id": "matter_123",
"name": "Document Service - Smith vs Jones",
"description": "Service of summons and complaint",
"status": "in_progress",
"created_at": "2024-01-15T10:30:00Z",
"updated_at": "2024-01-16T14:22:00Z",
"assigned_team": "process_servers",
"estimated_completion": "2024-01-18T17:00:00Z"
}
],
"count": 1
}

Get Matter Details

GET
`/api/client-portal/matters/{matter_id}`

Retrieve detailed information about a specific matter.

Parameters:

  • matter_id (string, required): Unique identifier for the matter

Response:

{
"success": true,
"matter": {
"id": "matter_123",
"name": "Document Service - Smith vs Jones",
"description": "Service of summons and complaint",
"status": "in_progress",
"matter_type": "document_service",
"urgency": "high",
"created_at": "2024-01-15T10:30:00Z",
"updated_at": "2024-01-16T14:22:00Z",
"assigned_team": "process_servers",
"assigned_staff": [
{
"id": "staff_456",
"name": "John Process",
"role": "process_server",
"email": "john@example.com"
}
],
"timeline": {
"estimated_start": "2024-01-16T09:00:00Z",
"estimated_completion": "2024-01-18T17:00:00Z",
"actual_start": "2024-01-16T09:15:00Z"
},
"progress": {
"current_step": "service_attempt",
"completed_steps": ["intake", "document_review", "assignment"],
"remaining_steps": ["service_completion", "proof_filing"]
},
"documents_count": 3,
"events_count": 7
}
}

Get Matter Events

GET
`/api/client-portal/matters/{matter_id}/events`

Retrieve the activity timeline for a specific matter.

Query Parameters:

  • limit (integer, optional): Maximum number of events to return (default: 50)
  • offset (integer, optional): Number of events to skip (default: 0)

Response:

{
"success": true,
"events": [
{
"id": "event_789",
"matter_id": "matter_123",
"type": "service_attempt",
"description": "First service attempt at residence",
"details": {
"location": "123 Main St, Apt 2B",
"time": "2024-01-16T14:30:00Z",
"result": "no_answer",
"notes": "No answer at door, left notice of attempt"
},
"created_at": "2024-01-16T14:35:00Z",
"created_by": {
"name": "John Process",
"role": "process_server"
}
}
],
"count": 7,
"has_more": false
}

Document Management

List Matter Documents

GET
`/api/client-portal/matters/{matter_id}/documents`

Retrieve documents associated with a specific matter.

Query Parameters:

  • type (string, optional): Filter by document type
  • access_type (string, optional): Filter by access level (view, download, edit)

Response:

{
"success": true,
"documents": [
{
"id": "doc_456",
"filename": "summons_smith_v_jones.pdf",
"type": "summons",
"size": 245760,
"access_type": "download",
"granted_at": "2024-01-15T10:30:00Z",
"created_at": "2024-01-15T10:30:00Z",
"metadata": {
"pages": 3,
"signed": false,
"requires_signature": false
}
}
],
"count": 3
}

Download Document

GET
`/api/client-portal/documents/{document_id}/download`

Download a specific document (returns file stream).

Headers:

Content-Type: application/pdf
Content-Disposition: attachment; filename="document.pdf"

Upload Document

POST
`/api/client-portal/matters/{matter_id}/documents`

Upload a new document to a matter.

Request (multipart/form-data):

file: [file data]
type: "evidence"
description: "Photos of service location"

Response:

{
"success": true,
"document": {
"id": "doc_789",
"filename": "service_photos.jpg",
"type": "evidence",
"size": 1024000,
"access_type": "view",
"created_at": "2024-01-16T15:30:00Z"
}
}

AI-Powered Intake

Start Intake Session

POST
`/api/client-portal/intake`

Process client intake with AI assistance and workflow routing.

Request:

{
"conversation": [
{
"role": "user",
"content": "I need to serve an eviction notice to my tenant",
"timestamp": "2024-01-15T10:00:00Z"
},
{
"role": "assistant",
"content": "I can help with eviction service. What type of notice needs to be served?",
"timestamp": "2024-01-15T10:00:15Z"
}
],
"formData": {
"client_name": "Jane Smith",
"email": "jane@example.com",
"phone": "+1-555-0123",
"matter_type": "eviction",
"urgency": "high",
"property_address": "456 Oak Street, Unit 3",
"tenant_name": "John Doe",
"eviction_reason": "non_payment_rent"
},
"documents": [],
"matterType": "eviction",
"urgency": "high",
"summary": "Eviction notice service for non-payment of rent",
"workflow": "expedited_eviction_service"
}

Response:

{
"success": true,
"caseNumber": "EV-2024-0123",
"analysis": {
"matterType": "eviction",
"urgency": "high",
"confidence": 0.95,
"extractedInfo": {
"detectedKeywords": ["eviction", "tenant", "notice"],
"timelineIndicators": ["immediately"],
"addressMentioned": true,
"documentTypes": ["notice"]
}
},
"workflowPlan": {
"workflow": "expedited_eviction_service",
"assignedTeam": "eviction_specialists",
"estimatedDays": 1,
"nextSteps": [
"Case file created and assigned case number EV-2024-0123",
"Matter routed to eviction_specialists for review",
"AI analysis summary generated for legal team",
"Client notification email sent with tracking information"
],
"automatedActions": [
"create_case_file",
"assign_team",
"generate_summary",
"send_notifications"
]
},
"aiSummary": "AI INTAKE ANALYSIS SUMMARY\n\nMatter Type: EVICTION\nUrgency Level: HIGH\nConfidence Score: 95%\n...",
"ragInsights": {
"similarCases": [
{
"id": "case_789",
"similarity": 0.89,
"outcome": "successful_service",
"timeline": 1
}
],
"guidance": "Based on similar eviction cases, this typically requires 3-day notice service with personal service attempt followed by posting if necessary.",
"contextualQuestions": [
{
"question": "Do you have the 3-day notice prepared?",
"type": "select",
"options": ["Yes", "No", "Need assistance"],
"required": true
}
]
}
}

Get AI Chat Guidance

POST
`/api/ai/chat-guidance`

Get AI-powered responses during intake conversation.

Request:

{
"message": "I need to serve an eviction notice",
"conversation": [
{
"role": "user",
"content": "I need help with a legal matter",
"timestamp": "2024-01-15T10:00:00Z"
}
],
"currentMatterType": "eviction"
}

Response:

{
"message": "I can help with eviction service. Based on similar cases in our knowledge base, eviction notices typically require specific service methods depending on your jurisdiction. What type of eviction notice do you need served?",
"detectedMatterType": "eviction",
"shouldShowForm": false,
"suggestedFields": [],
"ragInsights": {
"similarCases": [
{
"caseId": "EV-2024-0089",
"similarity": 0.87,
"outcome": "successful_service"
}
],
"guidance": "Based on 15 similar eviction cases, success rate is 94% with average 1.2 day service time.",
"confidence": 0.87
}
}

Signature Management

List Signature Requests

GET
`/api/client-portal/signatures`

Retrieve signature requests for the authenticated client.

Query Parameters:

  • status (string, optional): Filter by status (pending, signed, declined, expired)

Response:

{
"success": true,
"signatureRequests": [
{
"id": "sig_123",
"session_title": "Service Agreement - Case EV-2024-0123",
"document_name": "service_agreement.pdf",
"status": "pending",
"signer_name": "Jane Smith",
"signer_email": "jane@example.com",
"access_token": "abc123xyz",
"expiry_date": "2024-01-22T23:59:59Z",
"created_at": "2024-01-15T10:30:00Z",
"viewed_at": null,
"signed_at": null
}
],
"count": 1
}

Sign Document

POST
`/sign/{access_token}`

Access and sign a document using the provided access token.

Request:

{
"signature_data": "...",
"signed_at": "2024-01-16T14:30:00Z"
}

Response:

{
"success": true,
"message": "Document signed successfully",
"signed_document_id": "doc_signed_456"
}

Job Tracking

List Client Jobs

GET
`/api/client-portal/jobs`

Retrieve service jobs associated with client matters.

Query Parameters:

  • status (string, optional): Filter by job status
  • matter_id (string, optional): Filter by specific matter

Response:

{
"success": true,
"jobs": [
{
"id": "job_789",
"matter_id": "matter_123",
"status": "in_progress",
"service_type": "personal_service",
"service_address": "456 Oak Street, Unit 3",
"recipient_name": "John Doe",
"assigned_server": {
"name": "Mike Server",
"phone": "+1-555-0199"
},
"attempts": [
{
"attempt_number": 1,
"date": "2024-01-16T14:30:00Z",
"result": "no_answer",
"notes": "No answer at door, will retry tomorrow"
}
],
"created_at": "2024-01-16T09:00:00Z",
"estimated_completion": "2024-01-17T17:00:00Z"
}
],
"count": 1
}

Get Job Details

GET
`/api/client-portal/jobs/{job_id}`

Retrieve detailed information about a specific service job.

Response:

{
"success": true,
"job": {
"id": "job_789",
"matter_id": "matter_123",
"status": "in_progress",
"service_type": "personal_service",
"service_address": "456 Oak Street, Unit 3",
"recipient_name": "John Doe",
"recipient_description": "Male, approximately 35 years old",
"documents_to_serve": [
{
"document_id": "doc_456",
"document_name": "3-Day Notice to Quit",
"document_type": "eviction_notice"
}
],
"assigned_server": {
"id": "server_123",
"name": "Mike Server",
"license": "PS-12345",
"phone": "+1-555-0199",
"email": "mike@servers.com"
},
"attempts": [
{
"attempt_number": 1,
"date": "2024-01-16T14:30:00Z",
"result": "no_answer",
"location": "Front door of unit 3",
"notes": "No answer at door, lights on inside, will retry tomorrow morning",
"photos": [
{
"id": "photo_123",
"description": "Front door of service address",
"timestamp": "2024-01-16T14:32:00Z"
}
]
}
],
"special_instructions": "Tenant works night shift, try service attempts before 2 PM",
"created_at": "2024-01-16T09:00:00Z",
"estimated_completion": "2024-01-17T17:00:00Z"
}
}

Error Handling

All API endpoints follow consistent error response format:

{
"success": false,
"error": "Detailed error message",
"error_code": "INVALID_MATTER_ID",
"details": {
"field": "matter_id",
"message": "Matter not found or access denied"
}
}

Common Error Codes:

  • UNAUTHORIZED: Authentication required or invalid
  • FORBIDDEN: Insufficient permissions
  • NOT_FOUND: Resource does not exist
  • INVALID_INPUT: Request validation failed
  • RATE_LIMITED: Too many requests
  • INTERNAL_ERROR: Server-side error

Rate Limiting

API endpoints are rate limited to ensure fair usage:

  • Standard endpoints: 100 requests per minute
  • Upload endpoints: 10 requests per minute
  • AI endpoints: 20 requests per minute

Rate limit headers are included in responses:

X-RateLimit-Limit: 100
X-RateLimit-Remaining: 95
X-RateLimit-Reset: 1642617600

Pagination

List endpoints support pagination using cursor-based pagination:

Request:

GET /api/client-portal/matters?limit=10&cursor=eyJpZCI6Im1hdHRlcl8xMjMifQ

Response:

{
"success": true,
"matters": [...],
"pagination": {
"has_more": true,
"next_cursor": "eyJpZCI6Im1hdHRlcl8xMzQifQ"
}
}