@envive-ai/react-hooks 0.3.18 → 0.3.19

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 (196) hide show
  1. package/dist/application/commerce-api.cjs +14 -13
  2. package/dist/application/commerce-api.js +14 -13
  3. package/dist/application/logging/logger.cjs +16 -10
  4. package/dist/application/logging/logger.js +16 -10
  5. package/dist/application/models/guards/api/isApiFormResponse.cjs +9 -8
  6. package/dist/application/models/guards/api/isApiFormResponse.js +9 -8
  7. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.cjs +6 -5
  8. package/dist/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +6 -5
  9. package/dist/application/models/guards/api/isApiOrderResponseAttributes.cjs +19 -18
  10. package/dist/application/models/guards/api/isApiOrderResponseAttributes.js +19 -18
  11. package/dist/application/models/guards/api/isApiOrgConfigResults.cjs +27 -26
  12. package/dist/application/models/guards/api/isApiOrgConfigResults.js +27 -26
  13. package/dist/application/models/guards/api/isApiOrganizationConfig.cjs +23 -22
  14. package/dist/application/models/guards/api/isApiOrganizationConfig.js +23 -22
  15. package/dist/application/models/guards/api/isApiProductResponseAttributes.cjs +12 -11
  16. package/dist/application/models/guards/api/isApiProductResponseAttributes.js +12 -11
  17. package/dist/application/models/guards/api/isApiResponse.cjs +7 -6
  18. package/dist/application/models/guards/api/isApiResponse.js +7 -6
  19. package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.cjs +5 -4
  20. package/dist/application/models/guards/graphQL/isGraphQLColorsConfig.js +5 -4
  21. package/dist/application/models/validators/validateGraphQLFrontendConfig.cjs +15 -14
  22. package/dist/application/models/validators/validateGraphQLFrontendConfig.js +15 -14
  23. package/dist/application/utils/analyticsUtils.cjs +4 -3
  24. package/dist/application/utils/analyticsUtils.js +4 -3
  25. package/dist/application/utils/nextMessageRequestToApiRequest.cjs +3 -1
  26. package/dist/application/utils/nextMessageRequestToApiRequest.js +3 -1
  27. package/dist/atoms/app/index.d.cts +7 -7
  28. package/dist/atoms/app/index.d.ts +7 -7
  29. package/dist/atoms/app/variant.cjs +3 -2
  30. package/dist/atoms/app/variant.js +3 -2
  31. package/dist/atoms/chat/chatState.d.cts +17 -17
  32. package/dist/atoms/chat/chatState.d.ts +17 -17
  33. package/dist/atoms/chat/form.d.cts +2 -2
  34. package/dist/atoms/chat/form.d.ts +2 -2
  35. package/dist/atoms/chat/index.d.cts +2 -2
  36. package/dist/atoms/chat/index.d.ts +2 -2
  37. package/dist/atoms/chat/lastMessage.d.cts +2 -2
  38. package/dist/atoms/chat/lastMessage.d.ts +2 -2
  39. package/dist/atoms/chat/messageQueue.d.cts +6 -6
  40. package/dist/atoms/chat/messageQueue.d.ts +6 -6
  41. package/dist/atoms/chat/performanceMetrics.cjs +3 -2
  42. package/dist/atoms/chat/performanceMetrics.d.cts +6 -6
  43. package/dist/atoms/chat/performanceMetrics.d.ts +6 -6
  44. package/dist/atoms/chat/performanceMetrics.js +3 -2
  45. package/dist/atoms/chat/renderedWidgetRefs.d.cts +2 -2
  46. package/dist/atoms/chat/renderedWidgetRefs.d.ts +2 -2
  47. package/dist/atoms/chat/replies.d.cts +2 -2
  48. package/dist/atoms/chat/replies.d.ts +3 -3
  49. package/dist/atoms/chat/suggestions.d.cts +2 -2
  50. package/dist/atoms/chat/suggestions.d.ts +2 -2
  51. package/dist/atoms/envive/enviveConfig.cjs +5 -4
  52. package/dist/atoms/envive/enviveConfig.d.cts +13 -13
  53. package/dist/atoms/envive/enviveConfig.d.ts +13 -13
  54. package/dist/atoms/envive/enviveConfig.js +5 -4
  55. package/dist/atoms/globalSearch/globalSearch.d.cts +5 -5
  56. package/dist/atoms/globalSearch/globalSearch.d.ts +5 -5
  57. package/dist/atoms/org/customerService.d.cts +6 -6
  58. package/dist/atoms/org/customerService.d.ts +6 -6
  59. package/dist/atoms/org/graphqlConfig.d.cts +4 -4
  60. package/dist/atoms/org/graphqlConfig.d.ts +4 -4
  61. package/dist/atoms/org/newOrgConfigAtom.d.cts +2 -2
  62. package/dist/atoms/org/newOrgConfigAtom.d.ts +2 -2
  63. package/dist/atoms/org/orgAnalyticsConfig.d.cts +5 -5
  64. package/dist/atoms/org/orgAnalyticsConfig.d.ts +5 -5
  65. package/dist/atoms/search/chatSearch.d.cts +17 -17
  66. package/dist/atoms/search/chatSearch.d.ts +17 -17
  67. package/dist/atoms/search/searchAPI.d.cts +13 -13
  68. package/dist/atoms/search/searchAPI.d.ts +13 -13
  69. package/dist/atoms/search/types.d.cts +1 -1
  70. package/dist/atoms/search/types.d.ts +1 -1
  71. package/dist/atoms/search/utils.d.ts +1 -1
  72. package/dist/atoms/widget/chatPreviewLoading.d.cts +2 -2
  73. package/dist/atoms/widget/chatPreviewLoading.d.ts +2 -2
  74. package/dist/contexts/amplitudeContext/amplitudeContext.cjs +4 -3
  75. package/dist/contexts/amplitudeContext/amplitudeContext.js +3 -2
  76. package/dist/contexts/enviveConfigContext/enviveConfigContext.cjs +26 -15
  77. package/dist/contexts/enviveConfigContext/enviveConfigContext.d.cts +2 -4
  78. package/dist/contexts/enviveConfigContext/enviveConfigContext.d.ts +2 -4
  79. package/dist/contexts/enviveConfigContext/enviveConfigContext.js +29 -16
  80. package/dist/contexts/enviveConfigContext/index.cjs +2 -1
  81. package/dist/contexts/enviveConfigContext/index.d.cts +2 -1
  82. package/dist/contexts/enviveConfigContext/index.d.ts +2 -1
  83. package/dist/contexts/enviveConfigContext/index.js +2 -1
  84. package/dist/contexts/enviveConfigContext/useEnviveConfig.cjs +12 -0
  85. package/dist/contexts/enviveConfigContext/useEnviveConfig.d.cts +7 -0
  86. package/dist/contexts/enviveConfigContext/useEnviveConfig.d.ts +7 -0
  87. package/dist/contexts/enviveConfigContext/useEnviveConfig.js +11 -0
  88. package/dist/contexts/enviveContext/WindowChatToggleBinder.cjs +7 -5
  89. package/dist/contexts/enviveContext/WindowChatToggleBinder.js +6 -4
  90. package/dist/contexts/enviveContext/enviveContext.cjs +34 -39
  91. package/dist/contexts/enviveContext/enviveContext.js +35 -40
  92. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.cjs +7 -6
  93. package/dist/contexts/featureFlagServiceContext/featureFlagServiceContext.js +7 -6
  94. package/dist/contexts/graphqlContext/graphqlContext.cjs +8 -7
  95. package/dist/contexts/graphqlContext/graphqlContext.js +8 -7
  96. package/dist/contexts/hardcopyContext/hardcopyContext.cjs +9 -8
  97. package/dist/contexts/hardcopyContext/hardcopyContext.js +9 -8
  98. package/dist/contexts/localStorageContext/localStorageContext.cjs +4 -3
  99. package/dist/contexts/localStorageContext/localStorageContext.js +4 -3
  100. package/dist/contexts/pageContext/pageContext.cjs +3 -2
  101. package/dist/contexts/pageContext/pageContext.js +3 -2
  102. package/dist/contexts/salesAgentContext/chatAPI.cjs +3 -2
  103. package/dist/contexts/salesAgentContext/chatAPI.js +3 -2
  104. package/dist/contexts/salesAgentContext/salesAgentContext.cjs +4 -3
  105. package/dist/contexts/salesAgentContext/salesAgentContext.js +4 -3
  106. package/dist/contexts/salesAgentContext/salesAgentService.cjs +3 -2
  107. package/dist/contexts/salesAgentContext/salesAgentService.js +3 -2
  108. package/dist/contexts/searchContext/searchContext.cjs +8 -6
  109. package/dist/contexts/searchContext/searchContext.js +7 -5
  110. package/dist/contexts/sessionStorageContext/sessionStorageContext.cjs +3 -2
  111. package/dist/contexts/sessionStorageContext/sessionStorageContext.js +3 -2
  112. package/dist/contexts/systemSettingsContext/systemSettingsContext.d.cts +2 -2
  113. package/dist/contexts/types.d.cts +1 -1
  114. package/dist/contexts/types.d.ts +1 -1
  115. package/dist/contexts/typesV3.d.cts +1 -1
  116. package/dist/contexts/typesV3.d.ts +1 -1
  117. package/dist/contexts/uiConfigContext/index.cjs +0 -1
  118. package/dist/contexts/uiConfigContext/index.d.cts +2 -2
  119. package/dist/contexts/uiConfigContext/index.d.ts +2 -2
  120. package/dist/contexts/uiConfigContext/index.js +2 -2
  121. package/dist/contexts/uiConfigContext/uiConfigContext.cjs +13 -30
  122. package/dist/contexts/uiConfigContext/uiConfigContext.d.cts +5 -9
  123. package/dist/contexts/uiConfigContext/uiConfigContext.d.ts +5 -9
  124. package/dist/contexts/uiConfigContext/uiConfigContext.js +14 -29
  125. package/dist/contexts/userIdentityContext/userIdentityContext.cjs +7 -7
  126. package/dist/contexts/userIdentityContext/userIdentityContext.js +7 -7
  127. package/dist/contexts/widgetConfigContext/widgetConfigContext.cjs +4 -3
  128. package/dist/contexts/widgetConfigContext/widgetConfigContext.js +4 -3
  129. package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.cjs +4 -3
  130. package/dist/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.js +4 -3
  131. package/dist/hooks/GrabAndScroll/useGrabAndScroll.d.cts +2 -2
  132. package/dist/hooks/SystemSettingsContext/useSystemSettingsContext.d.cts +2 -2
  133. package/dist/hooks/WidgetInteraction/useWidgetInteraction.cjs +2 -2
  134. package/dist/hooks/WidgetInteraction/useWidgetInteraction.js +2 -2
  135. package/dist/hooks/WidgetInteraction/utils.cjs +2 -1
  136. package/dist/hooks/WidgetInteraction/utils.js +2 -1
  137. package/dist/hooks/utils.d.cts +1 -1
  138. package/dist/hooks/utils.d.ts +1 -1
  139. package/dist/services/amplitudeService/amplitudeService.cjs +8 -7
  140. package/dist/services/amplitudeService/amplitudeService.js +8 -7
  141. package/dist/services/ga4ProjectionService/ga4ProjectionService.cjs +3 -2
  142. package/dist/services/ga4ProjectionService/ga4ProjectionService.js +3 -2
  143. package/dist/services/userIdentityService/userIdentityService.cjs +8 -7
  144. package/dist/services/userIdentityService/userIdentityService.js +8 -7
  145. package/package.json +1 -1
  146. package/src/application/commerce-api.ts +14 -12
  147. package/src/application/logging/logger.ts +33 -8
  148. package/src/application/models/guards/api/isApiFormResponse.ts +9 -7
  149. package/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.ts +6 -4
  150. package/src/application/models/guards/api/isApiOrderResponseAttributes.ts +19 -17
  151. package/src/application/models/guards/api/isApiOrgConfigResults.ts +40 -48
  152. package/src/application/models/guards/api/isApiOrganizationConfig.ts +25 -38
  153. package/src/application/models/guards/api/isApiProductResponseAttributes.ts +12 -10
  154. package/src/application/models/guards/api/isApiResponse.ts +7 -5
  155. package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +5 -3
  156. package/src/application/models/validators/validateGraphQLFrontendConfig.ts +15 -13
  157. package/src/application/utils/analyticsUtils.ts +4 -4
  158. package/src/application/utils/nextMessageRequestToApiRequest.ts +2 -0
  159. package/src/atoms/app/variant.ts +3 -1
  160. package/src/atoms/chat/performanceMetrics.ts +3 -1
  161. package/src/atoms/envive/enviveConfig.ts +5 -3
  162. package/src/contexts/amplitudeContext/amplitudeContext.tsx +1 -1
  163. package/src/contexts/enviveConfigContext/__tests__/enviveConfigContext.test.tsx +4 -3
  164. package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +50 -35
  165. package/src/contexts/enviveConfigContext/index.ts +1 -0
  166. package/src/contexts/enviveConfigContext/useEnviveConfig.ts +9 -0
  167. package/src/contexts/enviveContext/WindowChatToggleBinder.tsx +6 -4
  168. package/src/contexts/enviveContext/enviveContext.tsx +40 -45
  169. package/src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx +11 -12
  170. package/src/contexts/graphqlContext/__tests__/graphqlContext.test.tsx +4 -4
  171. package/src/contexts/graphqlContext/graphqlContext.tsx +8 -6
  172. package/src/contexts/hardcopyContext/hardcopyContext.tsx +9 -7
  173. package/src/contexts/localStorageContext/__tests__/localStorageContext.test.tsx +6 -6
  174. package/src/contexts/localStorageContext/localStorageContext.tsx +4 -2
  175. package/src/contexts/pageContext/__tests__/pageContext.test.tsx +5 -5
  176. package/src/contexts/pageContext/pageContext.tsx +3 -1
  177. package/src/contexts/salesAgentContext/chatAPI.ts +5 -5
  178. package/src/contexts/salesAgentContext/salesAgentContext.tsx +4 -2
  179. package/src/contexts/salesAgentContext/salesAgentService.ts +4 -2
  180. package/src/contexts/searchContext/__tests__/searchContext.test.tsx +15 -12
  181. package/src/contexts/searchContext/searchContext.tsx +6 -4
  182. package/src/contexts/sessionStorageContext/sessionStorageContext.tsx +3 -1
  183. package/src/contexts/uiConfigContext/__tests__/uiConfigContext.test.tsx +7 -32
  184. package/src/contexts/uiConfigContext/uiConfigContext.tsx +17 -29
  185. package/src/contexts/userIdentityContext/__tests__/userIdentityContext.test.tsx +5 -5
  186. package/src/contexts/userIdentityContext/userIdentityContext.tsx +7 -6
  187. package/src/contexts/widgetConfigContext/__tests__/widgetConfigContext.test.tsx +7 -7
  188. package/src/contexts/widgetConfigContext/widgetConfigContext.tsx +4 -2
  189. package/src/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.ts +4 -2
  190. package/src/hooks/Search/__tests__/useSearch.test.tsx +14 -8
  191. package/src/hooks/WidgetInteraction/useWidgetInteraction.ts +3 -2
  192. package/src/hooks/WidgetInteraction/utils.ts +3 -1
  193. package/src/services/amplitudeService/__tests__/amplitudeService.test.ts +3 -3
  194. package/src/services/amplitudeService/amplitudeService.ts +8 -6
  195. package/src/services/ga4ProjectionService/ga4ProjectionService.ts +3 -1
  196. package/src/services/userIdentityService/userIdentityService.ts +8 -8
@@ -2,76 +2,77 @@ import logger_default from "../../../logging/logger.js";
2
2
  import { hasPropertyOfType } from "../utils.js";
3
3
 
4
4
  //#region src/application/models/guards/api/isApiOrderResponseAttributes.ts
5
+ const logger = new logger_default("isApiOrderResponseAttributes");
5
6
  const isApiOrderItemInfo = (data) => {
6
7
  if (data == null || typeof data !== "object") {
7
- logger_default.logError("OrderItemInfo must be an object", void 0, { data });
8
+ logger.logError("OrderItemInfo must be an object", void 0, { data });
8
9
  return false;
9
10
  }
10
11
  if (!hasPropertyOfType(data, "order_item_id", "string")) {
11
- logger_default.logError("OrderItemInfo must have an order_item_id property", void 0, { data });
12
+ logger.logError("OrderItemInfo must have an order_item_id property", void 0, { data });
12
13
  return false;
13
14
  }
14
15
  if (!hasPropertyOfType(data, "item_title", "string")) {
15
- logger_default.logError("OrderItemInfo must have an item_title property", void 0, { data });
16
+ logger.logError("OrderItemInfo must have an item_title property", void 0, { data });
16
17
  return false;
17
18
  }
18
19
  if (!hasPropertyOfType(data, "item_price", "number")) {
19
- logger_default.logError("OrderItemInfo must have an item_price property", void 0, { data });
20
+ logger.logError("OrderItemInfo must have an item_price property", void 0, { data });
20
21
  return false;
21
22
  }
22
23
  if (!hasPropertyOfType(data, "item_quantity", "number")) {
23
- logger_default.logError("OrderItemInfo must have an item_quantity property", void 0, { data });
24
+ logger.logError("OrderItemInfo must have an item_quantity property", void 0, { data });
24
25
  return false;
25
26
  }
26
27
  if (!hasPropertyOfType(data, "image", "string", true)) {
27
- logger_default.logError("OrderItemInfo.image must be a string or null", void 0, { data });
28
+ logger.logError("OrderItemInfo.image must be a string or null", void 0, { data });
28
29
  return false;
29
30
  }
30
31
  if (!hasPropertyOfType(data, "fulfillment_display_status", "string", true)) {
31
- logger_default.logError("OrderItemInfo.fulfillment_display_status must be a string or null", void 0, { data });
32
+ logger.logError("OrderItemInfo.fulfillment_display_status must be a string or null", void 0, { data });
32
33
  return false;
33
34
  }
34
35
  if (!hasPropertyOfType(data, "tracking_url", "string", true)) {
35
- logger_default.logError("OrderItemInfo.tracking_url must be a string or null", void 0, { data });
36
+ logger.logError("OrderItemInfo.tracking_url must be a string or null", void 0, { data });
36
37
  return false;
37
38
  }
38
39
  if (!hasPropertyOfType(data, "delivered_at", "string", true)) {
39
- logger_default.logError("OrderItemInfo.delivered_at must be a string or null", void 0, { data });
40
+ logger.logError("OrderItemInfo.delivered_at must be a string or null", void 0, { data });
40
41
  return false;
41
42
  }
42
43
  if (!hasPropertyOfType(data, "estimated_delivery_at", "string", true)) {
43
- logger_default.logError("OrderItemInfo.estimated_delivery_at must be a string or null", void 0, { data });
44
+ logger.logError("OrderItemInfo.estimated_delivery_at must be a string or null", void 0, { data });
44
45
  return false;
45
46
  }
46
47
  if (!hasPropertyOfType(data, "in_transit_at", "string", true)) {
47
- logger_default.logError("OrderItemInfo.in_transit_at must be a string or null", void 0, { data });
48
+ logger.logError("OrderItemInfo.in_transit_at must be a string or null", void 0, { data });
48
49
  return false;
49
50
  }
50
51
  return true;
51
52
  };
52
53
  const isApiOrderResponseAttributes = (data) => {
53
54
  if (data == null || typeof data !== "object") {
54
- logger_default.logError("Order response attributes must be an object", void 0, { data });
55
+ logger.logError("Order response attributes must be an object", void 0, { data });
55
56
  return false;
56
57
  }
57
58
  if (!hasPropertyOfType(data, "created_at", "string")) {
58
- logger_default.logError("Order response attributes must have a created_at property and have type string", void 0, { data });
59
+ logger.logError("Order response attributes must have a created_at property and have type string", void 0, { data });
59
60
  return false;
60
61
  }
61
62
  if (!hasPropertyOfType(data, "latest_event_date", "string")) {
62
- logger_default.logError("Order response attributes must have a latest_event_date property and have type string", void 0, { data });
63
+ logger.logError("Order response attributes must have a latest_event_date property and have type string", void 0, { data });
63
64
  return false;
64
65
  }
65
66
  if (!hasPropertyOfType(data, "line_items", "array") || !data.line_items.every((item) => isApiOrderItemInfo(item))) {
66
- logger_default.logError("Order response attributes must have a line_items property with at least one order item", void 0, { data });
67
+ logger.logError("Order response attributes must have a line_items property with at least one order item", void 0, { data });
67
68
  return false;
68
69
  }
69
70
  if (!hasPropertyOfType(data, "order_id", "string")) {
70
- logger_default.logError("Order response attributes must have an order_id property and have type string", void 0, { data });
71
+ logger.logError("Order response attributes must have an order_id property and have type string", void 0, { data });
71
72
  return false;
72
73
  }
73
74
  if (!hasPropertyOfType(data, "order_number", "string")) {
74
- logger_default.logError("Order response attributes must have an order_number property and have type string", void 0, { data });
75
+ logger.logError("Order response attributes must have an order_number property and have type string", void 0, { data });
75
76
  return false;
76
77
  }
77
78
  return true;
@@ -79,4 +80,4 @@ const isApiOrderResponseAttributes = (data) => {
79
80
 
80
81
  //#endregion
81
82
  export { isApiOrderResponseAttributes };
82
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrderResponseAttributes.js","names":[],"sources":["../../../../../src/application/models/guards/api/isApiOrderResponseAttributes.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport { OrderItemInfo, OrderResponseAttributes } from '@spiffy-ai/commerce-api-client';\nimport { hasPropertyOfType } from 'src/application/models/guards/utils';\n\n// the client SDK generates date-time format types as `Date` but the openapi typescript generator\n// does not correctly deserialize date-time values so they are always `string` at runtime instead of\n// `Date` objects. These interfaces override the SDK types so that we can validate against the actual\n// `string` values. https://github.com/OpenAPITools/openapi-generator/issues/926\nexport interface ApiOrderItemInfo extends Omit<\n  OrderItemInfo,\n  'delivered_at' | 'estimated_delivery_at' | 'in_transit_at'\n> {\n  delivered_at?: string;\n  estimated_delivery_at?: string;\n  in_transit_at?: string;\n}\n\nexport interface ApiOrderResponseAttributes extends Omit<\n  OrderResponseAttributes,\n  'created_at' | 'latest_event_date' | 'line_items'\n> {\n  created_at: string;\n  latest_event_date: string;\n  line_items: ApiOrderItemInfo[];\n}\n\nconst isApiOrderItemInfo = (data: unknown): data is ApiOrderItemInfo => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logError('OrderItemInfo must be an object', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_item_id', 'string')) {\n    Logger.logError('OrderItemInfo must have an order_item_id property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_title', 'string')) {\n    Logger.logError('OrderItemInfo must have an item_title property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_price', 'number')) {\n    Logger.logError('OrderItemInfo must have an item_price property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_quantity', 'number')) {\n    Logger.logError('OrderItemInfo must have an item_quantity property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'image', 'string', true)) {\n    Logger.logError('OrderItemInfo.image must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'fulfillment_display_status', 'string', true)) {\n    Logger.logError(\n      'OrderItemInfo.fulfillment_display_status must be a string or null',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'tracking_url', 'string', true)) {\n    Logger.logError('OrderItemInfo.tracking_url must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'delivered_at', 'string', true)) {\n    Logger.logError('OrderItemInfo.delivered_at must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'estimated_delivery_at', 'string', true)) {\n    Logger.logError('OrderItemInfo.estimated_delivery_at must be a string or null', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'in_transit_at', 'string', true)) {\n    Logger.logError('OrderItemInfo.in_transit_at must be a string or null', undefined, { data });\n    return false;\n  }\n\n  return true;\n};\n\nexport const isApiOrderResponseAttributes = (data: unknown): data is ApiOrderResponseAttributes => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logError('Order response attributes must be an object', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'created_at', 'string')) {\n    Logger.logError(\n      'Order response attributes must have a created_at property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'latest_event_date', 'string')) {\n    Logger.logError(\n      'Order response attributes must have a latest_event_date property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !hasPropertyOfType(data, 'line_items', 'array') ||\n    !data.line_items.every((item: unknown) => isApiOrderItemInfo(item))\n  ) {\n    Logger.logError(\n      'Order response attributes must have a line_items property with at least one order item',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_id', 'string')) {\n    Logger.logError(\n      'Order response attributes must have an order_id property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_number', 'string')) {\n    Logger.logError(\n      'Order response attributes must have an order_number property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":";;;;AA0BA,MAAM,sBAAsB,SAA4C;AACtE,KAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C,iBAAO,SAAS,mCAAmC,QAAW,EAAE,MAAM,CAAC;AACvE,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,SAAS,EAAE;AACvD,iBAAO,SAAS,qDAAqD,QAAW,EAAE,MAAM,CAAC;AACzF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,iBAAO,SAAS,kDAAkD,QAAW,EAAE,MAAM,CAAC;AACtF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,iBAAO,SAAS,kDAAkD,QAAW,EAAE,MAAM,CAAC;AACtF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,SAAS,EAAE;AACvD,iBAAO,SAAS,qDAAqD,QAAW,EAAE,MAAM,CAAC;AACzF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,SAAS,UAAU,KAAK,EAAE;AACrD,iBAAO,SAAS,gDAAgD,QAAW,EAAE,MAAM,CAAC;AACpF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,8BAA8B,UAAU,KAAK,EAAE;AAC1E,iBAAO,SACL,qEACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,UAAU,KAAK,EAAE;AAC5D,iBAAO,SAAS,uDAAuD,QAAW,EAAE,MAAM,CAAC;AAC3F,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,UAAU,KAAK,EAAE;AAC5D,iBAAO,SAAS,uDAAuD,QAAW,EAAE,MAAM,CAAC;AAC3F,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,yBAAyB,UAAU,KAAK,EAAE;AACrE,iBAAO,SAAS,gEAAgE,QAAW,EACzF,MACD,CAAC;AACF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,UAAU,KAAK,EAAE;AAC7D,iBAAO,SAAS,wDAAwD,QAAW,EAAE,MAAM,CAAC;AAC5F,SAAO;;AAGT,QAAO;;AAGT,MAAa,gCAAgC,SAAsD;AACjG,KAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C,iBAAO,SAAS,+CAA+C,QAAW,EAAE,MAAM,CAAC;AACnF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,iBAAO,SACL,kFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,qBAAqB,SAAS,EAAE;AAC3D,iBAAO,SACL,yFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KACE,CAAC,kBAAkB,MAAM,cAAc,QAAQ,IAC/C,CAAC,KAAK,WAAW,OAAO,SAAkB,mBAAmB,KAAK,CAAC,EACnE;AACA,iBAAO,SACL,0FACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,YAAY,SAAS,EAAE;AAClD,iBAAO,SACL,iFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,SAAS,EAAE;AACtD,iBAAO,SACL,qFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,QAAO"}
83
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrderResponseAttributes.js","names":["Logger"],"sources":["../../../../../src/application/models/guards/api/isApiOrderResponseAttributes.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport { OrderItemInfo, OrderResponseAttributes } from '@spiffy-ai/commerce-api-client';\nimport { hasPropertyOfType } from 'src/application/models/guards/utils';\n\nconst logger = new Logger('isApiOrderResponseAttributes');\n\n// the client SDK generates date-time format types as `Date` but the openapi typescript generator\n// does not correctly deserialize date-time values so they are always `string` at runtime instead of\n// `Date` objects. These interfaces override the SDK types so that we can validate against the actual\n// `string` values. https://github.com/OpenAPITools/openapi-generator/issues/926\nexport interface ApiOrderItemInfo extends Omit<\n  OrderItemInfo,\n  'delivered_at' | 'estimated_delivery_at' | 'in_transit_at'\n> {\n  delivered_at?: string;\n  estimated_delivery_at?: string;\n  in_transit_at?: string;\n}\n\nexport interface ApiOrderResponseAttributes extends Omit<\n  OrderResponseAttributes,\n  'created_at' | 'latest_event_date' | 'line_items'\n> {\n  created_at: string;\n  latest_event_date: string;\n  line_items: ApiOrderItemInfo[];\n}\n\nconst isApiOrderItemInfo = (data: unknown): data is ApiOrderItemInfo => {\n  if (data == null || typeof data !== 'object') {\n    logger.logError('OrderItemInfo must be an object', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_item_id', 'string')) {\n    logger.logError('OrderItemInfo must have an order_item_id property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_title', 'string')) {\n    logger.logError('OrderItemInfo must have an item_title property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_price', 'number')) {\n    logger.logError('OrderItemInfo must have an item_price property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'item_quantity', 'number')) {\n    logger.logError('OrderItemInfo must have an item_quantity property', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'image', 'string', true)) {\n    logger.logError('OrderItemInfo.image must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'fulfillment_display_status', 'string', true)) {\n    logger.logError(\n      'OrderItemInfo.fulfillment_display_status must be a string or null',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'tracking_url', 'string', true)) {\n    logger.logError('OrderItemInfo.tracking_url must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'delivered_at', 'string', true)) {\n    logger.logError('OrderItemInfo.delivered_at must be a string or null', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'estimated_delivery_at', 'string', true)) {\n    logger.logError('OrderItemInfo.estimated_delivery_at must be a string or null', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'in_transit_at', 'string', true)) {\n    logger.logError('OrderItemInfo.in_transit_at must be a string or null', undefined, { data });\n    return false;\n  }\n\n  return true;\n};\n\nexport const isApiOrderResponseAttributes = (data: unknown): data is ApiOrderResponseAttributes => {\n  if (data == null || typeof data !== 'object') {\n    logger.logError('Order response attributes must be an object', undefined, { data });\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'created_at', 'string')) {\n    logger.logError(\n      'Order response attributes must have a created_at property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'latest_event_date', 'string')) {\n    logger.logError(\n      'Order response attributes must have a latest_event_date property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !hasPropertyOfType(data, 'line_items', 'array') ||\n    !data.line_items.every((item: unknown) => isApiOrderItemInfo(item))\n  ) {\n    logger.logError(\n      'Order response attributes must have a line_items property with at least one order item',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_id', 'string')) {\n    logger.logError(\n      'Order response attributes must have an order_id property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!hasPropertyOfType(data, 'order_number', 'string')) {\n    logger.logError(\n      'Order response attributes must have an order_number property and have type string',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":";;;;AAIA,MAAM,SAAS,IAAIA,eAAO,+BAA+B;AAwBzD,MAAM,sBAAsB,SAA4C;AACtE,KAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C,SAAO,SAAS,mCAAmC,QAAW,EAAE,MAAM,CAAC;AACvE,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,SAAS,EAAE;AACvD,SAAO,SAAS,qDAAqD,QAAW,EAAE,MAAM,CAAC;AACzF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,SAAO,SAAS,kDAAkD,QAAW,EAAE,MAAM,CAAC;AACtF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,SAAO,SAAS,kDAAkD,QAAW,EAAE,MAAM,CAAC;AACtF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,SAAS,EAAE;AACvD,SAAO,SAAS,qDAAqD,QAAW,EAAE,MAAM,CAAC;AACzF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,SAAS,UAAU,KAAK,EAAE;AACrD,SAAO,SAAS,gDAAgD,QAAW,EAAE,MAAM,CAAC;AACpF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,8BAA8B,UAAU,KAAK,EAAE;AAC1E,SAAO,SACL,qEACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,UAAU,KAAK,EAAE;AAC5D,SAAO,SAAS,uDAAuD,QAAW,EAAE,MAAM,CAAC;AAC3F,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,UAAU,KAAK,EAAE;AAC5D,SAAO,SAAS,uDAAuD,QAAW,EAAE,MAAM,CAAC;AAC3F,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,yBAAyB,UAAU,KAAK,EAAE;AACrE,SAAO,SAAS,gEAAgE,QAAW,EACzF,MACD,CAAC;AACF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,iBAAiB,UAAU,KAAK,EAAE;AAC7D,SAAO,SAAS,wDAAwD,QAAW,EAAE,MAAM,CAAC;AAC5F,SAAO;;AAGT,QAAO;;AAGT,MAAa,gCAAgC,SAAsD;AACjG,KAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C,SAAO,SAAS,+CAA+C,QAAW,EAAE,MAAM,CAAC;AACnF,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,cAAc,SAAS,EAAE;AACpD,SAAO,SACL,kFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,qBAAqB,SAAS,EAAE;AAC3D,SAAO,SACL,yFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KACE,CAAC,kBAAkB,MAAM,cAAc,QAAQ,IAC/C,CAAC,KAAK,WAAW,OAAO,SAAkB,mBAAmB,KAAK,CAAC,EACnE;AACA,SAAO,SACL,0FACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,YAAY,SAAS,EAAE;AAClD,SAAO,SACL,iFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,KAAI,CAAC,kBAAkB,MAAM,gBAAgB,SAAS,EAAE;AACtD,SAAO,SACL,qFACA,QACA,EACE,MACD,CACF;AACD,SAAO;;AAGT,QAAO"}
@@ -4,94 +4,95 @@ const require_isApiOrganizationConfig = require('./isApiOrganizationConfig.cjs')
4
4
  let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
5
5
 
6
6
  //#region src/application/models/guards/api/isApiOrgConfigResults.ts
7
+ const logger = new require_logger.default("isApiOrgConfigResults");
7
8
  const isApiOrgConfigExperiment = (data) => {
8
9
  if (data == null || typeof data !== "object") {
9
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: data is not an object", void 0, { data });
10
+ logger.logDebug("isApiOrgConfigExperiment: data is not an object", void 0, { data });
10
11
  return false;
11
12
  }
12
13
  if ("group" in data && typeof data.group !== "string" && data.group !== void 0) {
13
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: group is not a string or undefined", void 0, { data });
14
+ logger.logDebug("isApiOrgConfigExperiment: group is not a string or undefined", void 0, { data });
14
15
  return false;
15
16
  }
16
17
  if ("group_name" in data && typeof data.group_name !== "string" && data.group_name !== void 0) {
17
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: group_name is not a string", void 0, { data });
18
+ logger.logDebug("isApiOrgConfigExperiment: group_name is not a string", void 0, { data });
18
19
  return false;
19
20
  }
20
21
  if ("name" in data && typeof data.name !== "string" && data.name !== void 0) {
21
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: name is not a string", void 0, { data });
22
+ logger.logDebug("isApiOrgConfigExperiment: name is not a string", void 0, { data });
22
23
  return false;
23
24
  }
24
25
  if ("rule_id" in data && typeof data.rule_id !== "string" && data.rule_id !== void 0) {
25
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: rule_id is not a string", void 0, { data });
26
+ logger.logDebug("isApiOrgConfigExperiment: rule_id is not a string", void 0, { data });
26
27
  return false;
27
28
  }
28
29
  if ("value" in data && typeof data.value !== "object" && data.value !== void 0) {
29
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: value is not an object", void 0, { data });
30
+ logger.logDebug("isApiOrgConfigExperiment: value is not an object", void 0, { data });
30
31
  return false;
31
32
  }
32
33
  return true;
33
34
  };
34
35
  const isApiOrgConfigFeatureGate = (data) => {
35
36
  if (data == null || typeof data !== "object") {
36
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: data is not an object", void 0, { data });
37
+ logger.logDebug("isApiOrgConfigFeatureGate: data is not an object", void 0, { data });
37
38
  return false;
38
39
  }
39
40
  if ("name" in data && typeof data.name !== "string" && data.name !== void 0) {
40
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: name is not a string", void 0, { data });
41
+ logger.logDebug("isApiOrgConfigFeatureGate: name is not a string", void 0, { data });
41
42
  return false;
42
43
  }
43
44
  if ("rule_id" in data && typeof data.rule_id !== "string" && data.rule_id !== void 0) {
44
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: rule_id is not a string", void 0, { data });
45
+ logger.logDebug("isApiOrgConfigFeatureGate: rule_id is not a string", void 0, { data });
45
46
  return false;
46
47
  }
47
48
  if ("value" in data && typeof data.value !== "boolean" && data.value !== void 0) {
48
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: value is not a boolean", void 0, { data });
49
+ logger.logDebug("isApiOrgConfigFeatureGate: value is not a boolean", void 0, { data });
49
50
  return false;
50
51
  }
51
52
  return true;
52
53
  };
53
54
  const isApiOrganization = (data) => {
54
55
  if (data == null || typeof data !== "object") {
55
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: data is not an object", void 0, { data });
56
+ logger.logDebug("isApiOrganization: data is not an object", void 0, { data });
56
57
  return false;
57
58
  }
58
59
  if (!("id" in data) || typeof data.id !== "string") {
59
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: id is not a string", void 0, { data });
60
+ logger.logDebug("isApiOrganization: id is not a string", void 0, { data });
60
61
  return false;
61
62
  }
62
63
  if (!("display_name" in data) || typeof data.display_name !== "string") {
63
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: display_name is not a string", void 0, { data });
64
+ logger.logDebug("isApiOrganization: display_name is not a string", void 0, { data });
64
65
  return false;
65
66
  }
66
67
  if (!("domain" in data) || typeof data.domain !== "string") {
67
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: domain is not a string", void 0, { data });
68
+ logger.logDebug("isApiOrganization: domain is not a string", void 0, { data });
68
69
  return false;
69
70
  }
70
71
  if (!("short_name" in data) || typeof data.short_name !== "string") {
71
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: short_name is not a string", void 0, { data });
72
+ logger.logDebug("isApiOrganization: short_name is not a string", void 0, { data });
72
73
  return false;
73
74
  }
74
75
  if (!("status" in data) || !Object.values(__spiffy_ai_commerce_api_client.OrganizationStatusEnum).includes(data.status)) {
75
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: status is not a valid OrganizationStatusEnum value", void 0, { data });
76
+ logger.logDebug("isApiOrganization: status is not a valid OrganizationStatusEnum value", void 0, { data });
76
77
  return false;
77
78
  }
78
79
  if ("created_at" in data && !(data.created_at instanceof Date) && typeof data.created_at !== "string" && data.created_at !== void 0) {
79
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: created_at is not a Date", void 0, { data });
80
+ logger.logDebug("isApiOrganization: created_at is not a Date", void 0, { data });
80
81
  return false;
81
82
  }
82
83
  if ("updated_at" in data && !(data.updated_at instanceof Date) && typeof data.updated_at !== "string" && data.updated_at !== void 0) {
83
- require_logger.default.logDebug("[spiffy-ai] isApiOrganization: updated_at is not a Date", void 0, { data });
84
+ logger.logDebug("isApiOrganization: updated_at is not a Date", void 0, { data });
84
85
  return false;
85
86
  }
86
87
  return true;
87
88
  };
88
89
  const isApiOrgConfigOrganizationSettings = (data) => {
89
90
  if (data == null || typeof data !== "object") {
90
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigOrganizationSettings: data is not an object", void 0, { data });
91
+ logger.logDebug("isApiOrgConfigOrganizationSettings: data is not an object", void 0, { data });
91
92
  return false;
92
93
  }
93
94
  if (!("org" in data) || !isApiOrganization(data.org)) {
94
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigOrganizationSettings: org is not an object", void 0, { data });
95
+ logger.logDebug("isApiOrgConfigOrganizationSettings: org is not an object", void 0, { data });
95
96
  return false;
96
97
  }
97
98
  return true;
@@ -103,23 +104,23 @@ const isApiOrgConfigOrganizationSettings = (data) => {
103
104
  */
104
105
  const isApiOrgConfigResults = (data) => {
105
106
  if (data == null || typeof data !== "object") {
106
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigResults: data is not an object", void 0, { data });
107
+ logger.logDebug("isApiOrgConfigResults: data is not an object", void 0, { data });
107
108
  return false;
108
109
  }
109
110
  if (!("configs" in data) || !Array.isArray(data.configs) || !data.configs.every((config) => require_isApiOrganizationConfig.isApiOrganizationConfig(config))) {
110
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigResults: configs is not an array", void 0, { data });
111
+ logger.logDebug("isApiOrgConfigResults: configs is not an array", void 0, { data });
111
112
  return false;
112
113
  }
113
114
  if ("experiments" in data && data.experiments !== void 0 && (!Array.isArray(data.experiments) || !data.experiments.every((exp) => isApiOrgConfigExperiment(exp)))) {
114
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigResults: experiments is not an array or contains invalid items", void 0, { data });
115
+ logger.logDebug("isApiOrgConfigResults: experiments is not an array or contains invalid items", void 0, { data });
115
116
  return false;
116
117
  }
117
118
  if (!("gates" in data) || !Array.isArray(data.gates) || !data.gates.every((gate) => isApiOrgConfigFeatureGate(gate))) {
118
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigResults: gates is not an array or contains invalid items", void 0, { data });
119
+ logger.logDebug("isApiOrgConfigResults: gates is not an array or contains invalid items", void 0, { data });
119
120
  return false;
120
121
  }
121
122
  if (!("org" in data) || !isApiOrgConfigOrganizationSettings(data.org)) {
122
- require_logger.default.logDebug("[spiffy-ai] isApiOrgConfigResults: org is not an object or has invalid fields", void 0, { data });
123
+ logger.logDebug("isApiOrgConfigResults: org is not an object or has invalid fields", void 0, { data });
123
124
  return false;
124
125
  }
125
126
  return true;
@@ -127,4 +128,4 @@ const isApiOrgConfigResults = (data) => {
127
128
 
128
129
  //#endregion
129
130
  exports.isApiOrgConfigResults = isApiOrgConfigResults;
130
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrgConfigResults.cjs","names":["OrganizationStatusEnum","isApiOrganizationConfig"],"sources":["../../../../../src/application/models/guards/api/isApiOrgConfigResults.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport {\n  StatsigExperiment as ApiOrgConfigExperiment,\n  StatsigFeatureGate as ApiOrgConfigFeatureGate,\n  OrganizationSettings as ApiOrgConfigOrganizationSettings,\n  Organization as ApiOrganization,\n  OrganizationStatusEnum,\n} from '@spiffy-ai/commerce-api-client';\nimport { ApiOrganizationConfig, isApiOrganizationConfig } from './isApiOrganizationConfig';\n\ninterface ApiOrgConfigResults {\n  configs: ApiOrganizationConfig[];\n  experiments: ApiOrgConfigExperiment[];\n  gates: ApiOrgConfigFeatureGate[];\n  org: ApiOrgConfigOrganizationSettings;\n}\n\nconst isApiOrgConfigExperiment = (data: unknown): data is ApiOrgConfigExperiment => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('group' in data && typeof data.group !== 'string' && data.group !== undefined) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigExperiment: group is not a string or undefined',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'group_name' in data &&\n    typeof data.group_name !== 'string' &&\n    data.group_name !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: group_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'object' && data.value !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: value is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigFeatureGate = (data: unknown): data is ApiOrgConfigFeatureGate => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'boolean' && data.value !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: value is not a boolean', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrganization = (data: unknown): data is ApiOrganization => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('id' in data) || typeof data.id !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('display_name' in data) || typeof data.display_name !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: display_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('domain' in data) || typeof data.domain !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: domain is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('short_name' in data) || typeof data.short_name !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: short_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('status' in data) ||\n    !Object.values(OrganizationStatusEnum).includes(data.status as OrganizationStatusEnum)\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrganization: status is not a valid OrganizationStatusEnum value',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'created_at' in data &&\n    !(data.created_at instanceof Date) &&\n    typeof data.created_at !== 'string' &&\n    data.created_at !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: created_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'updated_at' in data &&\n    !(data.updated_at instanceof Date) &&\n    typeof data.updated_at !== 'string' &&\n    data.updated_at !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: updated_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigOrganizationSettings = (\n  data: unknown,\n): data is ApiOrgConfigOrganizationSettings => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigOrganizationSettings: data is not an object',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrganization(data.org)) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigOrganizationSettings: org is not an object',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  // skip validation for 'settings' for now\n\n  return true;\n};\n\n/**\n *\n * @param data\n * @returns\n */\nexport const isApiOrgConfigResults = (data: unknown): data is Required<ApiOrgConfigResults> => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigResults: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('configs' in data) ||\n    !Array.isArray(data.configs) ||\n    !data.configs.every(config => isApiOrganizationConfig(config))\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigResults: configs is not an array', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'experiments' in data &&\n    data.experiments !== undefined &&\n    (!Array.isArray(data.experiments) ||\n      !data.experiments.every(exp => isApiOrgConfigExperiment(exp)))\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: experiments is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !('gates' in data) ||\n    !Array.isArray(data.gates) ||\n    !data.gates.every(gate => isApiOrgConfigFeatureGate(gate))\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: gates is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrgConfigOrganizationSettings(data.org)) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: org is not an object or has invalid fields',\n      undefined,\n      { data },\n    );\n\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":"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"}
131
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrgConfigResults.cjs","names":["Logger","OrganizationStatusEnum","isApiOrganizationConfig"],"sources":["../../../../../src/application/models/guards/api/isApiOrgConfigResults.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport {\n  StatsigExperiment as ApiOrgConfigExperiment,\n  StatsigFeatureGate as ApiOrgConfigFeatureGate,\n  OrganizationSettings as ApiOrgConfigOrganizationSettings,\n  Organization as ApiOrganization,\n  OrganizationStatusEnum,\n} from '@spiffy-ai/commerce-api-client';\nimport { ApiOrganizationConfig, isApiOrganizationConfig } from './isApiOrganizationConfig';\n\ninterface ApiOrgConfigResults {\n  configs: ApiOrganizationConfig[];\n  experiments: ApiOrgConfigExperiment[];\n  gates: ApiOrgConfigFeatureGate[];\n  org: ApiOrgConfigOrganizationSettings;\n}\n\nconst logger = new Logger('isApiOrgConfigResults');\n\nconst isApiOrgConfigExperiment = (data: unknown): data is ApiOrgConfigExperiment => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigExperiment: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('group' in data && typeof data.group !== 'string' && data.group !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: group is not a string or undefined', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'group_name' in data &&\n    typeof data.group_name !== 'string' &&\n    data.group_name !== undefined\n  ) {\n    logger.logDebug('isApiOrgConfigExperiment: group_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'object' && data.value !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: value is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigFeatureGate = (data: unknown): data is ApiOrgConfigFeatureGate => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigFeatureGate: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'boolean' && data.value !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: value is not a boolean', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrganization = (data: unknown): data is ApiOrganization => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrganization: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('id' in data) || typeof data.id !== 'string') {\n    logger.logDebug('isApiOrganization: id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('display_name' in data) || typeof data.display_name !== 'string') {\n    logger.logDebug('isApiOrganization: display_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('domain' in data) || typeof data.domain !== 'string') {\n    logger.logDebug('isApiOrganization: domain is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('short_name' in data) || typeof data.short_name !== 'string') {\n    logger.logDebug('isApiOrganization: short_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('status' in data) ||\n    !Object.values(OrganizationStatusEnum).includes(data.status as OrganizationStatusEnum)\n  ) {\n    logger.logDebug(\n      'isApiOrganization: status is not a valid OrganizationStatusEnum value',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'created_at' in data &&\n    !(data.created_at instanceof Date) &&\n    typeof data.created_at !== 'string' &&\n    data.created_at !== undefined\n  ) {\n    logger.logDebug('isApiOrganization: created_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'updated_at' in data &&\n    !(data.updated_at instanceof Date) &&\n    typeof data.updated_at !== 'string' &&\n    data.updated_at !== undefined\n  ) {\n    logger.logDebug('isApiOrganization: updated_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigOrganizationSettings = (\n  data: unknown,\n): data is ApiOrgConfigOrganizationSettings => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigOrganizationSettings: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrganization(data.org)) {\n    logger.logDebug('isApiOrgConfigOrganizationSettings: org is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  // skip validation for 'settings' for now\n\n  return true;\n};\n\n/**\n *\n * @param data\n * @returns\n */\nexport const isApiOrgConfigResults = (data: unknown): data is Required<ApiOrgConfigResults> => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigResults: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('configs' in data) ||\n    !Array.isArray(data.configs) ||\n    !data.configs.every(config => isApiOrganizationConfig(config))\n  ) {\n    logger.logDebug('isApiOrgConfigResults: configs is not an array', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'experiments' in data &&\n    data.experiments !== undefined &&\n    (!Array.isArray(data.experiments) ||\n      !data.experiments.every(exp => isApiOrgConfigExperiment(exp)))\n  ) {\n    logger.logDebug(\n      'isApiOrgConfigResults: experiments is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !('gates' in data) ||\n    !Array.isArray(data.gates) ||\n    !data.gates.every(gate => isApiOrgConfigFeatureGate(gate))\n  ) {\n    logger.logDebug(\n      'isApiOrgConfigResults: gates is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrgConfigOrganizationSettings(data.org)) {\n    logger.logDebug(\n      'isApiOrgConfigResults: org is not an object or has invalid fields',\n      undefined,\n      {\n        data,\n      },\n    );\n\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":"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"}
@@ -3,94 +3,95 @@ import { isApiOrganizationConfig } from "./isApiOrganizationConfig.js";
3
3
  import { OrganizationStatusEnum } from "@spiffy-ai/commerce-api-client";
4
4
 
5
5
  //#region src/application/models/guards/api/isApiOrgConfigResults.ts
6
+ const logger = new logger_default("isApiOrgConfigResults");
6
7
  const isApiOrgConfigExperiment = (data) => {
7
8
  if (data == null || typeof data !== "object") {
8
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: data is not an object", void 0, { data });
9
+ logger.logDebug("isApiOrgConfigExperiment: data is not an object", void 0, { data });
9
10
  return false;
10
11
  }
11
12
  if ("group" in data && typeof data.group !== "string" && data.group !== void 0) {
12
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: group is not a string or undefined", void 0, { data });
13
+ logger.logDebug("isApiOrgConfigExperiment: group is not a string or undefined", void 0, { data });
13
14
  return false;
14
15
  }
15
16
  if ("group_name" in data && typeof data.group_name !== "string" && data.group_name !== void 0) {
16
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: group_name is not a string", void 0, { data });
17
+ logger.logDebug("isApiOrgConfigExperiment: group_name is not a string", void 0, { data });
17
18
  return false;
18
19
  }
19
20
  if ("name" in data && typeof data.name !== "string" && data.name !== void 0) {
20
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: name is not a string", void 0, { data });
21
+ logger.logDebug("isApiOrgConfigExperiment: name is not a string", void 0, { data });
21
22
  return false;
22
23
  }
23
24
  if ("rule_id" in data && typeof data.rule_id !== "string" && data.rule_id !== void 0) {
24
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: rule_id is not a string", void 0, { data });
25
+ logger.logDebug("isApiOrgConfigExperiment: rule_id is not a string", void 0, { data });
25
26
  return false;
26
27
  }
27
28
  if ("value" in data && typeof data.value !== "object" && data.value !== void 0) {
28
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigExperiment: value is not an object", void 0, { data });
29
+ logger.logDebug("isApiOrgConfigExperiment: value is not an object", void 0, { data });
29
30
  return false;
30
31
  }
31
32
  return true;
32
33
  };
33
34
  const isApiOrgConfigFeatureGate = (data) => {
34
35
  if (data == null || typeof data !== "object") {
35
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: data is not an object", void 0, { data });
36
+ logger.logDebug("isApiOrgConfigFeatureGate: data is not an object", void 0, { data });
36
37
  return false;
37
38
  }
38
39
  if ("name" in data && typeof data.name !== "string" && data.name !== void 0) {
39
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: name is not a string", void 0, { data });
40
+ logger.logDebug("isApiOrgConfigFeatureGate: name is not a string", void 0, { data });
40
41
  return false;
41
42
  }
42
43
  if ("rule_id" in data && typeof data.rule_id !== "string" && data.rule_id !== void 0) {
43
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: rule_id is not a string", void 0, { data });
44
+ logger.logDebug("isApiOrgConfigFeatureGate: rule_id is not a string", void 0, { data });
44
45
  return false;
45
46
  }
46
47
  if ("value" in data && typeof data.value !== "boolean" && data.value !== void 0) {
47
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigFeatureGate: value is not a boolean", void 0, { data });
48
+ logger.logDebug("isApiOrgConfigFeatureGate: value is not a boolean", void 0, { data });
48
49
  return false;
49
50
  }
50
51
  return true;
51
52
  };
52
53
  const isApiOrganization = (data) => {
53
54
  if (data == null || typeof data !== "object") {
54
- logger_default.logDebug("[spiffy-ai] isApiOrganization: data is not an object", void 0, { data });
55
+ logger.logDebug("isApiOrganization: data is not an object", void 0, { data });
55
56
  return false;
56
57
  }
57
58
  if (!("id" in data) || typeof data.id !== "string") {
58
- logger_default.logDebug("[spiffy-ai] isApiOrganization: id is not a string", void 0, { data });
59
+ logger.logDebug("isApiOrganization: id is not a string", void 0, { data });
59
60
  return false;
60
61
  }
61
62
  if (!("display_name" in data) || typeof data.display_name !== "string") {
62
- logger_default.logDebug("[spiffy-ai] isApiOrganization: display_name is not a string", void 0, { data });
63
+ logger.logDebug("isApiOrganization: display_name is not a string", void 0, { data });
63
64
  return false;
64
65
  }
65
66
  if (!("domain" in data) || typeof data.domain !== "string") {
66
- logger_default.logDebug("[spiffy-ai] isApiOrganization: domain is not a string", void 0, { data });
67
+ logger.logDebug("isApiOrganization: domain is not a string", void 0, { data });
67
68
  return false;
68
69
  }
69
70
  if (!("short_name" in data) || typeof data.short_name !== "string") {
70
- logger_default.logDebug("[spiffy-ai] isApiOrganization: short_name is not a string", void 0, { data });
71
+ logger.logDebug("isApiOrganization: short_name is not a string", void 0, { data });
71
72
  return false;
72
73
  }
73
74
  if (!("status" in data) || !Object.values(OrganizationStatusEnum).includes(data.status)) {
74
- logger_default.logDebug("[spiffy-ai] isApiOrganization: status is not a valid OrganizationStatusEnum value", void 0, { data });
75
+ logger.logDebug("isApiOrganization: status is not a valid OrganizationStatusEnum value", void 0, { data });
75
76
  return false;
76
77
  }
77
78
  if ("created_at" in data && !(data.created_at instanceof Date) && typeof data.created_at !== "string" && data.created_at !== void 0) {
78
- logger_default.logDebug("[spiffy-ai] isApiOrganization: created_at is not a Date", void 0, { data });
79
+ logger.logDebug("isApiOrganization: created_at is not a Date", void 0, { data });
79
80
  return false;
80
81
  }
81
82
  if ("updated_at" in data && !(data.updated_at instanceof Date) && typeof data.updated_at !== "string" && data.updated_at !== void 0) {
82
- logger_default.logDebug("[spiffy-ai] isApiOrganization: updated_at is not a Date", void 0, { data });
83
+ logger.logDebug("isApiOrganization: updated_at is not a Date", void 0, { data });
83
84
  return false;
84
85
  }
85
86
  return true;
86
87
  };
87
88
  const isApiOrgConfigOrganizationSettings = (data) => {
88
89
  if (data == null || typeof data !== "object") {
89
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigOrganizationSettings: data is not an object", void 0, { data });
90
+ logger.logDebug("isApiOrgConfigOrganizationSettings: data is not an object", void 0, { data });
90
91
  return false;
91
92
  }
92
93
  if (!("org" in data) || !isApiOrganization(data.org)) {
93
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigOrganizationSettings: org is not an object", void 0, { data });
94
+ logger.logDebug("isApiOrgConfigOrganizationSettings: org is not an object", void 0, { data });
94
95
  return false;
95
96
  }
96
97
  return true;
@@ -102,23 +103,23 @@ const isApiOrgConfigOrganizationSettings = (data) => {
102
103
  */
103
104
  const isApiOrgConfigResults = (data) => {
104
105
  if (data == null || typeof data !== "object") {
105
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigResults: data is not an object", void 0, { data });
106
+ logger.logDebug("isApiOrgConfigResults: data is not an object", void 0, { data });
106
107
  return false;
107
108
  }
108
109
  if (!("configs" in data) || !Array.isArray(data.configs) || !data.configs.every((config) => isApiOrganizationConfig(config))) {
109
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigResults: configs is not an array", void 0, { data });
110
+ logger.logDebug("isApiOrgConfigResults: configs is not an array", void 0, { data });
110
111
  return false;
111
112
  }
112
113
  if ("experiments" in data && data.experiments !== void 0 && (!Array.isArray(data.experiments) || !data.experiments.every((exp) => isApiOrgConfigExperiment(exp)))) {
113
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigResults: experiments is not an array or contains invalid items", void 0, { data });
114
+ logger.logDebug("isApiOrgConfigResults: experiments is not an array or contains invalid items", void 0, { data });
114
115
  return false;
115
116
  }
116
117
  if (!("gates" in data) || !Array.isArray(data.gates) || !data.gates.every((gate) => isApiOrgConfigFeatureGate(gate))) {
117
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigResults: gates is not an array or contains invalid items", void 0, { data });
118
+ logger.logDebug("isApiOrgConfigResults: gates is not an array or contains invalid items", void 0, { data });
118
119
  return false;
119
120
  }
120
121
  if (!("org" in data) || !isApiOrgConfigOrganizationSettings(data.org)) {
121
- logger_default.logDebug("[spiffy-ai] isApiOrgConfigResults: org is not an object or has invalid fields", void 0, { data });
122
+ logger.logDebug("isApiOrgConfigResults: org is not an object or has invalid fields", void 0, { data });
122
123
  return false;
123
124
  }
124
125
  return true;
@@ -126,4 +127,4 @@ const isApiOrgConfigResults = (data) => {
126
127
 
127
128
  //#endregion
128
129
  export { isApiOrgConfigResults };
129
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrgConfigResults.js","names":[],"sources":["../../../../../src/application/models/guards/api/isApiOrgConfigResults.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport {\n  StatsigExperiment as ApiOrgConfigExperiment,\n  StatsigFeatureGate as ApiOrgConfigFeatureGate,\n  OrganizationSettings as ApiOrgConfigOrganizationSettings,\n  Organization as ApiOrganization,\n  OrganizationStatusEnum,\n} from '@spiffy-ai/commerce-api-client';\nimport { ApiOrganizationConfig, isApiOrganizationConfig } from './isApiOrganizationConfig';\n\ninterface ApiOrgConfigResults {\n  configs: ApiOrganizationConfig[];\n  experiments: ApiOrgConfigExperiment[];\n  gates: ApiOrgConfigFeatureGate[];\n  org: ApiOrgConfigOrganizationSettings;\n}\n\nconst isApiOrgConfigExperiment = (data: unknown): data is ApiOrgConfigExperiment => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('group' in data && typeof data.group !== 'string' && data.group !== undefined) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigExperiment: group is not a string or undefined',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'group_name' in data &&\n    typeof data.group_name !== 'string' &&\n    data.group_name !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: group_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'object' && data.value !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigExperiment: value is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigFeatureGate = (data: unknown): data is ApiOrgConfigFeatureGate => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'boolean' && data.value !== undefined) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigFeatureGate: value is not a boolean', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrganization = (data: unknown): data is ApiOrganization => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('id' in data) || typeof data.id !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('display_name' in data) || typeof data.display_name !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: display_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('domain' in data) || typeof data.domain !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: domain is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('short_name' in data) || typeof data.short_name !== 'string') {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: short_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('status' in data) ||\n    !Object.values(OrganizationStatusEnum).includes(data.status as OrganizationStatusEnum)\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrganization: status is not a valid OrganizationStatusEnum value',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'created_at' in data &&\n    !(data.created_at instanceof Date) &&\n    typeof data.created_at !== 'string' &&\n    data.created_at !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: created_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'updated_at' in data &&\n    !(data.updated_at instanceof Date) &&\n    typeof data.updated_at !== 'string' &&\n    data.updated_at !== undefined\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrganization: updated_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigOrganizationSettings = (\n  data: unknown,\n): data is ApiOrgConfigOrganizationSettings => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigOrganizationSettings: data is not an object',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrganization(data.org)) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigOrganizationSettings: org is not an object',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  // skip validation for 'settings' for now\n\n  return true;\n};\n\n/**\n *\n * @param data\n * @returns\n */\nexport const isApiOrgConfigResults = (data: unknown): data is Required<ApiOrgConfigResults> => {\n  if (data == null || typeof data !== 'object') {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigResults: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('configs' in data) ||\n    !Array.isArray(data.configs) ||\n    !data.configs.every(config => isApiOrganizationConfig(config))\n  ) {\n    Logger.logDebug('[spiffy-ai] isApiOrgConfigResults: configs is not an array', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'experiments' in data &&\n    data.experiments !== undefined &&\n    (!Array.isArray(data.experiments) ||\n      !data.experiments.every(exp => isApiOrgConfigExperiment(exp)))\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: experiments is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !('gates' in data) ||\n    !Array.isArray(data.gates) ||\n    !data.gates.every(gate => isApiOrgConfigFeatureGate(gate))\n  ) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: gates is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrgConfigOrganizationSettings(data.org)) {\n    Logger.logDebug(\n      '[spiffy-ai] isApiOrgConfigResults: org is not an object or has invalid fields',\n      undefined,\n      { data },\n    );\n\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":"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"}
130
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"isApiOrgConfigResults.js","names":["Logger"],"sources":["../../../../../src/application/models/guards/api/isApiOrgConfigResults.ts"],"sourcesContent":["import Logger from 'src/application/logging/logger';\nimport {\n  StatsigExperiment as ApiOrgConfigExperiment,\n  StatsigFeatureGate as ApiOrgConfigFeatureGate,\n  OrganizationSettings as ApiOrgConfigOrganizationSettings,\n  Organization as ApiOrganization,\n  OrganizationStatusEnum,\n} from '@spiffy-ai/commerce-api-client';\nimport { ApiOrganizationConfig, isApiOrganizationConfig } from './isApiOrganizationConfig';\n\ninterface ApiOrgConfigResults {\n  configs: ApiOrganizationConfig[];\n  experiments: ApiOrgConfigExperiment[];\n  gates: ApiOrgConfigFeatureGate[];\n  org: ApiOrgConfigOrganizationSettings;\n}\n\nconst logger = new Logger('isApiOrgConfigResults');\n\nconst isApiOrgConfigExperiment = (data: unknown): data is ApiOrgConfigExperiment => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigExperiment: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('group' in data && typeof data.group !== 'string' && data.group !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: group is not a string or undefined', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'group_name' in data &&\n    typeof data.group_name !== 'string' &&\n    data.group_name !== undefined\n  ) {\n    logger.logDebug('isApiOrgConfigExperiment: group_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'object' && data.value !== undefined) {\n    logger.logDebug('isApiOrgConfigExperiment: value is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigFeatureGate = (data: unknown): data is ApiOrgConfigFeatureGate => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigFeatureGate: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('name' in data && typeof data.name !== 'string' && data.name !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('rule_id' in data && typeof data.rule_id !== 'string' && data.rule_id !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: rule_id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if ('value' in data && typeof data.value !== 'boolean' && data.value !== undefined) {\n    logger.logDebug('isApiOrgConfigFeatureGate: value is not a boolean', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrganization = (data: unknown): data is ApiOrganization => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrganization: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('id' in data) || typeof data.id !== 'string') {\n    logger.logDebug('isApiOrganization: id is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('display_name' in data) || typeof data.display_name !== 'string') {\n    logger.logDebug('isApiOrganization: display_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('domain' in data) || typeof data.domain !== 'string') {\n    logger.logDebug('isApiOrganization: domain is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('short_name' in data) || typeof data.short_name !== 'string') {\n    logger.logDebug('isApiOrganization: short_name is not a string', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('status' in data) ||\n    !Object.values(OrganizationStatusEnum).includes(data.status as OrganizationStatusEnum)\n  ) {\n    logger.logDebug(\n      'isApiOrganization: status is not a valid OrganizationStatusEnum value',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    'created_at' in data &&\n    !(data.created_at instanceof Date) &&\n    typeof data.created_at !== 'string' &&\n    data.created_at !== undefined\n  ) {\n    logger.logDebug('isApiOrganization: created_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'updated_at' in data &&\n    !(data.updated_at instanceof Date) &&\n    typeof data.updated_at !== 'string' &&\n    data.updated_at !== undefined\n  ) {\n    logger.logDebug('isApiOrganization: updated_at is not a Date', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  return true;\n};\n\nconst isApiOrgConfigOrganizationSettings = (\n  data: unknown,\n): data is ApiOrgConfigOrganizationSettings => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigOrganizationSettings: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrganization(data.org)) {\n    logger.logDebug('isApiOrgConfigOrganizationSettings: org is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  // skip validation for 'settings' for now\n\n  return true;\n};\n\n/**\n *\n * @param data\n * @returns\n */\nexport const isApiOrgConfigResults = (data: unknown): data is Required<ApiOrgConfigResults> => {\n  if (data == null || typeof data !== 'object') {\n    logger.logDebug('isApiOrgConfigResults: data is not an object', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    !('configs' in data) ||\n    !Array.isArray(data.configs) ||\n    !data.configs.every(config => isApiOrganizationConfig(config))\n  ) {\n    logger.logDebug('isApiOrgConfigResults: configs is not an array', undefined, {\n      data,\n    });\n    return false;\n  }\n\n  if (\n    'experiments' in data &&\n    data.experiments !== undefined &&\n    (!Array.isArray(data.experiments) ||\n      !data.experiments.every(exp => isApiOrgConfigExperiment(exp)))\n  ) {\n    logger.logDebug(\n      'isApiOrgConfigResults: experiments is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (\n    !('gates' in data) ||\n    !Array.isArray(data.gates) ||\n    !data.gates.every(gate => isApiOrgConfigFeatureGate(gate))\n  ) {\n    logger.logDebug(\n      'isApiOrgConfigResults: gates is not an array or contains invalid items',\n      undefined,\n      {\n        data,\n      },\n    );\n    return false;\n  }\n\n  if (!('org' in data) || !isApiOrgConfigOrganizationSettings(data.org)) {\n    logger.logDebug(\n      'isApiOrgConfigResults: org is not an object or has invalid fields',\n      undefined,\n      {\n        data,\n      },\n    );\n\n    return false;\n  }\n\n  return true;\n};\n"],"mappings":"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"}