6d935e7180
- Add Redis-backed opportunity cache with background refresh (30s interval) - Fix concurrency bug: use lazy thunks instead of eager promises for batching - Add withCwRetry utility with exponential backoff for transient CW errors - Add adaptive TTL algorithms (primary, sub-resource, products) based on opportunity activity - Add include query param on GET /sales/opportunities/:id (notes,contacts,products) - Add opt-in CW API logger (LOG_CW_API env var) with timestamped files in cw-api-logs/ - Add debug-scripts/analyze-cw-calls.py for API call analysis - Add computeSubResourceCacheTTL and computeProductsCacheTTL algorithms with tests - Increase CW API timeout from 15s to 30s - Unblock cache refresh from startup chain (remove await) - Prioritize recently updated opportunities in refresh cycle - Add CACHING.md documentation - Update API_ROUTES.md with caching details and include param - Update copilot instructions to require CACHING.md sync - Add dev:log script for CW API call logging during development
26 lines
678 B
TypeScript
26 lines
678 B
TypeScript
import { connectWiseApi } from "../../constants";
|
|
import { Company } from "../../types/ConnectWiseTypes";
|
|
import { withCwRetry } from "./withCwRetry";
|
|
|
|
export const fetchCwCompanyById = async (
|
|
companyId: number,
|
|
): Promise<Company | null> => {
|
|
try {
|
|
const response = await withCwRetry(
|
|
() => connectWiseApi.get(`/company/companies/${companyId}`),
|
|
{
|
|
label: `fetchCompany#${companyId}`,
|
|
maxAttempts: 3,
|
|
baseDelayMs: 1_500,
|
|
},
|
|
);
|
|
return response.data;
|
|
} catch (error) {
|
|
console.error(
|
|
`Error fetching company with ID ${companyId}:`,
|
|
(error as any).response?.data || error,
|
|
);
|
|
return null;
|
|
}
|
|
};
|