@greensecurity/javascript-sdk 0.30.15 → 0.30.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/bin/mcp-server.js +56 -26
  2. package/bin/mcp-server.js.map +13 -13
  3. package/dist/commonjs/__tests__/vendors.test.js +1 -1
  4. package/dist/commonjs/__tests__/webhooks.test.js +1 -1
  5. package/dist/commonjs/__tests__/webhooks.test.js.map +1 -1
  6. package/dist/commonjs/funcs/vendorsListVendorInvoices.js +2 -0
  7. package/dist/commonjs/funcs/vendorsListVendorInvoices.js.map +1 -1
  8. package/dist/commonjs/lib/config.d.ts +3 -3
  9. package/dist/commonjs/lib/config.js +3 -3
  10. package/dist/commonjs/mcp-server/mcp-server.js +1 -1
  11. package/dist/commonjs/mcp-server/prompts.d.ts.map +1 -1
  12. package/dist/commonjs/mcp-server/prompts.js +5 -1
  13. package/dist/commonjs/mcp-server/prompts.js.map +1 -1
  14. package/dist/commonjs/mcp-server/resources.d.ts.map +1 -1
  15. package/dist/commonjs/mcp-server/resources.js +10 -2
  16. package/dist/commonjs/mcp-server/resources.js.map +1 -1
  17. package/dist/commonjs/mcp-server/server.d.ts.map +1 -1
  18. package/dist/commonjs/mcp-server/server.js +2 -3
  19. package/dist/commonjs/mcp-server/server.js.map +1 -1
  20. package/dist/commonjs/mcp-server/tools.d.ts.map +1 -1
  21. package/dist/commonjs/mcp-server/tools.js +4 -3
  22. package/dist/commonjs/mcp-server/tools.js.map +1 -1
  23. package/dist/commonjs/models/operations/listvendorinvoices.d.ts +54 -0
  24. package/dist/commonjs/models/operations/listvendorinvoices.d.ts.map +1 -1
  25. package/dist/commonjs/models/operations/listvendorinvoices.js +35 -1
  26. package/dist/commonjs/models/operations/listvendorinvoices.js.map +1 -1
  27. package/dist/commonjs/react-query/vendorsListVendorInvoices.d.ts +6 -0
  28. package/dist/commonjs/react-query/vendorsListVendorInvoices.d.ts.map +1 -1
  29. package/dist/commonjs/react-query/vendorsListVendorInvoices.js +4 -0
  30. package/dist/commonjs/react-query/vendorsListVendorInvoices.js.map +1 -1
  31. package/dist/esm/__tests__/vendors.test.js +1 -1
  32. package/dist/esm/__tests__/webhooks.test.js +1 -1
  33. package/dist/esm/__tests__/webhooks.test.js.map +1 -1
  34. package/dist/esm/funcs/vendorsListVendorInvoices.js +2 -0
  35. package/dist/esm/funcs/vendorsListVendorInvoices.js.map +1 -1
  36. package/dist/esm/lib/config.d.ts +3 -3
  37. package/dist/esm/lib/config.js +3 -3
  38. package/dist/esm/mcp-server/mcp-server.js +1 -1
  39. package/dist/esm/mcp-server/prompts.d.ts.map +1 -1
  40. package/dist/esm/mcp-server/prompts.js +5 -1
  41. package/dist/esm/mcp-server/prompts.js.map +1 -1
  42. package/dist/esm/mcp-server/resources.d.ts.map +1 -1
  43. package/dist/esm/mcp-server/resources.js +10 -2
  44. package/dist/esm/mcp-server/resources.js.map +1 -1
  45. package/dist/esm/mcp-server/server.d.ts.map +1 -1
  46. package/dist/esm/mcp-server/server.js +2 -3
  47. package/dist/esm/mcp-server/server.js.map +1 -1
  48. package/dist/esm/mcp-server/tools.d.ts.map +1 -1
  49. package/dist/esm/mcp-server/tools.js +4 -3
  50. package/dist/esm/mcp-server/tools.js.map +1 -1
  51. package/dist/esm/models/operations/listvendorinvoices.d.ts +54 -0
  52. package/dist/esm/models/operations/listvendorinvoices.d.ts.map +1 -1
  53. package/dist/esm/models/operations/listvendorinvoices.js +34 -0
  54. package/dist/esm/models/operations/listvendorinvoices.js.map +1 -1
  55. package/dist/esm/react-query/vendorsListVendorInvoices.d.ts +6 -0
  56. package/dist/esm/react-query/vendorsListVendorInvoices.d.ts.map +1 -1
  57. package/dist/esm/react-query/vendorsListVendorInvoices.js +4 -0
  58. package/dist/esm/react-query/vendorsListVendorInvoices.js.map +1 -1
  59. package/jsr.json +1 -1
  60. package/package.json +1 -1
  61. package/src/__tests__/vendors.test.ts +1 -1
  62. package/src/__tests__/webhooks.test.ts +1 -1
  63. package/src/funcs/vendorsListVendorInvoices.ts +2 -0
  64. package/src/lib/config.ts +3 -3
  65. package/src/mcp-server/mcp-server.ts +1 -1
  66. package/src/mcp-server/prompts.ts +8 -1
  67. package/src/mcp-server/resources.ts +16 -2
  68. package/src/mcp-server/server.ts +3 -3
  69. package/src/mcp-server/tools.ts +6 -3
  70. package/src/models/operations/listvendorinvoices.ts +56 -0
  71. package/src/react-query/vendorsListVendorInvoices.ts +10 -0
@@ -74,7 +74,14 @@ export function createRegisterPrompt(
74
74
  prompt: PromptDefinition<A>,
75
75
  ): void => {
76
76
  const scopes = prompt.scopes ?? [];
77
- if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
77
+ if (allowedScopes.size > 0 && scopes.length === 0) {
78
+ return;
79
+ }
80
+
81
+ if (
82
+ allowedScopes.size > 0
83
+ && !scopes.every((s: MCPScope) => allowedScopes.has(s))
84
+ ) {
78
85
  return;
79
86
  }
80
87
 
@@ -109,7 +109,14 @@ export function createRegisterResource(
109
109
  ): (resource: ResourceDefinition) => void {
110
110
  return (resource: ResourceDefinition): void => {
111
111
  const scopes = resource.scopes ?? [];
112
- if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
112
+ if (allowedScopes.size > 0 && scopes.length === 0) {
113
+ return;
114
+ }
115
+
116
+ if (
117
+ allowedScopes.size > 0
118
+ && !scopes.every((s: MCPScope) => allowedScopes.has(s))
119
+ ) {
113
120
  return;
114
121
  }
115
122
 
@@ -137,7 +144,14 @@ export function createRegisterResourceTemplate(
137
144
  ): (resource: ResourceTemplateDefinition) => void {
138
145
  return (resource: ResourceTemplateDefinition): void => {
139
146
  const scopes = resource.scopes ?? [];
140
- if (!scopes.every((s: MCPScope) => allowedScopes.has(s))) {
147
+ if (allowedScopes.size > 0 && scopes.length === 0) {
148
+ return;
149
+ }
150
+
151
+ if (
152
+ allowedScopes.size > 0
153
+ && !scopes.every((s: MCPScope) => allowedScopes.has(s))
154
+ ) {
141
155
  return;
142
156
  }
143
157
 
@@ -11,7 +11,7 @@ import {
11
11
  createRegisterResource,
12
12
  createRegisterResourceTemplate,
13
13
  } from "./resources.js";
14
- import { MCPScope, mcpScopes } from "./scopes.js";
14
+ import { MCPScope } from "./scopes.js";
15
15
  import { createRegisterTool } from "./tools.js";
16
16
  import { tool$organizationsGetFacility } from "./tools/organizationsGetFacility.js";
17
17
  import { tool$organizationsListOrSearchFacilities } from "./tools/organizationsListOrSearchFacilities.js";
@@ -56,7 +56,7 @@ export function createMCPServer(deps: {
56
56
  }) {
57
57
  const server = new McpServer({
58
58
  name: "GreenSecurity",
59
- version: "0.30.15",
59
+ version: "0.30.17",
60
60
  });
61
61
 
62
62
  const client = new GreenSecurityCore({
@@ -65,7 +65,7 @@ export function createMCPServer(deps: {
65
65
  serverIdx: deps.serverIdx,
66
66
  });
67
67
 
68
- const scopes = new Set(deps.scopes ?? mcpScopes);
68
+ const scopes = new Set(deps.scopes);
69
69
 
70
70
  const allowedTools = deps.allowedTools && new Set(deps.allowedTools);
71
71
  const tool = createRegisterTool(
@@ -102,12 +102,15 @@ export function createRegisterTool(
102
102
  return;
103
103
  }
104
104
 
105
- const toolScopes = tool.scopes ?? [];
106
- if (allowedScopes.size > 0 && toolScopes.length === 0) {
105
+ const scopes = tool.scopes ?? [];
106
+ if (allowedScopes.size > 0 && scopes.length === 0) {
107
107
  return;
108
108
  }
109
109
 
110
- if (!toolScopes.every((s) => allowedScopes.has(s))) {
110
+ if (
111
+ allowedScopes.size > 0
112
+ && !scopes.every((s: MCPScope) => allowedScopes.has(s))
113
+ ) {
111
114
  return;
112
115
  }
113
116
 
@@ -5,10 +5,27 @@
5
5
  import * as z from "zod";
6
6
  import { remap as remap$ } from "../../lib/primitives.js";
7
7
  import { safeParse } from "../../lib/schemas.js";
8
+ import { ClosedEnum } from "../../types/enums.js";
8
9
  import { Result as SafeParseResult } from "../../types/fp.js";
9
10
  import * as components from "../components/index.js";
10
11
  import { SDKValidationError } from "../errors/sdkvalidationerror.js";
11
12
 
13
+ /**
14
+ * Filter invoices by status
15
+ */
16
+ export const InvoiceStatus = {
17
+ Cart: "cart",
18
+ Pending: "pending",
19
+ Canceled: "canceled",
20
+ ReadyToShip: "ready to ship",
21
+ Processed: "processed",
22
+ UnderReview: "under review",
23
+ } as const;
24
+ /**
25
+ * Filter invoices by status
26
+ */
27
+ export type InvoiceStatus = ClosedEnum<typeof InvoiceStatus>;
28
+
12
29
  export type ListVendorInvoicesRequest = {
13
30
  /**
14
31
  * A comma-separated list of object attributes to sort on.
@@ -34,6 +51,14 @@ export type ListVendorInvoicesRequest = {
34
51
  * Either the ID of the vendor rep or the keyword "me" to represent the current vendor.
35
52
  */
36
53
  vendorIdOrMe: string;
54
+ /**
55
+ * Filter invoices by invoice number
56
+ */
57
+ invoiceNumber?: string | undefined;
58
+ /**
59
+ * Filter invoices by status
60
+ */
61
+ invoiceStatus?: InvoiceStatus | undefined;
37
62
  };
38
63
 
39
64
  /**
@@ -51,6 +76,27 @@ export type ListVendorInvoicesResponse = {
51
76
  result: ListVendorInvoicesResponseBody;
52
77
  };
53
78
 
79
+ /** @internal */
80
+ export const InvoiceStatus$inboundSchema: z.ZodNativeEnum<
81
+ typeof InvoiceStatus
82
+ > = z.nativeEnum(InvoiceStatus);
83
+
84
+ /** @internal */
85
+ export const InvoiceStatus$outboundSchema: z.ZodNativeEnum<
86
+ typeof InvoiceStatus
87
+ > = InvoiceStatus$inboundSchema;
88
+
89
+ /**
90
+ * @internal
91
+ * @deprecated This namespace will be removed in future versions. Use schemas and types that are exported directly from this module.
92
+ */
93
+ export namespace InvoiceStatus$ {
94
+ /** @deprecated use `InvoiceStatus$inboundSchema` instead. */
95
+ export const inboundSchema = InvoiceStatus$inboundSchema;
96
+ /** @deprecated use `InvoiceStatus$outboundSchema` instead. */
97
+ export const outboundSchema = InvoiceStatus$outboundSchema;
98
+ }
99
+
54
100
  /** @internal */
55
101
  export const ListVendorInvoicesRequest$inboundSchema: z.ZodType<
56
102
  ListVendorInvoicesRequest,
@@ -63,10 +109,14 @@ export const ListVendorInvoicesRequest$inboundSchema: z.ZodType<
63
109
  items_per_page: z.number().int().optional(),
64
110
  expand: z.array(components.Expand$inboundSchema).optional(),
65
111
  vendor_id_or_me: z.string(),
112
+ invoice_number: z.string().optional(),
113
+ invoice_status: InvoiceStatus$inboundSchema.optional(),
66
114
  }).transform((v) => {
67
115
  return remap$(v, {
68
116
  "items_per_page": "itemsPerPage",
69
117
  "vendor_id_or_me": "vendorIdOrMe",
118
+ "invoice_number": "invoiceNumber",
119
+ "invoice_status": "invoiceStatus",
70
120
  });
71
121
  });
72
122
 
@@ -78,6 +128,8 @@ export type ListVendorInvoicesRequest$Outbound = {
78
128
  items_per_page?: number | undefined;
79
129
  expand?: Array<string> | undefined;
80
130
  vendor_id_or_me: string;
131
+ invoice_number?: string | undefined;
132
+ invoice_status?: string | undefined;
81
133
  };
82
134
 
83
135
  /** @internal */
@@ -92,10 +144,14 @@ export const ListVendorInvoicesRequest$outboundSchema: z.ZodType<
92
144
  itemsPerPage: z.number().int().optional(),
93
145
  expand: z.array(components.Expand$outboundSchema).optional(),
94
146
  vendorIdOrMe: z.string(),
147
+ invoiceNumber: z.string().optional(),
148
+ invoiceStatus: InvoiceStatus$outboundSchema.optional(),
95
149
  }).transform((v) => {
96
150
  return remap$(v, {
97
151
  itemsPerPage: "items_per_page",
98
152
  vendorIdOrMe: "vendor_id_or_me",
153
+ invoiceNumber: "invoice_number",
154
+ invoiceStatus: "invoice_status",
99
155
  });
100
156
  });
101
157
 
@@ -208,6 +208,8 @@ export function setVendorsListVendorInvoicesData(
208
208
  page?: number | undefined;
209
209
  itemsPerPage?: number | undefined;
210
210
  expand?: Array<components.Expand> | undefined;
211
+ invoiceNumber?: string | undefined;
212
+ invoiceStatus?: operations.InvoiceStatus | undefined;
211
213
  },
212
214
  ],
213
215
  data: VendorsListVendorInvoicesQueryData,
@@ -228,6 +230,8 @@ export function invalidateVendorsListVendorInvoices(
228
230
  page?: number | undefined;
229
231
  itemsPerPage?: number | undefined;
230
232
  expand?: Array<components.Expand> | undefined;
233
+ invoiceNumber?: string | undefined;
234
+ invoiceStatus?: operations.InvoiceStatus | undefined;
231
235
  },
232
236
  ]
233
237
  >,
@@ -275,6 +279,8 @@ export function buildVendorsListVendorInvoicesQuery(
275
279
  page: request.page,
276
280
  itemsPerPage: request.itemsPerPage,
277
281
  expand: request.expand,
282
+ invoiceNumber: request.invoiceNumber,
283
+ invoiceStatus: request.invoiceStatus,
278
284
  }),
279
285
  queryFn: async function vendorsListVendorInvoicesQueryFn(
280
286
  ctx,
@@ -314,6 +320,8 @@ export function buildVendorsListVendorInvoicesInfiniteQuery(
314
320
  page: request.page,
315
321
  itemsPerPage: request.itemsPerPage,
316
322
  expand: request.expand,
323
+ invoiceNumber: request.invoiceNumber,
324
+ invoiceStatus: request.invoiceStatus,
317
325
  }),
318
326
  queryFn: async function vendorsListVendorInvoicesQuery(
319
327
  ctx,
@@ -352,6 +360,8 @@ export function queryKeyVendorsListVendorInvoices(
352
360
  page?: number | undefined;
353
361
  itemsPerPage?: number | undefined;
354
362
  expand?: Array<components.Expand> | undefined;
363
+ invoiceNumber?: string | undefined;
364
+ invoiceStatus?: operations.InvoiceStatus | undefined;
355
365
  },
356
366
  ): QueryKey {
357
367
  return [