d7b374f8ab
New features: - ActivityController and manager for CW sales activities (CRUD) - ForecastProductController for opportunity forecast/product lines - CW member cache with dual-layer (in-memory + Redis) resolution - Catalog category/subcategory/ecosystem taxonomy module - Quote statuses type definitions with CW mapping - User-defined fields (UDF) module with cache and event refresh - Company sites CW module with serialization - Procurement manager filters (category, ecosystem, manufacturer, price, stock) - Opportunity notes CRUD and product line management via CW API - Opportunity type definitions endpoint Updates: - OpportunityController: CW refresh, company hydration, activities, custom fields - UserController: cwIdentifier field for CW member linking - CatalogItemController: category/subcategory fields from CW - PermissionNodes: sales note/product CRUD nodes, subCategories, collectPermissions - API routes: procurement categories/filters, sales notes/products, opportunity types - Global events: UDF and member refresh intervals on startup Tests (414 passing): - ActivityController, ForecastProductController, OpportunityController unit tests - UserController cwIdentifier tests - catalogCategories, companySites, memberCache, procurement module tests - activityTypes, opportunityTypes, quoteStatuses type tests - permissionNodes subCategories and getAllPermissionNodes tests - Updated test setup with redis mock, API method mocks, and builder helpers
51 lines
1.8 KiB
TypeScript
51 lines
1.8 KiB
TypeScript
import { Hono } from "hono/tiny";
|
|
import { createRoute } from "../../modules/api-utils/createRoute";
|
|
import { companies } from "../../managers/companies";
|
|
import { apiResponse } from "../../modules/api-utils/apiResponse";
|
|
import { ContentfulStatusCode } from "hono/utils/http-status";
|
|
import { authMiddleware } from "../middleware/authorization";
|
|
import { processObjectValuePerms } from "../../modules/permission-utils/processObjectPermissions";
|
|
|
|
/* /v1/company/companies */
|
|
export default createRoute(
|
|
"get",
|
|
["/companies"],
|
|
async (c) => {
|
|
const page = new Number(c.req.query("page") ?? 1) as number;
|
|
const rpp = new Number(c.req.query("rpp") ?? 30) as number; // Records Per Page
|
|
const search = c.req.query("search") as string;
|
|
|
|
const data = search
|
|
? await companies.search(search, page, rpp)
|
|
: await companies.fetchPages(page, rpp);
|
|
|
|
const companyQty = search
|
|
? (await companies.search(search, 1, 999999)).length
|
|
: await companies.count();
|
|
|
|
const gatedData = await Promise.all(
|
|
data.map((item) =>
|
|
processObjectValuePerms(item, "obj.company", c.get("user")),
|
|
),
|
|
);
|
|
|
|
let response = apiResponse.successful(
|
|
"Companies Fetched Successfully!",
|
|
gatedData,
|
|
{
|
|
pagination: {
|
|
previousPage: page == 1 ? null : page - 1, // Previous Page
|
|
currentPage: page, // Current Page
|
|
nextPage: page >= companyQty / rpp ? null : page + 1, // Next Page
|
|
totalPages: Math.ceil(companyQty / rpp), // Total Number of Pages
|
|
totalRecords: companyQty, // Total Number of Records
|
|
listedRecords: rpp, // Total Number of Records being recieved at time of request.
|
|
},
|
|
},
|
|
);
|
|
|
|
return c.json(response, response.status as ContentfulStatusCode);
|
|
},
|
|
authMiddleware({ permissions: ["company.fetch.many"] }),
|
|
);
|