@cloud-copilot/iam-simulate 0.1.12 → 0.1.14

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 (329) hide show
  1. package/dist/cjs/StatementAnalysis.d.ts +14 -0
  2. package/dist/cjs/StatementAnalysis.d.ts.map +1 -1
  3. package/dist/cjs/StatementAnalysis.js +51 -0
  4. package/dist/cjs/StatementAnalysis.js.map +1 -1
  5. package/dist/cjs/action/action.d.ts +13 -3
  6. package/dist/cjs/action/action.d.ts.map +1 -1
  7. package/dist/cjs/action/action.js +43 -21
  8. package/dist/cjs/action/action.js.map +1 -1
  9. package/dist/cjs/condition/BaseConditionOperator.d.ts +6 -1
  10. package/dist/cjs/condition/BaseConditionOperator.d.ts.map +1 -1
  11. package/dist/cjs/condition/arn/ArnEquals.d.ts.map +1 -1
  12. package/dist/cjs/condition/arn/ArnEquals.js +2 -1
  13. package/dist/cjs/condition/arn/ArnEquals.js.map +1 -1
  14. package/dist/cjs/condition/arn/ArnLike.d.ts.map +1 -1
  15. package/dist/cjs/condition/arn/ArnLike.js +8 -40
  16. package/dist/cjs/condition/arn/ArnLike.js.map +1 -1
  17. package/dist/cjs/condition/arn/ArnNotEquals.d.ts.map +1 -1
  18. package/dist/cjs/condition/arn/ArnNotEquals.js +2 -1
  19. package/dist/cjs/condition/arn/ArnNotEquals.js.map +1 -1
  20. package/dist/cjs/condition/arn/ArnNotLike.d.ts.map +1 -1
  21. package/dist/cjs/condition/arn/ArnNotLike.js +8 -3
  22. package/dist/cjs/condition/arn/ArnNotLike.js.map +1 -1
  23. package/dist/cjs/condition/arn/arn.d.ts +12 -0
  24. package/dist/cjs/condition/arn/arn.d.ts.map +1 -0
  25. package/dist/cjs/condition/arn/arn.js +68 -0
  26. package/dist/cjs/condition/arn/arn.js.map +1 -0
  27. package/dist/cjs/condition/baseConditionperatorTests.d.ts +7 -1
  28. package/dist/cjs/condition/baseConditionperatorTests.d.ts.map +1 -1
  29. package/dist/cjs/condition/baseConditionperatorTests.js +17 -1
  30. package/dist/cjs/condition/baseConditionperatorTests.js.map +1 -1
  31. package/dist/cjs/condition/binary/BinaryEquals.d.ts.map +1 -1
  32. package/dist/cjs/condition/binary/BinaryEquals.js +14 -2
  33. package/dist/cjs/condition/binary/BinaryEquals.js.map +1 -1
  34. package/dist/cjs/condition/boolean/Bool.d.ts.map +1 -1
  35. package/dist/cjs/condition/boolean/Bool.js +36 -7
  36. package/dist/cjs/condition/boolean/Bool.js.map +1 -1
  37. package/dist/cjs/condition/condition.d.ts +46 -3
  38. package/dist/cjs/condition/condition.d.ts.map +1 -1
  39. package/dist/cjs/condition/condition.js +242 -48
  40. package/dist/cjs/condition/condition.js.map +1 -1
  41. package/dist/cjs/condition/conditionUtil.d.ts +10 -0
  42. package/dist/cjs/condition/conditionUtil.d.ts.map +1 -0
  43. package/dist/cjs/condition/conditionUtil.js +16 -0
  44. package/dist/cjs/condition/conditionUtil.js.map +1 -0
  45. package/dist/cjs/condition/date/DateEquals.d.ts.map +1 -1
  46. package/dist/cjs/condition/date/DateEquals.js +7 -2
  47. package/dist/cjs/condition/date/DateEquals.js.map +1 -1
  48. package/dist/cjs/condition/date/DateGreaterThan.d.ts.map +1 -1
  49. package/dist/cjs/condition/date/DateGreaterThan.js +7 -2
  50. package/dist/cjs/condition/date/DateGreaterThan.js.map +1 -1
  51. package/dist/cjs/condition/date/DateGreaterThanEquals.d.ts.map +1 -1
  52. package/dist/cjs/condition/date/DateGreaterThanEquals.js +7 -2
  53. package/dist/cjs/condition/date/DateGreaterThanEquals.js.map +1 -1
  54. package/dist/cjs/condition/date/DateLessThan.d.ts.map +1 -1
  55. package/dist/cjs/condition/date/DateLessThan.js +7 -2
  56. package/dist/cjs/condition/date/DateLessThan.js.map +1 -1
  57. package/dist/cjs/condition/date/DateLessThanEquals.d.ts.map +1 -1
  58. package/dist/cjs/condition/date/DateLessThanEquals.js +7 -2
  59. package/dist/cjs/condition/date/DateLessThanEquals.js.map +1 -1
  60. package/dist/cjs/condition/date/DateNotEquals.d.ts.map +1 -1
  61. package/dist/cjs/condition/date/DateNotEquals.js +11 -18
  62. package/dist/cjs/condition/date/DateNotEquals.js.map +1 -1
  63. package/dist/cjs/condition/date/date.d.ts +2 -1
  64. package/dist/cjs/condition/date/date.d.ts.map +1 -1
  65. package/dist/cjs/condition/date/date.js +20 -5
  66. package/dist/cjs/condition/date/date.js.map +1 -1
  67. package/dist/cjs/condition/ipaddress/IpAddress.d.ts.map +1 -1
  68. package/dist/cjs/condition/ipaddress/IpAddress.js +9 -16
  69. package/dist/cjs/condition/ipaddress/IpAddress.js.map +1 -1
  70. package/dist/cjs/condition/ipaddress/NotIpAddress.d.ts.map +1 -1
  71. package/dist/cjs/condition/ipaddress/NotIpAddress.js +9 -20
  72. package/dist/cjs/condition/ipaddress/NotIpAddress.js.map +1 -1
  73. package/dist/cjs/condition/ipaddress/ip.d.ts +10 -0
  74. package/dist/cjs/condition/ipaddress/ip.d.ts.map +1 -0
  75. package/dist/cjs/condition/ipaddress/ip.js +57 -0
  76. package/dist/cjs/condition/ipaddress/ip.js.map +1 -0
  77. package/dist/cjs/condition/numeric/NumericEquals.d.ts.map +1 -1
  78. package/dist/cjs/condition/numeric/NumericEquals.js +7 -2
  79. package/dist/cjs/condition/numeric/NumericEquals.js.map +1 -1
  80. package/dist/cjs/condition/numeric/NumericGreaterThan.d.ts.map +1 -1
  81. package/dist/cjs/condition/numeric/NumericGreaterThan.js +7 -2
  82. package/dist/cjs/condition/numeric/NumericGreaterThan.js.map +1 -1
  83. package/dist/cjs/condition/numeric/NumericGreaterThanEquals.d.ts.map +1 -1
  84. package/dist/cjs/condition/numeric/NumericGreaterThanEquals.js +7 -2
  85. package/dist/cjs/condition/numeric/NumericGreaterThanEquals.js.map +1 -1
  86. package/dist/cjs/condition/numeric/NumericLessThan.d.ts.map +1 -1
  87. package/dist/cjs/condition/numeric/NumericLessThan.js +7 -2
  88. package/dist/cjs/condition/numeric/NumericLessThan.js.map +1 -1
  89. package/dist/cjs/condition/numeric/NumericLessThanEquals.d.ts.map +1 -1
  90. package/dist/cjs/condition/numeric/NumericLessThanEquals.js +7 -2
  91. package/dist/cjs/condition/numeric/NumericLessThanEquals.js.map +1 -1
  92. package/dist/cjs/condition/numeric/NumericNotEquals.d.ts.map +1 -1
  93. package/dist/cjs/condition/numeric/NumericNotEquals.js +11 -18
  94. package/dist/cjs/condition/numeric/NumericNotEquals.js.map +1 -1
  95. package/dist/cjs/condition/numeric/numeric.d.ts +2 -1
  96. package/dist/cjs/condition/numeric/numeric.d.ts.map +1 -1
  97. package/dist/cjs/condition/numeric/numeric.js +18 -3
  98. package/dist/cjs/condition/numeric/numeric.js.map +1 -1
  99. package/dist/cjs/condition/string/StringEquals.d.ts.map +1 -1
  100. package/dist/cjs/condition/string/StringEquals.js +24 -3
  101. package/dist/cjs/condition/string/StringEquals.js.map +1 -1
  102. package/dist/cjs/condition/string/StringEqualsIgnoreCase.d.ts.map +1 -1
  103. package/dist/cjs/condition/string/StringEqualsIgnoreCase.js +23 -5
  104. package/dist/cjs/condition/string/StringEqualsIgnoreCase.js.map +1 -1
  105. package/dist/cjs/condition/string/StringLike.d.ts.map +1 -1
  106. package/dist/cjs/condition/string/StringLike.js +24 -3
  107. package/dist/cjs/condition/string/StringLike.js.map +1 -1
  108. package/dist/cjs/condition/string/StringNotEquals.d.ts.map +1 -1
  109. package/dist/cjs/condition/string/StringNotEquals.js +24 -3
  110. package/dist/cjs/condition/string/StringNotEquals.js.map +1 -1
  111. package/dist/cjs/condition/string/StringNotEqualsIgnoreCase.d.ts.map +1 -1
  112. package/dist/cjs/condition/string/StringNotEqualsIgnoreCase.js +25 -3
  113. package/dist/cjs/condition/string/StringNotEqualsIgnoreCase.js.map +1 -1
  114. package/dist/cjs/condition/string/StringNotLike.d.ts.map +1 -1
  115. package/dist/cjs/condition/string/StringNotLike.js +25 -3
  116. package/dist/cjs/condition/string/StringNotLike.js.map +1 -1
  117. package/dist/cjs/core_engine/coreSimulatorEngine.d.ts +10 -7
  118. package/dist/cjs/core_engine/coreSimulatorEngine.d.ts.map +1 -1
  119. package/dist/cjs/core_engine/coreSimulatorEngine.js +148 -28
  120. package/dist/cjs/core_engine/coreSimulatorEngine.js.map +1 -1
  121. package/dist/cjs/evaluate.d.ts +47 -0
  122. package/dist/cjs/evaluate.d.ts.map +1 -1
  123. package/dist/cjs/explain/displayExplainCli.d.ts +3 -0
  124. package/dist/cjs/explain/displayExplainCli.d.ts.map +1 -0
  125. package/dist/cjs/explain/displayExplainCli.js +249 -0
  126. package/dist/cjs/explain/displayExplainCli.js.map +1 -0
  127. package/dist/cjs/explain/statementExplain.d.ts +51 -0
  128. package/dist/cjs/explain/statementExplain.d.ts.map +1 -0
  129. package/dist/cjs/explain/statementExplain.js +7 -0
  130. package/dist/cjs/explain/statementExplain.js.map +1 -0
  131. package/dist/cjs/index.d.ts +1 -0
  132. package/dist/cjs/index.d.ts.map +1 -1
  133. package/dist/cjs/index.js.map +1 -1
  134. package/dist/cjs/principal/principal.d.ts +28 -6
  135. package/dist/cjs/principal/principal.d.ts.map +1 -1
  136. package/dist/cjs/principal/principal.js +146 -40
  137. package/dist/cjs/principal/principal.js.map +1 -1
  138. package/dist/cjs/resource/resource.d.ts +13 -3
  139. package/dist/cjs/resource/resource.d.ts.map +1 -1
  140. package/dist/cjs/resource/resource.js +68 -15
  141. package/dist/cjs/resource/resource.js.map +1 -1
  142. package/dist/cjs/services/DefaultServiceAuthorizer.d.ts +2 -34
  143. package/dist/cjs/services/DefaultServiceAuthorizer.d.ts.map +1 -1
  144. package/dist/cjs/services/DefaultServiceAuthorizer.js +95 -131
  145. package/dist/cjs/services/DefaultServiceAuthorizer.js.map +1 -1
  146. package/dist/cjs/services/ServiceAuthorizer.d.ts +6 -7
  147. package/dist/cjs/services/ServiceAuthorizer.d.ts.map +1 -1
  148. package/dist/cjs/simulation_engine/simulation.d.ts +4 -0
  149. package/dist/cjs/simulation_engine/simulation.d.ts.map +1 -1
  150. package/dist/cjs/simulation_engine/simulationEngine.d.ts +2 -4
  151. package/dist/cjs/simulation_engine/simulationEngine.d.ts.map +1 -1
  152. package/dist/cjs/simulation_engine/simulationEngine.js +16 -4
  153. package/dist/cjs/simulation_engine/simulationEngine.js.map +1 -1
  154. package/dist/cjs/simulation_engine/unsafeSimulationEngine.d.ts.map +1 -1
  155. package/dist/cjs/simulation_engine/unsafeSimulationEngine.js +5 -2
  156. package/dist/cjs/simulation_engine/unsafeSimulationEngine.js.map +1 -1
  157. package/dist/cjs/util.d.ts +31 -3
  158. package/dist/cjs/util.d.ts.map +1 -1
  159. package/dist/cjs/util.js +74 -32
  160. package/dist/cjs/util.js.map +1 -1
  161. package/dist/esm/StatementAnalysis.d.ts +14 -0
  162. package/dist/esm/StatementAnalysis.d.ts.map +1 -1
  163. package/dist/esm/StatementAnalysis.js +48 -1
  164. package/dist/esm/StatementAnalysis.js.map +1 -1
  165. package/dist/esm/action/action.d.ts +13 -3
  166. package/dist/esm/action/action.d.ts.map +1 -1
  167. package/dist/esm/action/action.js +43 -21
  168. package/dist/esm/action/action.js.map +1 -1
  169. package/dist/esm/condition/BaseConditionOperator.d.ts +6 -1
  170. package/dist/esm/condition/BaseConditionOperator.d.ts.map +1 -1
  171. package/dist/esm/condition/arn/ArnEquals.d.ts.map +1 -1
  172. package/dist/esm/condition/arn/ArnEquals.js +2 -1
  173. package/dist/esm/condition/arn/ArnEquals.js.map +1 -1
  174. package/dist/esm/condition/arn/ArnLike.d.ts.map +1 -1
  175. package/dist/esm/condition/arn/ArnLike.js +8 -40
  176. package/dist/esm/condition/arn/ArnLike.js.map +1 -1
  177. package/dist/esm/condition/arn/ArnNotEquals.d.ts.map +1 -1
  178. package/dist/esm/condition/arn/ArnNotEquals.js +2 -1
  179. package/dist/esm/condition/arn/ArnNotEquals.js.map +1 -1
  180. package/dist/esm/condition/arn/ArnNotLike.d.ts.map +1 -1
  181. package/dist/esm/condition/arn/ArnNotLike.js +8 -3
  182. package/dist/esm/condition/arn/ArnNotLike.js.map +1 -1
  183. package/dist/esm/condition/arn/arn.d.ts +12 -0
  184. package/dist/esm/condition/arn/arn.d.ts.map +1 -0
  185. package/dist/esm/condition/arn/arn.js +65 -0
  186. package/dist/esm/condition/arn/arn.js.map +1 -0
  187. package/dist/esm/condition/baseConditionperatorTests.d.ts +7 -1
  188. package/dist/esm/condition/baseConditionperatorTests.d.ts.map +1 -1
  189. package/dist/esm/condition/baseConditionperatorTests.js +17 -1
  190. package/dist/esm/condition/baseConditionperatorTests.js.map +1 -1
  191. package/dist/esm/condition/binary/BinaryEquals.d.ts.map +1 -1
  192. package/dist/esm/condition/binary/BinaryEquals.js +14 -2
  193. package/dist/esm/condition/binary/BinaryEquals.js.map +1 -1
  194. package/dist/esm/condition/boolean/Bool.d.ts.map +1 -1
  195. package/dist/esm/condition/boolean/Bool.js +37 -8
  196. package/dist/esm/condition/boolean/Bool.js.map +1 -1
  197. package/dist/esm/condition/condition.d.ts +46 -3
  198. package/dist/esm/condition/condition.d.ts.map +1 -1
  199. package/dist/esm/condition/condition.js +239 -48
  200. package/dist/esm/condition/condition.js.map +1 -1
  201. package/dist/esm/condition/conditionUtil.d.ts +10 -0
  202. package/dist/esm/condition/conditionUtil.d.ts.map +1 -0
  203. package/dist/esm/condition/conditionUtil.js +13 -0
  204. package/dist/esm/condition/conditionUtil.js.map +1 -0
  205. package/dist/esm/condition/date/DateEquals.d.ts.map +1 -1
  206. package/dist/esm/condition/date/DateEquals.js +7 -2
  207. package/dist/esm/condition/date/DateEquals.js.map +1 -1
  208. package/dist/esm/condition/date/DateGreaterThan.d.ts.map +1 -1
  209. package/dist/esm/condition/date/DateGreaterThan.js +7 -2
  210. package/dist/esm/condition/date/DateGreaterThan.js.map +1 -1
  211. package/dist/esm/condition/date/DateGreaterThanEquals.d.ts.map +1 -1
  212. package/dist/esm/condition/date/DateGreaterThanEquals.js +7 -2
  213. package/dist/esm/condition/date/DateGreaterThanEquals.js.map +1 -1
  214. package/dist/esm/condition/date/DateLessThan.d.ts.map +1 -1
  215. package/dist/esm/condition/date/DateLessThan.js +7 -2
  216. package/dist/esm/condition/date/DateLessThan.js.map +1 -1
  217. package/dist/esm/condition/date/DateLessThanEquals.d.ts.map +1 -1
  218. package/dist/esm/condition/date/DateLessThanEquals.js +7 -2
  219. package/dist/esm/condition/date/DateLessThanEquals.js.map +1 -1
  220. package/dist/esm/condition/date/DateNotEquals.d.ts.map +1 -1
  221. package/dist/esm/condition/date/DateNotEquals.js +12 -19
  222. package/dist/esm/condition/date/DateNotEquals.js.map +1 -1
  223. package/dist/esm/condition/date/date.d.ts +2 -1
  224. package/dist/esm/condition/date/date.d.ts.map +1 -1
  225. package/dist/esm/condition/date/date.js +20 -5
  226. package/dist/esm/condition/date/date.js.map +1 -1
  227. package/dist/esm/condition/ipaddress/IpAddress.d.ts.map +1 -1
  228. package/dist/esm/condition/ipaddress/IpAddress.js +9 -16
  229. package/dist/esm/condition/ipaddress/IpAddress.js.map +1 -1
  230. package/dist/esm/condition/ipaddress/NotIpAddress.d.ts.map +1 -1
  231. package/dist/esm/condition/ipaddress/NotIpAddress.js +9 -20
  232. package/dist/esm/condition/ipaddress/NotIpAddress.js.map +1 -1
  233. package/dist/esm/condition/ipaddress/ip.d.ts +10 -0
  234. package/dist/esm/condition/ipaddress/ip.d.ts.map +1 -0
  235. package/dist/esm/condition/ipaddress/ip.js +54 -0
  236. package/dist/esm/condition/ipaddress/ip.js.map +1 -0
  237. package/dist/esm/condition/numeric/NumericEquals.d.ts.map +1 -1
  238. package/dist/esm/condition/numeric/NumericEquals.js +7 -2
  239. package/dist/esm/condition/numeric/NumericEquals.js.map +1 -1
  240. package/dist/esm/condition/numeric/NumericGreaterThan.d.ts.map +1 -1
  241. package/dist/esm/condition/numeric/NumericGreaterThan.js +7 -2
  242. package/dist/esm/condition/numeric/NumericGreaterThan.js.map +1 -1
  243. package/dist/esm/condition/numeric/NumericGreaterThanEquals.d.ts.map +1 -1
  244. package/dist/esm/condition/numeric/NumericGreaterThanEquals.js +7 -2
  245. package/dist/esm/condition/numeric/NumericGreaterThanEquals.js.map +1 -1
  246. package/dist/esm/condition/numeric/NumericLessThan.d.ts.map +1 -1
  247. package/dist/esm/condition/numeric/NumericLessThan.js +7 -2
  248. package/dist/esm/condition/numeric/NumericLessThan.js.map +1 -1
  249. package/dist/esm/condition/numeric/NumericLessThanEquals.d.ts.map +1 -1
  250. package/dist/esm/condition/numeric/NumericLessThanEquals.js +7 -2
  251. package/dist/esm/condition/numeric/NumericLessThanEquals.js.map +1 -1
  252. package/dist/esm/condition/numeric/NumericNotEquals.d.ts.map +1 -1
  253. package/dist/esm/condition/numeric/NumericNotEquals.js +12 -19
  254. package/dist/esm/condition/numeric/NumericNotEquals.js.map +1 -1
  255. package/dist/esm/condition/numeric/numeric.d.ts +2 -1
  256. package/dist/esm/condition/numeric/numeric.d.ts.map +1 -1
  257. package/dist/esm/condition/numeric/numeric.js +18 -3
  258. package/dist/esm/condition/numeric/numeric.js.map +1 -1
  259. package/dist/esm/condition/string/StringEquals.d.ts.map +1 -1
  260. package/dist/esm/condition/string/StringEquals.js +25 -4
  261. package/dist/esm/condition/string/StringEquals.js.map +1 -1
  262. package/dist/esm/condition/string/StringEqualsIgnoreCase.d.ts.map +1 -1
  263. package/dist/esm/condition/string/StringEqualsIgnoreCase.js +24 -6
  264. package/dist/esm/condition/string/StringEqualsIgnoreCase.js.map +1 -1
  265. package/dist/esm/condition/string/StringLike.d.ts.map +1 -1
  266. package/dist/esm/condition/string/StringLike.js +25 -4
  267. package/dist/esm/condition/string/StringLike.js.map +1 -1
  268. package/dist/esm/condition/string/StringNotEquals.d.ts.map +1 -1
  269. package/dist/esm/condition/string/StringNotEquals.js +25 -4
  270. package/dist/esm/condition/string/StringNotEquals.js.map +1 -1
  271. package/dist/esm/condition/string/StringNotEqualsIgnoreCase.d.ts.map +1 -1
  272. package/dist/esm/condition/string/StringNotEqualsIgnoreCase.js +25 -3
  273. package/dist/esm/condition/string/StringNotEqualsIgnoreCase.js.map +1 -1
  274. package/dist/esm/condition/string/StringNotLike.d.ts.map +1 -1
  275. package/dist/esm/condition/string/StringNotLike.js +25 -3
  276. package/dist/esm/condition/string/StringNotLike.js.map +1 -1
  277. package/dist/esm/core_engine/coreSimulatorEngine.d.ts +10 -7
  278. package/dist/esm/core_engine/coreSimulatorEngine.d.ts.map +1 -1
  279. package/dist/esm/core_engine/coreSimulatorEngine.js +147 -28
  280. package/dist/esm/core_engine/coreSimulatorEngine.js.map +1 -1
  281. package/dist/esm/evaluate.d.ts +47 -0
  282. package/dist/esm/evaluate.d.ts.map +1 -1
  283. package/dist/esm/explain/displayExplainCli.d.ts +3 -0
  284. package/dist/esm/explain/displayExplainCli.d.ts.map +1 -0
  285. package/dist/esm/explain/displayExplainCli.js +246 -0
  286. package/dist/esm/explain/displayExplainCli.js.map +1 -0
  287. package/dist/esm/explain/statementExplain.d.ts +51 -0
  288. package/dist/esm/explain/statementExplain.d.ts.map +1 -0
  289. package/dist/esm/explain/statementExplain.js +6 -0
  290. package/dist/esm/explain/statementExplain.js.map +1 -0
  291. package/dist/esm/index.d.ts +1 -0
  292. package/dist/esm/index.d.ts.map +1 -1
  293. package/dist/esm/index.js.map +1 -1
  294. package/dist/esm/principal/principal.d.ts +28 -6
  295. package/dist/esm/principal/principal.d.ts.map +1 -1
  296. package/dist/esm/principal/principal.js +144 -38
  297. package/dist/esm/principal/principal.js.map +1 -1
  298. package/dist/esm/resource/resource.d.ts +13 -3
  299. package/dist/esm/resource/resource.d.ts.map +1 -1
  300. package/dist/esm/resource/resource.js +69 -16
  301. package/dist/esm/resource/resource.js.map +1 -1
  302. package/dist/esm/services/DefaultServiceAuthorizer.d.ts +2 -34
  303. package/dist/esm/services/DefaultServiceAuthorizer.d.ts.map +1 -1
  304. package/dist/esm/services/DefaultServiceAuthorizer.js +95 -131
  305. package/dist/esm/services/DefaultServiceAuthorizer.js.map +1 -1
  306. package/dist/esm/services/ServiceAuthorizer.d.ts +6 -7
  307. package/dist/esm/services/ServiceAuthorizer.d.ts.map +1 -1
  308. package/dist/esm/simulation_engine/simulation.d.ts +4 -0
  309. package/dist/esm/simulation_engine/simulation.d.ts.map +1 -1
  310. package/dist/esm/simulation_engine/simulationEngine.d.ts +2 -4
  311. package/dist/esm/simulation_engine/simulationEngine.d.ts.map +1 -1
  312. package/dist/esm/simulation_engine/simulationEngine.js +16 -4
  313. package/dist/esm/simulation_engine/simulationEngine.js.map +1 -1
  314. package/dist/esm/simulation_engine/unsafeSimulationEngine.d.ts.map +1 -1
  315. package/dist/esm/simulation_engine/unsafeSimulationEngine.js +5 -2
  316. package/dist/esm/simulation_engine/unsafeSimulationEngine.js.map +1 -1
  317. package/dist/esm/util.d.ts +31 -3
  318. package/dist/esm/util.d.ts.map +1 -1
  319. package/dist/esm/util.js +70 -31
  320. package/dist/esm/util.js.map +1 -1
  321. package/package.json +2 -2
  322. package/dist/cjs/SCPAnalysis.d.ts +0 -6
  323. package/dist/cjs/SCPAnalysis.d.ts.map +0 -1
  324. package/dist/cjs/SCPAnalysis.js +0 -3
  325. package/dist/cjs/SCPAnalysis.js.map +0 -1
  326. package/dist/esm/SCPAnalysis.d.ts +0 -6
  327. package/dist/esm/SCPAnalysis.d.ts.map +0 -1
  328. package/dist/esm/SCPAnalysis.js +0 -2
  329. package/dist/esm/SCPAnalysis.js.map +0 -1
@@ -5,13 +5,18 @@ const date_js_1 = require("./date.js");
5
5
  exports.DateLessThan = {
6
6
  name: 'DateLessThan',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, date_js_1.checkIfDate)(policyValue, keyValue, (policyEpoch, requestEpoch) => {
10
10
  return policyEpoch > requestEpoch;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=DateLessThan.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DateLessThan.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThan.ts"],"names":[],"mappings":";;;AAEA,uCAAwC;AAE3B,QAAA,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IAEpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,qBAAW,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,GAAG,YAAY,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"DateLessThan.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThan.ts"],"names":[],"mappings":";;;AAEA,uCAAwC;AAE3B,QAAA,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IAEpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,qBAAW,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,GAAG,YAAY,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"DateLessThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,kBAAkB,EAAE,qBAYhC,CAAA"}
1
+ {"version":3,"file":"DateLessThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,kBAAkB,EAAE,qBAkBhC,CAAA"}
@@ -5,13 +5,18 @@ const date_js_1 = require("./date.js");
5
5
  exports.DateLessThanEquals = {
6
6
  name: 'DateLessThanEquals',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, date_js_1.checkIfDate)(policyValue, keyValue, (policyEpoch, requestEpoch) => {
10
10
  return policyEpoch >= requestEpoch;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=DateLessThanEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DateLessThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":";;;AAEA,uCAAwC;AAE3B,QAAA,kBAAkB,GAA0B;IACvD,IAAI,EAAE,oBAAoB;IAE1B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,qBAAW,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"DateLessThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateLessThanEquals.ts"],"names":[],"mappings":";;;AAEA,uCAAwC;AAE3B,QAAA,kBAAkB,GAA0B;IACvD,IAAI,EAAE,oBAAoB;IAE1B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,qBAAW,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"DateNotEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,aAAa,EAAE,qBAsB3B,CAAA"}
1
+ {"version":3,"file":"DateNotEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,aAAa,EAAE,qBAiB3B,CAAA"}
@@ -1,29 +1,22 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DateNotEquals = void 0;
4
- const util_js_1 = require("../../util.js");
5
4
  const date_js_1 = require("./date.js");
6
5
  exports.DateNotEquals = {
7
6
  name: 'DateNotEquals',
8
7
  matches: (request, keyValue, policyValues) => {
9
- //How does this behave with malformed numbers
10
- // return !NumericEquals.matches(request, keyValue, policyValues)
11
- // const numericMatch = policyValues.some(policyValue => {
12
- // return checkIfNumeric(policyValue, keyValue, (policyNumber, testNumber) => {
13
- // return policyNumber == testNumber
14
- // })
15
- // })
16
- const requestValue = (0, date_js_1.parseDate)(keyValue);
17
- if ((0, util_js_1.isNotDefined)(requestValue)) {
18
- return false;
19
- }
20
- const policyNumbers = policyValues.map(value => (0, date_js_1.parseDate)(value)).filter(value => (0, util_js_1.isDefined)(value));
21
- if (policyNumbers.length === 0) {
22
- return false;
23
- }
24
- return !policyNumbers.some(policyNumber => policyNumber == requestValue);
8
+ const explains = policyValues.map(policyValue => {
9
+ return (0, date_js_1.checkIfDate)(policyValue, keyValue, (policyEpoch, requestEpoch) => {
10
+ return policyEpoch != requestEpoch;
11
+ });
12
+ });
13
+ return {
14
+ matches: !explains.some(explain => !explain.matches),
15
+ explains
16
+ };
25
17
  },
26
18
  allowsVariables: false,
27
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: true
28
21
  };
29
22
  //# sourceMappingURL=DateNotEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DateNotEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":";;;AAAA,2CAAwD;AAExD,uCAAsC;AAEzB,QAAA,aAAa,GAA0B;IAClD,IAAI,EAAE,eAAe;IACrB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,6CAA6C;QAC7C,iEAAiE;QACjE,2DAA2D;QAC3D,iFAAiF;QACjF,wCAAwC;QACxC,OAAO;QACP,KAAK;QACL,MAAM,YAAY,GAAG,IAAA,mBAAS,EAAC,QAAQ,CAAC,CAAA;QACxC,IAAG,IAAA,sBAAY,EAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,MAAM,aAAa,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAA,mBAAS,EAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAA,mBAAS,EAAC,KAAK,CAAC,CAAC,CAAA;QACnG,IAAG,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,IAAI,YAAY,CAAC,CAAA;IAC1E,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"DateNotEquals.js","sourceRoot":"","sources":["../../../../src/condition/date/DateNotEquals.ts"],"names":[],"mappings":";;;AACA,uCAAwC;AAE3B,QAAA,aAAa,GAA0B;IAClD,IAAI,EAAE,eAAe;IACrB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,qBAAW,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE;gBACtE,OAAO,WAAW,IAAI,YAAY,CAAA;YACpC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YACpD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,IAAI;CACjB,CAAA"}
@@ -1,3 +1,4 @@
1
+ import { ConditionValueExplain } from "../../explain/statementExplain.js";
1
2
  /**
2
3
  * Parse a string to an epoch date value
3
4
  *
@@ -13,5 +14,5 @@ export declare function parseDate(value: string): number | undefined;
13
14
  * @param check
14
15
  * @returns
15
16
  */
16
- export declare function checkIfDate(policyValue: string, testValue: string, check: (policyValue: number, testValue: number) => boolean): boolean;
17
+ export declare function checkIfDate(policyValue: string, testValue: string, check: (policyValue: number, testValue: number) => boolean): ConditionValueExplain;
17
18
  //# sourceMappingURL=date.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"date.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAiB3D;AAED;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,GAAG,OAAO,CAOvI"}
1
+ {"version":3,"file":"date.d.ts","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAA;AAGzE;;;;;GAKG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAe3D;AAED;;;;;;;GAOG;AACH,wBAAgB,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,GAAG,qBAAqB,CAuBrJ"}
@@ -32,11 +32,26 @@ function parseDate(value) {
32
32
  * @returns
33
33
  */
34
34
  function checkIfDate(policyValue, testValue, check) {
35
- const policyNumber = parseDate(policyValue);
36
- const testNumber = parseDate(testValue);
37
- if ((0, util_js_1.isNotDefined)(policyNumber) || (0, util_js_1.isNotDefined)(testNumber)) {
38
- return false;
35
+ const policyDate = parseDate(policyValue);
36
+ const testDate = parseDate(testValue);
37
+ if ((0, util_js_1.isNotDefined)(policyDate)) {
38
+ return {
39
+ value: policyValue,
40
+ matches: false,
41
+ errors: [`${policyValue} is not a date`]
42
+ };
39
43
  }
40
- return check(policyNumber, testNumber);
44
+ if ((0, util_js_1.isNotDefined)(testDate)) {
45
+ return {
46
+ value: policyValue,
47
+ matches: false,
48
+ errors: [`request value '${testValue}' is not a date`]
49
+ };
50
+ }
51
+ const matches = check(policyDate, testDate);
52
+ return {
53
+ value: policyValue,
54
+ matches,
55
+ };
41
56
  }
42
57
  //# sourceMappingURL=date.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":";;AAQA,8BAiBC;AAUD,kCAOC;AA1CD,2CAAuD;AAEvD;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,KAAa;IACrC,mEAAmE;IACnE,oBAAoB;IACpB,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IACrC,IAAG,IAAA,mBAAS,EAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,QAAQ,EAAE,KAAK,KAAK,EAAE,CAAC;QAC/E,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,wEAAwE;IACxE,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACpC,IAAG,IAAA,mBAAS,EAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,OAAO,UAAU,CAAA;IACnB,CAAC;IAID,OAAO,SAAS,CAAA;AAClB,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,WAAW,CAAC,WAAmB,EAAE,SAAiB,EAAE,KAA0D;IAC5H,MAAM,YAAY,GAAG,SAAS,CAAC,WAAW,CAAC,CAAA;IAC3C,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,CAAC,CAAA;IACvC,IAAG,IAAA,sBAAY,EAAC,YAAY,CAAC,IAAI,IAAA,sBAAY,EAAC,UAAU,CAAC,EAAE,CAAC;QAC1D,OAAO,KAAK,CAAA;IACd,CAAC;IACD,OAAO,KAAK,CAAC,YAAY,EAAE,UAAU,CAAC,CAAA;AACxC,CAAC"}
1
+ {"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../src/condition/date/date.ts"],"names":[],"mappings":";;AASA,8BAeC;AAUD,kCAuBC;AAxDD,2CAAuD;AAEvD;;;;;GAKG;AACH,SAAgB,SAAS,CAAC,KAAa;IACrC,mEAAmE;IACnE,oBAAoB;IACpB,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IACrC,IAAG,IAAA,mBAAS,EAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,QAAQ,EAAE,KAAK,KAAK,EAAE,CAAC;QAC/E,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,wEAAwE;IACxE,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACpC,IAAG,IAAA,mBAAS,EAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,OAAO,UAAU,CAAA;IACnB,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,WAAW,CAAC,WAAmB,EAAE,SAAiB,EAAE,KAA0D;IAC5H,MAAM,UAAU,GAAG,SAAS,CAAC,WAAW,CAAC,CAAA;IACzC,MAAM,QAAQ,GAAG,SAAS,CAAC,SAAS,CAAC,CAAA;IACrC,IAAG,IAAA,sBAAY,EAAC,UAAU,CAAC,EAAE,CAAC;QAC5B,OAAO;YACL,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,CAAC,GAAG,WAAW,gBAAgB,CAAC;SACzC,CAAA;IACH,CAAC;IACD,IAAG,IAAA,sBAAY,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,OAAO;YACL,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,KAAK;YACd,MAAM,EAAE,CAAC,kBAAkB,SAAS,iBAAiB,CAAC;SACvD,CAAA;IACH,CAAC;IAED,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IAC3C,OAAO;QACL,KAAK,EAAE,WAAW;QAClB,OAAO;KACR,CAAA;AACH,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"IpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAIpE,eAAO,MAAM,SAAS,EAAE,qBAoBvB,CAAA"}
1
+ {"version":3,"file":"IpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,SAAS,EAAE,qBAevB,CAAA"}
@@ -1,27 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.IpAddress = void 0;
4
- const ipv4_js_1 = require("./ipv4.js");
5
- const ipv6_js_1 = require("./ipv6.js");
4
+ const ip_js_1 = require("./ip.js");
6
5
  exports.IpAddress = {
7
6
  name: 'IpAddress',
8
7
  matches: (request, keyValue, policyValues) => {
9
- if (!(0, ipv4_js_1.isValidIpV4)(keyValue) && !(0, ipv6_js_1.isValidIpV6)(keyValue)) {
10
- return false;
11
- }
12
- return policyValues.some(policyValue => {
13
- const isV4Cidr = (0, ipv4_js_1.isValidCidrV4)(policyValue);
14
- const isV6Cidr = (0, ipv6_js_1.isValidIpCidrV6)(policyValue);
15
- if (!isV4Cidr && !isV6Cidr) {
16
- return false;
17
- }
18
- if (isV4Cidr) {
19
- return (0, ipv4_js_1.isValidIpV4)(keyValue) && (0, ipv4_js_1.isIpInCidrV4)(keyValue, policyValue);
20
- }
21
- return (0, ipv6_js_1.isValidIpV6)(keyValue) && (0, ipv6_js_1.isIpInCidrV6)(keyValue, policyValue);
8
+ const explains = policyValues.map(policyValue => {
9
+ return (0, ip_js_1.checkIfIpAddress)(policyValue, keyValue, true);
22
10
  });
11
+ return {
12
+ matches: explains.some(explain => explain.matches),
13
+ explains
14
+ };
23
15
  },
24
16
  allowsVariables: false,
25
- allowsWildcards: false
17
+ allowsWildcards: false,
18
+ isNegative: false
26
19
  };
27
20
  //# sourceMappingURL=IpAddress.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"IpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":";;;AACA,uCAAqE;AACrE,uCAAwF;AAE3E,QAAA,SAAS,GAA0B;IAC9C,IAAI,EAAE,WAAW;IACjB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,IAAG,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,EAAE,CAAC;YACpD,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,MAAM,QAAQ,GAAG,IAAA,uBAAa,EAAC,WAAW,CAAC,CAAA;YAC3C,MAAM,QAAQ,GAAG,IAAA,yBAAa,EAAC,WAAW,CAAC,CAAA;YAC3C,IAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC1B,OAAO,KAAK,CAAA;YACd,CAAC;YACD,IAAG,QAAQ,EAAE,CAAC;gBACZ,OAAO,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,IAAA,sBAAY,EAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YACrE,CAAC;YACD,OAAO,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,IAAA,sBAAY,EAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;QACrE,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"IpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/IpAddress.ts"],"names":[],"mappings":";;;AACA,mCAA2C;AAE9B,QAAA,SAAS,GAA0B;IAC9C,IAAI,EAAE,WAAW;IACjB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,wBAAgB,EAAC,WAAW,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAA;QACtD,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NotIpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAIpE,eAAO,MAAM,YAAY,EAAE,qBAyB1B,CAAA"}
1
+ {"version":3,"file":"NotIpAddress.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,YAAY,EAAE,qBAe1B,CAAA"}
@@ -1,31 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.NotIpAddress = void 0;
4
- const ipv4_js_1 = require("./ipv4.js");
5
- const ipv6_js_1 = require("./ipv6.js");
4
+ const ip_js_1 = require("./ip.js");
6
5
  exports.NotIpAddress = {
7
6
  name: 'NotIpAddress',
8
7
  matches: (request, keyValue, policyValues) => {
9
- const validPolicyValues = policyValues.filter(policyValue => (0, ipv4_js_1.isValidCidrV4)(policyValue) || (0, ipv6_js_1.isValidIpCidrV6)(policyValue));
10
- if (validPolicyValues.length === 0) {
11
- return false;
12
- }
13
- if (!(0, ipv4_js_1.isValidIpV4)(keyValue) && !(0, ipv6_js_1.isValidIpV6)(keyValue)) {
14
- return false;
15
- }
16
- return !validPolicyValues.some(policyValue => {
17
- const isV4Cidr = (0, ipv4_js_1.isValidCidrV4)(policyValue);
18
- const isV6Cidr = (0, ipv6_js_1.isValidIpCidrV6)(policyValue);
19
- if (!isV4Cidr && !isV6Cidr) {
20
- return false;
21
- }
22
- if (isV4Cidr) {
23
- return (0, ipv4_js_1.isValidIpV4)(keyValue) && (0, ipv4_js_1.isIpInCidrV4)(keyValue, policyValue);
24
- }
25
- return (0, ipv6_js_1.isValidIpV6)(keyValue) && (0, ipv6_js_1.isIpInCidrV6)(keyValue, policyValue);
8
+ const explains = policyValues.map(policyValue => {
9
+ return (0, ip_js_1.checkIfIpAddress)(policyValue, keyValue, false);
26
10
  });
11
+ return {
12
+ matches: !explains.some(explain => !explain.matches),
13
+ explains
14
+ };
27
15
  },
28
16
  allowsVariables: false,
29
- allowsWildcards: false
17
+ allowsWildcards: false,
18
+ isNegative: true
30
19
  };
31
20
  //# sourceMappingURL=NotIpAddress.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NotIpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":";;;AACA,uCAAqE;AACrE,uCAAwF;AAE3E,QAAA,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IACpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,iBAAiB,GAAG,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,IAAA,uBAAa,EAAC,WAAW,CAAC,IAAI,IAAA,yBAAa,EAAC,WAAW,CAAC,CAAC,CAAA;QACtH,IAAG,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO,KAAK,CAAA;QACd,CAAC;QAED,IAAG,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,CAAC,IAAA,qBAAW,EAAC,QAAQ,CAAC,EAAE,CAAC;YACpD,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC3C,MAAM,QAAQ,GAAG,IAAA,uBAAa,EAAC,WAAW,CAAC,CAAA;YAC3C,MAAM,QAAQ,GAAG,IAAA,yBAAa,EAAC,WAAW,CAAC,CAAA;YAC3C,IAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC1B,OAAO,KAAK,CAAA;YACd,CAAC;YACD,IAAG,QAAQ,EAAE,CAAC;gBACZ,OAAO,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,IAAA,sBAAY,EAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;YACrE,CAAC;YACD,OAAO,IAAA,qBAAW,EAAC,QAAQ,CAAC,IAAI,IAAA,sBAAY,EAAC,QAAQ,EAAE,WAAW,CAAC,CAAA;QACrE,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NotIpAddress.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/NotIpAddress.ts"],"names":[],"mappings":";;;AACA,mCAA2C;AAE9B,QAAA,YAAY,GAA0B;IACjD,IAAI,EAAE,cAAc;IACpB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,wBAAgB,EAAC,WAAW,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;QACvD,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YACpD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,IAAI;CACjB,CAAA"}
@@ -0,0 +1,10 @@
1
+ import { ConditionValueExplain } from "../../explain/statementExplain.js";
2
+ /**
3
+ * Check if the request value is within the policy value CIDR block if the policy value is a valid CIDR block.
4
+ *
5
+ * @param policyValue - The CIDR block to check against.
6
+ * @param requestValue - The IP address to check.
7
+ * @returns An object explaining the result.
8
+ */
9
+ export declare function checkIfIpAddress(policyValue: string, requestValue: string, expectInCidr: boolean): ConditionValueExplain;
10
+ //# sourceMappingURL=ip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ip.d.ts","sourceRoot":"","sources":["../../../../src/condition/ipaddress/ip.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAI1E;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,GAAG,qBAAqB,CA8CxH"}
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.checkIfIpAddress = checkIfIpAddress;
4
+ const ipv4_js_1 = require("./ipv4.js");
5
+ const ipv6_js_1 = require("./ipv6.js");
6
+ /**
7
+ * Check if the request value is within the policy value CIDR block if the policy value is a valid CIDR block.
8
+ *
9
+ * @param policyValue - The CIDR block to check against.
10
+ * @param requestValue - The IP address to check.
11
+ * @returns An object explaining the result.
12
+ */
13
+ function checkIfIpAddress(policyValue, requestValue, expectInCidr) {
14
+ if ((0, ipv4_js_1.isValidCidrV4)(policyValue)) {
15
+ if ((0, ipv6_js_1.isValidIpV6)(requestValue)) {
16
+ return {
17
+ matches: false == expectInCidr,
18
+ value: policyValue,
19
+ };
20
+ }
21
+ if (!(0, ipv4_js_1.isValidIpV4)(requestValue)) {
22
+ return {
23
+ matches: false,
24
+ value: policyValue
25
+ };
26
+ }
27
+ return {
28
+ matches: (0, ipv4_js_1.isIpInCidrV4)(requestValue, policyValue) == expectInCidr,
29
+ value: policyValue
30
+ };
31
+ }
32
+ if ((0, ipv6_js_1.isValidIpCidrV6)(policyValue)) {
33
+ if ((0, ipv4_js_1.isValidIpV4)(requestValue)) {
34
+ return {
35
+ matches: false == expectInCidr,
36
+ value: policyValue
37
+ };
38
+ }
39
+ if (!(0, ipv6_js_1.isValidIpV6)(requestValue)) {
40
+ return {
41
+ matches: false,
42
+ value: policyValue,
43
+ errors: [`Request value '${requestValue}' not a valid IPv6 address`]
44
+ };
45
+ }
46
+ return {
47
+ matches: (0, ipv6_js_1.isIpInCidrV6)(requestValue, policyValue) == expectInCidr,
48
+ value: policyValue
49
+ };
50
+ }
51
+ return {
52
+ matches: false,
53
+ value: policyValue,
54
+ errors: [`${policyValue} is not a valid CIDR block`]
55
+ };
56
+ }
57
+ //# sourceMappingURL=ip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ip.js","sourceRoot":"","sources":["../../../../src/condition/ipaddress/ip.ts"],"names":[],"mappings":";;AAWA,4CA8CC;AAxDD,uCAAqE;AACrE,uCAAuE;AAEvE;;;;;;GAMG;AACH,SAAgB,gBAAgB,CAAC,WAAmB,EAAE,YAAoB,EAAE,YAAqB;IAC/F,IAAG,IAAA,uBAAa,EAAC,WAAW,CAAC,EAAE,CAAC;QAC9B,IAAG,IAAA,qBAAW,EAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,OAAO;gBACL,OAAO,EAAE,KAAK,IAAI,YAAY;gBAC9B,KAAK,EAAE,WAAW;aACnB,CAAA;QACH,CAAC;QACD,IAAG,CAAC,IAAA,qBAAW,EAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,WAAW;aACnB,CAAA;QACH,CAAC;QAED,OAAO;YACL,OAAO,EAAE,IAAA,sBAAY,EAAC,YAAY,EAAE,WAAW,CAAC,IAAI,YAAY;YAChE,KAAK,EAAE,WAAW;SACnB,CAAA;IACH,CAAC;IACD,IAAG,IAAA,yBAAe,EAAC,WAAW,CAAC,EAAE,CAAC;QAChC,IAAG,IAAA,qBAAW,EAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,OAAO;gBACL,OAAO,EAAE,KAAK,IAAI,YAAY;gBAC9B,KAAK,EAAE,WAAW;aACnB,CAAA;QACH,CAAC;QACD,IAAG,CAAC,IAAA,qBAAW,EAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,OAAO;gBACL,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,WAAW;gBAClB,MAAM,EAAE,CAAC,kBAAkB,YAAY,4BAA4B,CAAC;aACrE,CAAA;QACH,CAAC;QAED,OAAO;YACL,OAAO,EAAE,IAAA,sBAAY,EAAC,YAAY,EAAE,WAAW,CAAC,IAAI,YAAY;YAChE,KAAK,EAAE,WAAW;SACnB,CAAA;IACH,CAAC;IAED,OAAO;QACL,OAAO,EAAE,KAAK;QACd,KAAK,EAAE,WAAW;QAClB,MAAM,EAAE,CAAC,GAAG,WAAW,4BAA4B,CAAC;KACrD,CAAA;AACH,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,aAAa,EAAE,qBAY3B,CAAA"}
1
+ {"version":3,"file":"NumericEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,aAAa,EAAE,qBAkB3B,CAAA"}
@@ -5,13 +5,18 @@ const numeric_js_1 = require("./numeric.js");
5
5
  exports.NumericEquals = {
6
6
  name: 'NumericEquals',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
10
  return policyNumber == testNumber;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=NumericEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,aAAa,GAA0B;IAClD,IAAI,EAAE,eAAe;IAErB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,aAAa,GAA0B;IAClD,IAAI,EAAE,eAAe;IAErB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericGreaterThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,kBAAkB,EAAE,qBAYhC,CAAA"}
1
+ {"version":3,"file":"NumericGreaterThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,kBAAkB,EAAE,qBAiBhC,CAAA"}
@@ -5,13 +5,18 @@ const numeric_js_1 = require("./numeric.js");
5
5
  exports.NumericGreaterThan = {
6
6
  name: 'NumericGreaterThan',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
10
  return policyNumber > testNumber;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=NumericGreaterThan.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericGreaterThan.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThan.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,kBAAkB,GAA0B;IACvD,IAAI,EAAE,oBAAoB;IAE1B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,GAAG,UAAU,CAAA;YAClC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericGreaterThan.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThan.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,kBAAkB,GAA0B;IACvD,IAAI,EAAE,oBAAoB;IAC1B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,GAAG,UAAU,CAAA;YAClC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericGreaterThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThanEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,wBAAwB,EAAE,qBAYtC,CAAA"}
1
+ {"version":3,"file":"NumericGreaterThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThanEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,wBAAwB,EAAE,qBAkBtC,CAAA"}
@@ -5,13 +5,18 @@ const numeric_js_1 = require("./numeric.js");
5
5
  exports.NumericGreaterThanEquals = {
6
6
  name: 'NumericGreaterThanEquals',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
10
  return policyNumber >= testNumber;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=NumericGreaterThanEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericGreaterThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThanEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,wBAAwB,GAA0B;IAC7D,IAAI,EAAE,0BAA0B;IAEhC,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericGreaterThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericGreaterThanEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,wBAAwB,GAA0B;IAC7D,IAAI,EAAE,0BAA0B;IAEhC,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericLessThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,eAAe,EAAE,qBAY7B,CAAA"}
1
+ {"version":3,"file":"NumericLessThan.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,eAAe,EAAE,qBAkB7B,CAAA"}
@@ -5,13 +5,18 @@ const numeric_js_1 = require("./numeric.js");
5
5
  exports.NumericLessThan = {
6
6
  name: 'NumericLessThan',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
10
  return policyNumber > testNumber;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=NumericLessThan.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericLessThan.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThan.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,eAAe,GAA0B;IACpD,IAAI,EAAE,iBAAiB;IAEvB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,GAAG,UAAU,CAAA;YAClC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericLessThan.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThan.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,eAAe,GAA0B;IACpD,IAAI,EAAE,iBAAiB;IAEvB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,GAAG,UAAU,CAAA;YAClC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericLessThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThanEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,qBAAqB,EAAE,qBAYnC,CAAA"}
1
+ {"version":3,"file":"NumericLessThanEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThanEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,qBAAqB,EAAE,qBAkBnC,CAAA"}
@@ -5,13 +5,18 @@ const numeric_js_1 = require("./numeric.js");
5
5
  exports.NumericLessThanEquals = {
6
6
  name: 'NumericLessThanEquals',
7
7
  matches: (request, keyValue, policyValues) => {
8
- return policyValues.some(policyValue => {
8
+ const explains = policyValues.map(policyValue => {
9
9
  return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
10
  return policyNumber >= testNumber;
11
11
  });
12
12
  });
13
+ return {
14
+ matches: explains.some(explain => explain.matches),
15
+ explains
16
+ };
13
17
  },
14
18
  allowsVariables: false,
15
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: false
16
21
  };
17
22
  //# sourceMappingURL=NumericLessThanEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericLessThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThanEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,qBAAqB,GAA0B;IAC1D,IAAI,EAAE,uBAAuB;IAE7B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,OAAO,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACrC,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericLessThanEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericLessThanEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,qBAAqB,GAA0B;IAC1D,IAAI,EAAE,uBAAuB;IAE7B,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,KAAK;CAClB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"NumericNotEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericNotEquals.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,gBAAgB,EAAE,qBAsB9B,CAAA"}
1
+ {"version":3,"file":"NumericNotEquals.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericNotEquals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,eAAO,MAAM,gBAAgB,EAAE,qBAiB9B,CAAA"}
@@ -1,29 +1,22 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.NumericNotEquals = void 0;
4
- const util_js_1 = require("../../util.js");
5
4
  const numeric_js_1 = require("./numeric.js");
6
5
  exports.NumericNotEquals = {
7
6
  name: 'NumericNotEquals',
8
7
  matches: (request, keyValue, policyValues) => {
9
- //How does this behave with malformed numbers
10
- // return !NumericEquals.matches(request, keyValue, policyValues)
11
- // const numericMatch = policyValues.some(policyValue => {
12
- // return checkIfNumeric(policyValue, keyValue, (policyNumber, testNumber) => {
13
- // return policyNumber == testNumber
14
- // })
15
- // })
16
- const requestValue = (0, numeric_js_1.parseNumber)(keyValue);
17
- if ((0, util_js_1.isNotDefined)(requestValue)) {
18
- return false;
19
- }
20
- const policyNumbers = policyValues.map(value => (0, numeric_js_1.parseNumber)(value)).filter(value => (0, util_js_1.isDefined)(value));
21
- if (policyNumbers.length === 0) {
22
- return false;
23
- }
24
- return !policyNumbers.some(policyNumber => policyNumber == requestValue);
8
+ const explains = policyValues.map(policyValue => {
9
+ return (0, numeric_js_1.checkIfNumeric)(policyValue, keyValue, (policyNumber, testNumber) => {
10
+ return policyNumber != testNumber;
11
+ });
12
+ });
13
+ return {
14
+ matches: !explains.some(explain => !explain.matches),
15
+ explains
16
+ };
25
17
  },
26
18
  allowsVariables: false,
27
- allowsWildcards: false
19
+ allowsWildcards: false,
20
+ isNegative: true
28
21
  };
29
22
  //# sourceMappingURL=NumericNotEquals.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NumericNotEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericNotEquals.ts"],"names":[],"mappings":";;;AAAA,2CAAwD;AAExD,6CAA2C;AAE9B,QAAA,gBAAgB,GAA0B;IACrD,IAAI,EAAE,kBAAkB;IACxB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,6CAA6C;QAC7C,iEAAiE;QACjE,2DAA2D;QAC3D,iFAAiF;QACjF,wCAAwC;QACxC,OAAO;QACP,KAAK;QACL,MAAM,YAAY,GAAG,IAAA,wBAAW,EAAC,QAAQ,CAAC,CAAA;QAC1C,IAAG,IAAA,sBAAY,EAAC,YAAY,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,MAAM,aAAa,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAA,wBAAW,EAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAA,mBAAS,EAAC,KAAK,CAAC,CAAC,CAAA;QACrG,IAAG,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAA;QACd,CAAC;QACD,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,IAAI,YAAY,CAAC,CAAA;IAC1E,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;CACvB,CAAA"}
1
+ {"version":3,"file":"NumericNotEquals.js","sourceRoot":"","sources":["../../../../src/condition/numeric/NumericNotEquals.ts"],"names":[],"mappings":";;;AACA,6CAA8C;AAEjC,QAAA,gBAAgB,GAA0B;IACrD,IAAI,EAAE,kBAAkB;IACxB,OAAO,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE;QAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;YAC9C,OAAO,IAAA,2BAAc,EAAC,WAAW,EAAE,QAAQ,EAAE,CAAC,YAAY,EAAE,UAAU,EAAE,EAAE;gBACxE,OAAO,YAAY,IAAI,UAAU,CAAA;YACnC,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,OAAO,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YACpD,QAAQ;SACT,CAAA;IACH,CAAC;IACD,eAAe,EAAE,KAAK;IACtB,eAAe,EAAE,KAAK;IACtB,UAAU,EAAE,IAAI;CACjB,CAAA"}
@@ -1,3 +1,4 @@
1
+ import { ConditionValueExplain } from "../../explain/statementExplain.js";
1
2
  /**
2
3
  * Parse a string to a number, returns undefined if the string is not a number
3
4
  *
@@ -13,5 +14,5 @@ export declare function parseNumber(value: string): number | undefined;
13
14
  * @param check
14
15
  * @returns
15
16
  */
16
- export declare function checkIfNumeric(policyValue: string, testValue: string, check: (policyValue: number, testValue: number) => boolean): boolean;
17
+ export declare function checkIfNumeric(policyValue: string, testValue: string, check: (policyValue: number, testValue: number) => boolean): ConditionValueExplain;
17
18
  //# sourceMappingURL=numeric.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"numeric.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/numeric.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAY7D;AAED;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,GAAG,OAAO,CAO1I"}
1
+ {"version":3,"file":"numeric.d.ts","sourceRoot":"","sources":["../../../../src/condition/numeric/numeric.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAA;AAGzE;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAY7D;AAED;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,OAAO,GAAG,qBAAqB,CAuBxJ"}