addio-admin-sdk 1.7.167 → 1.7.169

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 (577) hide show
  1. package/.babelrc +17 -17
  2. package/.env +15 -0
  3. package/.env.dev +14 -14
  4. package/.github/workflows/run_unit_test.yaml +48 -48
  5. package/addio-sdk-doc.md +1473 -1473
  6. package/changelog.md +573 -573
  7. package/dist/Interfaces/Address/index.d.ts +21 -21
  8. package/dist/Interfaces/Address/index.js +16 -16
  9. package/dist/Interfaces/Algolia/index.d.ts +182 -180
  10. package/dist/Interfaces/Algolia/index.js +2 -2
  11. package/dist/Interfaces/Attachement/index.d.ts +5 -5
  12. package/dist/Interfaces/Attachement/index.js +2 -2
  13. package/dist/Interfaces/Attribute/index.d.ts +53 -53
  14. package/dist/Interfaces/Attribute/index.js +10 -10
  15. package/dist/Interfaces/BGJob/index.d.ts +56 -56
  16. package/dist/Interfaces/BGJob/index.js +25 -25
  17. package/dist/Interfaces/BaseClass/index.d.ts +8 -8
  18. package/dist/Interfaces/BaseClass/index.js +2 -2
  19. package/dist/Interfaces/Blog/IBlogArticle.d.ts +18 -18
  20. package/dist/Interfaces/Blog/IBlogArticle.js +2 -2
  21. package/dist/Interfaces/Blog/IBlogAuthor.d.ts +7 -7
  22. package/dist/Interfaces/Blog/IBlogAuthor.js +2 -2
  23. package/dist/Interfaces/Blog/IBlogCategory.d.ts +9 -9
  24. package/dist/Interfaces/Blog/IBlogCategory.js +2 -2
  25. package/dist/Interfaces/Blog/IBlogComment.d.ts +13 -13
  26. package/dist/Interfaces/Blog/IBlogComment.js +2 -2
  27. package/dist/Interfaces/Blog/IBlogKeywords.d.ts +9 -9
  28. package/dist/Interfaces/Blog/IBlogKeywords.js +2 -2
  29. package/dist/Interfaces/Booking/index.d.ts +74 -74
  30. package/dist/Interfaces/Booking/index.js +17 -17
  31. package/dist/Interfaces/Brand/index.d.ts +15 -15
  32. package/dist/Interfaces/Brand/index.js +2 -2
  33. package/dist/Interfaces/CMS/index.d.ts +28 -28
  34. package/dist/Interfaces/CMS/index.js +5 -5
  35. package/dist/Interfaces/Cart/IElavonPayload.d.ts +93 -93
  36. package/dist/Interfaces/Cart/IElavonPayload.js +17 -17
  37. package/dist/Interfaces/Cart/IMarketPayload.d.ts +12 -12
  38. package/dist/Interfaces/Cart/IMarketPayload.js +2 -2
  39. package/dist/Interfaces/Cart/IPandaPayload.d.ts +64 -64
  40. package/dist/Interfaces/Cart/IPandaPayload.js +18 -18
  41. package/dist/Interfaces/Cart/IPaymentCard.d.ts +22 -22
  42. package/dist/Interfaces/Cart/IPaymentCard.js +44 -44
  43. package/dist/Interfaces/Cart/IPaypalPayload.d.ts +9 -9
  44. package/dist/Interfaces/Cart/IPaypalPayload.js +2 -2
  45. package/dist/Interfaces/Cart/IPaysafePayload.d.ts +72 -72
  46. package/dist/Interfaces/Cart/IPaysafePayload.js +2 -2
  47. package/dist/Interfaces/Cart/IStripePayload.d.ts +66 -66
  48. package/dist/Interfaces/Cart/IStripePayload.js +2 -2
  49. package/dist/Interfaces/Cart/index.d.ts +451 -451
  50. package/dist/Interfaces/Cart/index.js +216 -216
  51. package/dist/Interfaces/CartReservedQuantities/index.d.ts +10 -10
  52. package/dist/Interfaces/CartReservedQuantities/index.js +2 -2
  53. package/dist/Interfaces/CashDrawers/index.d.ts +38 -38
  54. package/dist/Interfaces/CashDrawers/index.js +19 -19
  55. package/dist/Interfaces/Catalogue/index.d.ts +68 -68
  56. package/dist/Interfaces/Catalogue/index.js +37 -37
  57. package/dist/Interfaces/Category/index.d.ts +33 -33
  58. package/dist/Interfaces/Category/index.js +2 -2
  59. package/dist/Interfaces/Chart/index.d.ts +11 -11
  60. package/dist/Interfaces/Chart/index.js +2 -2
  61. package/dist/Interfaces/Class/index.d.ts +8 -8
  62. package/dist/Interfaces/Class/index.js +2 -2
  63. package/dist/Interfaces/Consent/index.d.ts +6 -6
  64. package/dist/Interfaces/Consent/index.js +2 -2
  65. package/dist/Interfaces/Context/IContextProps.d.ts +4 -4
  66. package/dist/Interfaces/Context/IContextProps.js +2 -2
  67. package/dist/Interfaces/Context/IContextState.d.ts +15 -15
  68. package/dist/Interfaces/Context/IContextState.js +2 -2
  69. package/dist/Interfaces/Customer/ICustomerBadge.d.ts +2 -2
  70. package/dist/Interfaces/Customer/ICustomerBadge.js +2 -2
  71. package/dist/Interfaces/Customer/ICustomerRating.d.ts +10 -10
  72. package/dist/Interfaces/Customer/ICustomerRating.js +2 -2
  73. package/dist/Interfaces/Customer/IStoreCredit.d.ts +13 -13
  74. package/dist/Interfaces/Customer/IStoreCredit.js +2 -2
  75. package/dist/Interfaces/Customer/index.d.ts +104 -104
  76. package/dist/Interfaces/Customer/index.js +148 -148
  77. package/dist/Interfaces/Declination/index.d.ts +117 -117
  78. package/dist/Interfaces/Declination/index.js +66 -66
  79. package/dist/Interfaces/Document/index.d.ts +8 -8
  80. package/dist/Interfaces/Document/index.js +2 -2
  81. package/dist/Interfaces/Elastic/index.d.ts +89 -89
  82. package/dist/Interfaces/Elastic/index.js +2 -2
  83. package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.d.ts +11 -11
  84. package/dist/Interfaces/Email/CustomGR/I3DPrintEmail.js +2 -2
  85. package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.d.ts +15 -15
  86. package/dist/Interfaces/Email/CustomGR/IBorrowToolsEmail.js +2 -2
  87. package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.d.ts +12 -12
  88. package/dist/Interfaces/Email/CustomGR/IPickupMaterialsEmail.js +2 -2
  89. package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.d.ts +36 -36
  90. package/dist/Interfaces/Email/CustomGR/IPreMeetingFormEmail.js +2 -2
  91. package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.d.ts +12 -12
  92. package/dist/Interfaces/Email/CustomGR/ISponsorRequestEmail.js +2 -2
  93. package/dist/Interfaces/Email/CustomGR/ITransportEmail.d.ts +12 -12
  94. package/dist/Interfaces/Email/CustomGR/ITransportEmail.js +2 -2
  95. package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.d.ts +12 -12
  96. package/dist/Interfaces/Email/CustomGR/ITransportQuoteEmail.js +2 -2
  97. package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.d.ts +16 -16
  98. package/dist/Interfaces/Email/CustomGR/IVegetalsEmail.js +2 -2
  99. package/dist/Interfaces/Email/CustomGR/IWishlistEmail.d.ts +15 -15
  100. package/dist/Interfaces/Email/CustomGR/IWishlistEmail.js +2 -2
  101. package/dist/Interfaces/Email/IAbandonnedCartEmail.d.ts +29 -29
  102. package/dist/Interfaces/Email/IAbandonnedCartEmail.js +2 -2
  103. package/dist/Interfaces/Email/IAccountConfirmationEmail.d.ts +22 -22
  104. package/dist/Interfaces/Email/IAccountConfirmationEmail.js +2 -2
  105. package/dist/Interfaces/Email/IApplicationEmail.d.ts +19 -19
  106. package/dist/Interfaces/Email/IApplicationEmail.js +2 -2
  107. package/dist/Interfaces/Email/IBackInStockEmail.d.ts +21 -21
  108. package/dist/Interfaces/Email/IBackInStockEmail.js +2 -2
  109. package/dist/Interfaces/Email/IContactEmail.d.ts +20 -20
  110. package/dist/Interfaces/Email/IContactEmail.js +2 -2
  111. package/dist/Interfaces/Email/ICustomerBookingAdminEmail.d.ts +15 -15
  112. package/dist/Interfaces/Email/ICustomerBookingAdminEmail.js +2 -2
  113. package/dist/Interfaces/Email/ICustomerBookingEmail.d.ts +14 -14
  114. package/dist/Interfaces/Email/ICustomerBookingEmail.js +2 -2
  115. package/dist/Interfaces/Email/IEmail.d.ts +20 -20
  116. package/dist/Interfaces/Email/IEmail.js +60 -60
  117. package/dist/Interfaces/Email/IOrderConfirmationEmail.d.ts +47 -47
  118. package/dist/Interfaces/Email/IOrderConfirmationEmail.js +2 -2
  119. package/dist/Interfaces/Email/IPasswordResetEmail.d.ts +17 -17
  120. package/dist/Interfaces/Email/IPasswordResetEmail.js +2 -2
  121. package/dist/Interfaces/Email/IPhotoShootEmail.d.ts +14 -14
  122. package/dist/Interfaces/Email/IPhotoShootEmail.js +2 -2
  123. package/dist/Interfaces/Email/IPickupConfirmation.d.ts +23 -23
  124. package/dist/Interfaces/Email/IPickupConfirmation.js +2 -2
  125. package/dist/Interfaces/Email/IShippingConfirmation.d.ts +23 -23
  126. package/dist/Interfaces/Email/IShippingConfirmation.js +2 -2
  127. package/dist/Interfaces/Email/IWelcomeEmail.d.ts +19 -19
  128. package/dist/Interfaces/Email/IWelcomeEmail.js +2 -2
  129. package/dist/Interfaces/ExportSchema/index.d.ts +7 -7
  130. package/dist/Interfaces/ExportSchema/index.js +2 -2
  131. package/dist/Interfaces/ExternalService/BaseExternalService.d.ts +12 -12
  132. package/dist/Interfaces/ExternalService/BaseExternalService.js +2 -2
  133. package/dist/Interfaces/ExternalService/ExternalProductsService.d.ts +4 -4
  134. package/dist/Interfaces/ExternalService/ExternalProductsService.js +2 -2
  135. package/dist/Interfaces/ExternalService/index.d.ts +9 -9
  136. package/dist/Interfaces/ExternalService/index.js +2 -2
  137. package/dist/Interfaces/FirstOrderTracking/index.d.ts +5 -5
  138. package/dist/Interfaces/FirstOrderTracking/index.js +2 -2
  139. package/dist/Interfaces/G2/index.d.ts +556 -556
  140. package/dist/Interfaces/G2/index.js +38 -38
  141. package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.d.ts +20 -20
  142. package/dist/Interfaces/Indexed/Product/IIndexedLastSavedProduct.js +2 -2
  143. package/dist/Interfaces/Indexed/Product/index.d.ts +105 -105
  144. package/dist/Interfaces/Indexed/Product/index.js +253 -253
  145. package/dist/Interfaces/Inventory/index.d.ts +19 -19
  146. package/dist/Interfaces/Inventory/index.js +8 -8
  147. package/dist/Interfaces/Invoice/index.d.ts +4 -4
  148. package/dist/Interfaces/Invoice/index.js +2 -2
  149. package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.d.ts +3 -3
  150. package/dist/Interfaces/MarketplacePublication/MarketplaceOrderData.js +2 -2
  151. package/dist/Interfaces/MarketplacePublication/index.d.ts +23 -23
  152. package/dist/Interfaces/MarketplacePublication/index.js +22 -22
  153. package/dist/Interfaces/Menu/index.d.ts +40 -40
  154. package/dist/Interfaces/Menu/index.js +16 -16
  155. package/dist/Interfaces/Note/index.d.ts +10 -10
  156. package/dist/Interfaces/Note/index.js +7 -7
  157. package/dist/Interfaces/Operations/ICreatedBy.d.ts +6 -6
  158. package/dist/Interfaces/Operations/ICreatedBy.js +2 -2
  159. package/dist/Interfaces/Operations/IUpdate.d.ts +5 -5
  160. package/dist/Interfaces/Operations/IUpdate.js +2 -2
  161. package/dist/Interfaces/Order/index.d.ts +4 -4
  162. package/dist/Interfaces/Order/index.js +2 -2
  163. package/dist/Interfaces/Org/IRelUser.d.ts +9 -9
  164. package/dist/Interfaces/Org/IRelUser.js +2 -2
  165. package/dist/Interfaces/Org/index.d.ts +29 -29
  166. package/dist/Interfaces/Org/index.js +12 -12
  167. package/dist/Interfaces/Payment/index.d.ts +26 -26
  168. package/dist/Interfaces/Payment/index.js +14 -14
  169. package/dist/Interfaces/Product/IAttributeFamily.d.ts +6 -6
  170. package/dist/Interfaces/Product/IAttributeFamily.js +2 -2
  171. package/dist/Interfaces/Product/IImportProduct.d.ts +42 -42
  172. package/dist/Interfaces/Product/IImportProduct.js +882 -882
  173. package/dist/Interfaces/Product/IInventoryItem.d.ts +74 -74
  174. package/dist/Interfaces/Product/IInventoryItem.js +38 -38
  175. package/dist/Interfaces/Product/IPricing.d.ts +177 -177
  176. package/dist/Interfaces/Product/IPricing.js +180 -180
  177. package/dist/Interfaces/Product/index.d.ts +137 -137
  178. package/dist/Interfaces/Product/index.js +64 -64
  179. package/dist/Interfaces/ProductAttribute/index.d.ts +11 -11
  180. package/dist/Interfaces/ProductAttribute/index.js +2 -2
  181. package/dist/Interfaces/PromiseToPurchase/BankType.d.ts +41 -41
  182. package/dist/Interfaces/PromiseToPurchase/BankType.js +41 -41
  183. package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.d.ts +33 -33
  184. package/dist/Interfaces/PromiseToPurchase/IIndexedBankUsed.js +15 -15
  185. package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.d.ts +19 -19
  186. package/dist/Interfaces/PromiseToPurchase/IIndexedCustomerPromiseToPurchase.js +2 -2
  187. package/dist/Interfaces/PromiseToPurchase/index.d.ts +50 -50
  188. package/dist/Interfaces/PromiseToPurchase/index.js +13 -13
  189. package/dist/Interfaces/PurchaseOrder/index.d.ts +17 -17
  190. package/dist/Interfaces/PurchaseOrder/index.js +2 -2
  191. package/dist/Interfaces/Query/IBrandQueryOptions.d.ts +11 -11
  192. package/dist/Interfaces/Query/IBrandQueryOptions.js +2 -2
  193. package/dist/Interfaces/Query/ICategoryQueryOptions.d.ts +11 -11
  194. package/dist/Interfaces/Query/ICategoryQueryOptions.js +2 -2
  195. package/dist/Interfaces/Query/IProductQueryOptions.d.ts +16 -16
  196. package/dist/Interfaces/Query/IProductQueryOptions.js +2 -2
  197. package/dist/Interfaces/Quote/index.d.ts +5 -5
  198. package/dist/Interfaces/Quote/index.js +2 -2
  199. package/dist/Interfaces/Refunds/index.d.ts +106 -106
  200. package/dist/Interfaces/Refunds/index.js +2 -2
  201. package/dist/Interfaces/Rules/IDiscountRule.d.ts +155 -155
  202. package/dist/Interfaces/Rules/IDiscountRule.js +114 -114
  203. package/dist/Interfaces/Schedule/index.d.ts +48 -48
  204. package/dist/Interfaces/Schedule/index.js +2 -2
  205. package/dist/Interfaces/Services/IAddServiceResponse.d.ts +4 -4
  206. package/dist/Interfaces/Services/IAddServiceResponse.js +2 -2
  207. package/dist/Interfaces/Services/IService.d.ts +16 -16
  208. package/dist/Interfaces/Services/IService.js +2 -2
  209. package/dist/Interfaces/Services/IServiceSecret.d.ts +8 -8
  210. package/dist/Interfaces/Services/IServiceSecret.js +2 -2
  211. package/dist/Interfaces/Shipping/Shipstation/carriers.d.ts +10 -10
  212. package/dist/Interfaces/Shipping/Shipstation/carriers.js +2 -2
  213. package/dist/Interfaces/Shipping/Shipstation/order.d.ts +227 -227
  214. package/dist/Interfaces/Shipping/Shipstation/order.js +2 -2
  215. package/dist/Interfaces/Shipping/Shipstation/quote.d.ts +31 -31
  216. package/dist/Interfaces/Shipping/Shipstation/quote.js +2 -2
  217. package/dist/Interfaces/Shipping/Shiptime/order.d.ts +54 -54
  218. package/dist/Interfaces/Shipping/Shiptime/order.js +71 -71
  219. package/dist/Interfaces/Shipping/Shiptime/quote.d.ts +111 -111
  220. package/dist/Interfaces/Shipping/Shiptime/quote.js +2 -2
  221. package/dist/Interfaces/Slider/GR.d.ts +114 -114
  222. package/dist/Interfaces/Slider/GR.js +271 -271
  223. package/dist/Interfaces/Slider/index.d.ts +30 -30
  224. package/dist/Interfaces/Slider/index.js +2 -2
  225. package/dist/Interfaces/Space/IExternalService.d.ts +54 -54
  226. package/dist/Interfaces/Space/IExternalService.js +45 -45
  227. package/dist/Interfaces/Space/IMember.d.ts +16 -16
  228. package/dist/Interfaces/Space/IMember.js +9 -9
  229. package/dist/Interfaces/Space/index.d.ts +414 -413
  230. package/dist/Interfaces/Space/index.js +176 -175
  231. package/dist/Interfaces/Space/index.js.map +1 -1
  232. package/dist/Interfaces/Specials/gr.d.ts +61 -61
  233. package/dist/Interfaces/Specials/gr.js +2 -2
  234. package/dist/Interfaces/StockNotification/index.d.ts +7 -7
  235. package/dist/Interfaces/StockNotification/index.js +2 -2
  236. package/dist/Interfaces/Store/index.d.ts +63 -63
  237. package/dist/Interfaces/Store/index.js +27 -27
  238. package/dist/Interfaces/Supplier/ICommand.d.ts +11 -11
  239. package/dist/Interfaces/Supplier/ICommand.js +2 -2
  240. package/dist/Interfaces/Supplier/index.d.ts +36 -36
  241. package/dist/Interfaces/Supplier/index.js +24 -24
  242. package/dist/Interfaces/TCG/index.d.ts +194 -194
  243. package/dist/Interfaces/TCG/index.js +60 -60
  244. package/dist/Interfaces/Tag/index.d.ts +18 -18
  245. package/dist/Interfaces/Tag/index.js +2 -2
  246. package/dist/Interfaces/Tax/index.d.ts +13 -13
  247. package/dist/Interfaces/Tax/index.js +2 -2
  248. package/dist/Interfaces/TransferRequest/index.d.ts +103 -103
  249. package/dist/Interfaces/TransferRequest/index.js +46 -46
  250. package/dist/Interfaces/Translation/index.d.ts +8 -8
  251. package/dist/Interfaces/Translation/index.js +5 -5
  252. package/dist/Interfaces/Update/index.d.ts +10 -10
  253. package/dist/Interfaces/Update/index.js +2 -2
  254. package/dist/Interfaces/User/IUser.d.ts +65 -65
  255. package/dist/Interfaces/User/IUser.js +8 -8
  256. package/dist/Interfaces/Version/index.d.ts +11 -11
  257. package/dist/Interfaces/Version/index.js +2 -2
  258. package/dist/Interfaces/Wishlist/index.d.ts +7 -7
  259. package/dist/Interfaces/Wishlist/index.js +2 -2
  260. package/dist/constants/Interfaces/IBaseApi.d.ts +15 -15
  261. package/dist/constants/Interfaces/IBaseApi.js +2 -2
  262. package/dist/constants/Interfaces/IEndpointResult.d.ts +9 -9
  263. package/dist/constants/Interfaces/IEndpointResult.js +2 -2
  264. package/dist/constants/enums.d.ts +6 -6
  265. package/dist/constants/enums.js +10 -10
  266. package/dist/constants/services.d.ts +2 -2
  267. package/dist/constants/services.js +122 -122
  268. package/dist/constants/version.d.ts +2 -2
  269. package/dist/constants/version.js +5 -5
  270. package/dist/index.d.ts +50 -50
  271. package/dist/index.js +266 -266
  272. package/dist/lib/Attribute/index.d.ts +14 -14
  273. package/dist/lib/Attribute/index.js +186 -186
  274. package/dist/lib/BGJob/index.d.ts +9 -9
  275. package/dist/lib/BGJob/index.js +216 -216
  276. package/dist/lib/BackgroundWorker/index.d.ts +34 -34
  277. package/dist/lib/BackgroundWorker/index.js +59 -59
  278. package/dist/lib/Blog/BlogArticle.d.ts +5 -5
  279. package/dist/lib/Blog/BlogArticle.js +10 -10
  280. package/dist/lib/Blog/BlogAuthor.d.ts +5 -5
  281. package/dist/lib/Blog/BlogAuthor.js +10 -10
  282. package/dist/lib/Blog/BlogCategory.d.ts +5 -5
  283. package/dist/lib/Blog/BlogCategory.js +10 -10
  284. package/dist/lib/Blog/BlogKeyword.d.ts +5 -5
  285. package/dist/lib/Blog/BlogKeyword.js +10 -10
  286. package/dist/lib/Booking/index.d.ts +85 -85
  287. package/dist/lib/Booking/index.js +596 -596
  288. package/dist/lib/Brand/index.d.ts +26 -26
  289. package/dist/lib/Brand/index.js +131 -131
  290. package/dist/lib/Cart/index.d.ts +354 -354
  291. package/dist/lib/Cart/index.js +4031 -4031
  292. package/dist/lib/CartReservedQuantities/index.d.ts +49 -49
  293. package/dist/lib/CartReservedQuantities/index.js +159 -159
  294. package/dist/lib/CashDrawerShift/index.d.ts +84 -84
  295. package/dist/lib/CashDrawerShift/index.js +206 -206
  296. package/dist/lib/Catalogue/index.d.ts +15 -15
  297. package/dist/lib/Catalogue/index.js +78 -78
  298. package/dist/lib/Category/index.d.ts +34 -34
  299. package/dist/lib/Category/index.js +230 -230
  300. package/dist/lib/Class/index.d.ts +16 -16
  301. package/dist/lib/Class/index.js +66 -66
  302. package/dist/lib/Consent/index.d.ts +4 -4
  303. package/dist/lib/Consent/index.js +29 -29
  304. package/dist/lib/Customer/index.d.ts +30 -30
  305. package/dist/lib/Customer/index.js +92 -92
  306. package/dist/lib/Declination/index.d.ts +9 -9
  307. package/dist/lib/Declination/index.js +26 -26
  308. package/dist/lib/Discount/index.d.ts +27 -27
  309. package/dist/lib/Discount/index.js +493 -493
  310. package/dist/lib/ElasticSearch/index.d.ts +13 -13
  311. package/dist/lib/ElasticSearch/index.js +50 -50
  312. package/dist/lib/Elavon/index.d.ts +18 -18
  313. package/dist/lib/Elavon/index.js +135 -135
  314. package/dist/lib/Email/AbandonedCartEmail.d.ts +16 -16
  315. package/dist/lib/Email/AbandonedCartEmail.js +24 -24
  316. package/dist/lib/Email/AccountConfirmationEmail.d.ts +19 -19
  317. package/dist/lib/Email/AccountConfirmationEmail.js +30 -30
  318. package/dist/lib/Email/AdminOrderConfirmationEmail.d.ts +16 -16
  319. package/dist/lib/Email/AdminOrderConfirmationEmail.js +24 -24
  320. package/dist/lib/Email/ApplicationEmail.d.ts +16 -16
  321. package/dist/lib/Email/ApplicationEmail.js +24 -24
  322. package/dist/lib/Email/BackInStockEmail.d.ts +16 -16
  323. package/dist/lib/Email/BackInStockEmail.js +24 -24
  324. package/dist/lib/Email/ContactEmail.d.ts +16 -16
  325. package/dist/lib/Email/ContactEmail.js +24 -24
  326. package/dist/lib/Email/CustomerBookingAdminEmail.d.ts +16 -16
  327. package/dist/lib/Email/CustomerBookingAdminEmail.js +24 -24
  328. package/dist/lib/Email/CustomerBookingEmail.d.ts +16 -16
  329. package/dist/lib/Email/CustomerBookingEmail.js +24 -24
  330. package/dist/lib/Email/OrderConfirmationEmail.d.ts +16 -16
  331. package/dist/lib/Email/OrderConfirmationEmail.js +24 -24
  332. package/dist/lib/Email/OrderDenounciationEmail.d.ts +16 -16
  333. package/dist/lib/Email/OrderDenounciationEmail.js +24 -24
  334. package/dist/lib/Email/OrderSampleEmail.d.ts +16 -16
  335. package/dist/lib/Email/OrderSampleEmail.js +24 -24
  336. package/dist/lib/Email/OtherTypeEmails.d.ts +16 -16
  337. package/dist/lib/Email/OtherTypeEmails.js +27 -27
  338. package/dist/lib/Email/PasswordResetEmail.d.ts +16 -16
  339. package/dist/lib/Email/PasswordResetEmail.js +24 -24
  340. package/dist/lib/Email/PhotoShootEmail.d.ts +16 -16
  341. package/dist/lib/Email/PhotoShootEmail.js +24 -24
  342. package/dist/lib/Email/PickUpConfirmation.d.ts +16 -16
  343. package/dist/lib/Email/PickUpConfirmation.js +24 -24
  344. package/dist/lib/Email/ShippingConfirmation.d.ts +16 -16
  345. package/dist/lib/Email/ShippingConfirmation.js +24 -24
  346. package/dist/lib/Email/WelcomeEmail.d.ts +16 -16
  347. package/dist/lib/Email/WelcomeEmail.js +24 -24
  348. package/dist/lib/Email/index.d.ts +16 -16
  349. package/dist/lib/Email/index.js +31 -31
  350. package/dist/lib/ExternalService/Ebay.d.ts +74 -74
  351. package/dist/lib/ExternalService/Ebay.js +124 -124
  352. package/dist/lib/ExternalService/index.d.ts +5 -5
  353. package/dist/lib/ExternalService/index.js +10 -10
  354. package/dist/lib/FirstOrderTracking/index.d.ts +5 -5
  355. package/dist/lib/FirstOrderTracking/index.js +10 -10
  356. package/dist/lib/Indexed/IndexedCart.d.ts +13 -13
  357. package/dist/lib/Indexed/IndexedCart.js +91 -91
  358. package/dist/lib/Indexed/Product.d.ts +17 -17
  359. package/dist/lib/Indexed/Product.js +98 -98
  360. package/dist/lib/Inventory/index.d.ts +112 -112
  361. package/dist/lib/Inventory/index.js +492 -492
  362. package/dist/lib/Invoice/index.d.ts +16 -16
  363. package/dist/lib/Invoice/index.js +21 -21
  364. package/dist/lib/MarketplacePublication/index.d.ts +9 -9
  365. package/dist/lib/MarketplacePublication/index.js +426 -426
  366. package/dist/lib/Menu/index.d.ts +11 -11
  367. package/dist/lib/Menu/index.js +107 -107
  368. package/dist/lib/MongoDB/BaseAPI.d.ts +18 -18
  369. package/dist/lib/MongoDB/BaseAPI.js +200 -200
  370. package/dist/lib/Note/index.d.ts +4 -4
  371. package/dist/lib/Note/index.js +6 -6
  372. package/dist/lib/Order/index.d.ts +27 -27
  373. package/dist/lib/Order/index.js +56 -56
  374. package/dist/lib/Org/index.d.ts +68 -68
  375. package/dist/lib/Org/index.js +216 -216
  376. package/dist/lib/PandaPay/index.d.ts +16 -16
  377. package/dist/lib/PandaPay/index.js +176 -176
  378. package/dist/lib/Paysafe/index.d.ts +11 -11
  379. package/dist/lib/Paysafe/index.js +41 -41
  380. package/dist/lib/Product/index.d.ts +182 -182
  381. package/dist/lib/Product/index.js +847 -847
  382. package/dist/lib/ProductAttribute/index.d.ts +15 -15
  383. package/dist/lib/ProductAttribute/index.js +45 -45
  384. package/dist/lib/PromiseToPurchase/index.d.ts +109 -109
  385. package/dist/lib/PromiseToPurchase/index.js +343 -343
  386. package/dist/lib/PurchaseOrder/index.d.ts +20 -20
  387. package/dist/lib/PurchaseOrder/index.js +28 -28
  388. package/dist/lib/Queue/index.d.ts +40 -40
  389. package/dist/lib/Queue/index.js +254 -254
  390. package/dist/lib/Schedule/index.d.ts +5 -5
  391. package/dist/lib/Schedule/index.js +12 -12
  392. package/dist/lib/Service/Enum/ServiceEnum.d.ts +3 -3
  393. package/dist/lib/Service/Enum/ServiceEnum.js +7 -7
  394. package/dist/lib/Service/index.d.ts +13 -13
  395. package/dist/lib/Service/index.js +21 -21
  396. package/dist/lib/Shipment/index.d.ts +28 -28
  397. package/dist/lib/Shipment/index.js +370 -370
  398. package/dist/lib/Slider/index.d.ts +22 -22
  399. package/dist/lib/Slider/index.js +119 -119
  400. package/dist/lib/Space/index.d.ts +1181 -1181
  401. package/dist/lib/Space/index.js +5841 -5841
  402. package/dist/lib/StockNotification/index.d.ts +4 -4
  403. package/dist/lib/StockNotification/index.js +6 -6
  404. package/dist/lib/Store/index.d.ts +5 -5
  405. package/dist/lib/Store/index.js +12 -12
  406. package/dist/lib/Supplier/Command.d.ts +5 -5
  407. package/dist/lib/Supplier/Command.js +10 -10
  408. package/dist/lib/Supplier/index.d.ts +25 -25
  409. package/dist/lib/Supplier/index.js +27 -27
  410. package/dist/lib/Tags/index.d.ts +6 -6
  411. package/dist/lib/Tags/index.js +26 -26
  412. package/dist/lib/Tax/index.d.ts +8 -8
  413. package/dist/lib/Tax/index.js +54 -54
  414. package/dist/lib/TransferRequest/index.d.ts +290 -290
  415. package/dist/lib/TransferRequest/index.js +1026 -1026
  416. package/dist/lib/Update/index.d.ts +10 -10
  417. package/dist/lib/Update/index.js +22 -22
  418. package/dist/lib/User/index.d.ts +89 -89
  419. package/dist/lib/User/index.js +328 -328
  420. package/dist/lib/Wishlist/index.d.ts +5 -5
  421. package/dist/lib/Wishlist/index.js +10 -10
  422. package/dist/lib/base.d.ts +14 -14
  423. package/dist/lib/base.js +62 -62
  424. package/dist/lib/baseService.d.ts +17 -17
  425. package/dist/lib/baseService.js +69 -69
  426. package/dist/rules/ADD/utils/buyback.d.ts +4 -4
  427. package/dist/rules/ADD/utils/buyback.js +135 -135
  428. package/dist/rules/GR/constants/data.d.ts +26 -26
  429. package/dist/rules/GR/constants/data.js +81 -81
  430. package/dist/rules/GR/constants/expedition.d.ts +4 -4
  431. package/dist/rules/GR/constants/expedition.js +9 -9
  432. package/dist/rules/GR/constants/products.d.ts +22 -22
  433. package/dist/rules/GR/constants/products.js +263 -263
  434. package/dist/rules/GR/interfaces/cart.d.ts +84 -84
  435. package/dist/rules/GR/interfaces/cart.js +41 -41
  436. package/dist/rules/GR/interfaces/data.d.ts +101 -101
  437. package/dist/rules/GR/interfaces/data.js +114 -114
  438. package/dist/rules/GR/interfaces/products.d.ts +61 -61
  439. package/dist/rules/GR/interfaces/products.js +10 -10
  440. package/dist/rules/GR/utils/cart.d.ts +95 -95
  441. package/dist/rules/GR/utils/cart.js +839 -839
  442. package/dist/rules/GR/utils/data.d.ts +3 -3
  443. package/dist/rules/GR/utils/data.js +28 -28
  444. package/dist/rules/GR/utils/expedition.d.ts +140 -140
  445. package/dist/rules/GR/utils/expedition.js +2016 -2016
  446. package/dist/rules/GR/utils/g2.d.ts +209 -209
  447. package/dist/rules/GR/utils/g2.js +1002 -1002
  448. package/dist/rules/GR/utils/invoices.d.ts +51 -51
  449. package/dist/rules/GR/utils/invoices.js +215 -215
  450. package/dist/rules/GR/utils/products.d.ts +277 -277
  451. package/dist/rules/GR/utils/products.js +1350 -1350
  452. package/dist/rules/GR/utils/upsells.d.ts +111 -111
  453. package/dist/rules/GR/utils/upsells.js +215 -215
  454. package/dist/services/database/BaseProvider.d.ts +29 -29
  455. package/dist/services/database/BaseProvider.js +28 -28
  456. package/dist/services/database/BatchUtils.d.ts +14 -14
  457. package/dist/services/database/BatchUtils.js +43 -43
  458. package/dist/services/database/Config.d.ts +2 -2
  459. package/dist/services/database/Config.js +5 -5
  460. package/dist/services/database/DatabaseService.d.ts +125 -125
  461. package/dist/services/database/DatabaseService.js +237 -237
  462. package/dist/services/database/FirebaseProvider.d.ts +17 -17
  463. package/dist/services/database/FirebaseProvider.js +235 -235
  464. package/dist/services/database/NotFirebaseProvider.d.ts +49 -49
  465. package/dist/services/database/NotFirebaseProvider.js +262 -262
  466. package/dist/services/g2/G2OrderSlip.d.ts +49 -49
  467. package/dist/services/g2/G2OrderSlip.js +228 -228
  468. package/dist/services/g2/utils.d.ts +19 -19
  469. package/dist/services/g2/utils.js +967 -967
  470. package/dist/services/logs/index.d.ts +23 -23
  471. package/dist/services/logs/index.js +66 -66
  472. package/dist/services/marketplace/BaseMarketServiceClass.d.ts +69 -69
  473. package/dist/services/marketplace/BaseMarketServiceClass.js +133 -133
  474. package/dist/services/marketplace/CardtraderServiceClass.d.ts +33 -33
  475. package/dist/services/marketplace/CardtraderServiceClass.js +215 -215
  476. package/dist/services/marketplace/utils.d.ts +17 -17
  477. package/dist/services/marketplace/utils.js +32 -32
  478. package/dist/services/products/BaseClass.d.ts +50 -50
  479. package/dist/services/products/BaseClass.js +66 -66
  480. package/dist/services/products/TCGService.d.ts +32 -32
  481. package/dist/services/products/TCGService.js +554 -555
  482. package/dist/services/products/TCGService.js.map +1 -1
  483. package/dist/services/products/utils.d.ts +31 -31
  484. package/dist/services/products/utils.js +144 -144
  485. package/dist/utils/algolia.d.ts +46 -46
  486. package/dist/utils/algolia.js +21 -21
  487. package/dist/utils/anonymisation.d.ts +54 -54
  488. package/dist/utils/anonymisation.js +280 -280
  489. package/dist/utils/array.d.ts +5 -5
  490. package/dist/utils/array.js +14 -14
  491. package/dist/utils/aws.d.ts +36 -36
  492. package/dist/utils/aws.js +154 -154
  493. package/dist/utils/booking.d.ts +30 -30
  494. package/dist/utils/booking.js +127 -127
  495. package/dist/utils/cart.d.ts +272 -272
  496. package/dist/utils/cart.js +1169 -1169
  497. package/dist/utils/categories.d.ts +2 -2
  498. package/dist/utils/categories.js +54 -54
  499. package/dist/utils/cmv.d.ts +10 -10
  500. package/dist/utils/cmv.js +107 -107
  501. package/dist/utils/console.d.ts +6 -6
  502. package/dist/utils/console.js +59 -59
  503. package/dist/utils/context.d.ts +20 -20
  504. package/dist/utils/context.js +61 -61
  505. package/dist/utils/currency.d.ts +6 -6
  506. package/dist/utils/currency.js +91 -91
  507. package/dist/utils/data.d.ts +31 -31
  508. package/dist/utils/data.js +296 -296
  509. package/dist/utils/date.d.ts +1 -1
  510. package/dist/utils/date.js +16 -16
  511. package/dist/utils/dimensions.d.ts +3 -3
  512. package/dist/utils/dimensions.js +16 -16
  513. package/dist/utils/discount.d.ts +174 -174
  514. package/dist/utils/discount.js +1118 -1118
  515. package/dist/utils/errors.d.ts +118 -118
  516. package/dist/utils/errors.js +123 -123
  517. package/dist/utils/file-admin.d.ts +8 -8
  518. package/dist/utils/file-admin.js +39 -39
  519. package/dist/utils/file.d.ts +39 -39
  520. package/dist/utils/file.js +208 -208
  521. package/dist/utils/firebase-admin.d.ts +11 -11
  522. package/dist/utils/firebase-admin.js +73 -73
  523. package/dist/utils/firebase.d.ts +58 -58
  524. package/dist/utils/firebase.js +148 -148
  525. package/dist/utils/import.d.ts +1 -1
  526. package/dist/utils/import.js +21 -21
  527. package/dist/utils/inventories.d.ts +101 -101
  528. package/dist/utils/inventories.js +467 -467
  529. package/dist/utils/locale.d.ts +24 -24
  530. package/dist/utils/locale.js +91 -91
  531. package/dist/utils/mailchimp.d.ts +58 -58
  532. package/dist/utils/mailchimp.js +531 -531
  533. package/dist/utils/mathUtils.d.ts +17 -17
  534. package/dist/utils/mathUtils.js +324 -324
  535. package/dist/utils/mongodb.d.ts +1 -1
  536. package/dist/utils/mongodb.js +22 -22
  537. package/dist/utils/object.d.ts +32 -32
  538. package/dist/utils/object.js +133 -133
  539. package/dist/utils/payment.d.ts +10 -10
  540. package/dist/utils/payment.js +23 -23
  541. package/dist/utils/products.d.ts +39 -39
  542. package/dist/utils/products.js +195 -195
  543. package/dist/utils/promiseToPurchase.d.ts +88 -88
  544. package/dist/utils/promiseToPurchase.js +229 -229
  545. package/dist/utils/prosprsearch.d.ts +42 -42
  546. package/dist/utils/prosprsearch.js +216 -216
  547. package/dist/utils/refunds.d.ts +2 -2
  548. package/dist/utils/refunds.js +21 -21
  549. package/dist/utils/sdc.d.ts +10 -10
  550. package/dist/utils/sdc.js +1309 -1309
  551. package/dist/utils/searchIndexes.d.ts +58 -58
  552. package/dist/utils/searchIndexes.js +247 -247
  553. package/dist/utils/services.d.ts +42 -42
  554. package/dist/utils/services.js +409 -409
  555. package/dist/utils/shipment.d.ts +110 -110
  556. package/dist/utils/shipment.js +345 -345
  557. package/dist/utils/simpletexting.d.ts +2 -2
  558. package/dist/utils/simpletexting.js +45 -45
  559. package/dist/utils/sliders.d.ts +4 -4
  560. package/dist/utils/sliders.js +24 -24
  561. package/dist/utils/string.d.ts +16 -16
  562. package/dist/utils/string.js +192 -192
  563. package/dist/utils/tcgService.d.ts +88 -88
  564. package/dist/utils/tcgService.js +408 -408
  565. package/dist/utils/tools.d.ts +5 -5
  566. package/dist/utils/tools.js +13 -13
  567. package/dist/utils/transferRequests.d.ts +43 -43
  568. package/dist/utils/transferRequests.js +67 -67
  569. package/dist/utils/update.d.ts +7 -7
  570. package/dist/utils/update.js +137 -137
  571. package/dist/utils/weight.d.ts +3 -3
  572. package/dist/utils/weight.js +16 -16
  573. package/dist/utils/zones.d.ts +11 -11
  574. package/dist/utils/zones.js +218 -218
  575. package/package.json +107 -107
  576. package/publish.sh +143 -143
  577. package/readme.md +182 -182
@@ -1,329 +1,329 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- var _a;
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- const app_1 = __importDefault(require("firebase/compat/app"));
8
- const version_1 = require("../../constants/version");
9
- const console_1 = require("../../utils/console");
10
- const moment_1 = __importDefault(require("moment"));
11
- const data_1 = require("../../utils/data");
12
- const uuid_1 = require("uuid");
13
- const __1 = require("../..");
14
- const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
15
- /**
16
- * User class
17
- */
18
- class User {
19
- constructor(user, user_ref) {
20
- this.getDefaultSpaceId = () => this._user.active_space_id;
21
- this.getFullName = () => {
22
- const nameArray = [];
23
- if (!!this._user.firstname)
24
- nameArray.push(this._user.firstname);
25
- if (!!this._user.lastname)
26
- nameArray.push(this._user.lastname);
27
- return nameArray.join(' ');
28
- };
29
- this.getEmail = () => this._user.email;
30
- this.data = () => this._user;
31
- this.save = async (partial) => {
32
- try {
33
- this._user = Object.assign(Object.assign({}, this._user), partial);
34
- //await this._user_ref.set(!!partial ? partial : {}, { merge: true })
35
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, !!partial ? partial : {}, {
36
- merge: true
37
- });
38
- return true;
39
- }
40
- catch (err) {
41
- console.log(err);
42
- return false;
43
- }
44
- };
45
- this.setFavoriteWarehouse = async (warehouse_id) => {
46
- try {
47
- //await this._user_ref.set({ favorite_warehouse_id: warehouse_id }, { merge: true })
48
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { favorite_warehouse_id: warehouse_id }, { merge: true });
49
- this._user = Object.assign(Object.assign({}, this._user), { favorite_warehouse_id: warehouse_id });
50
- return true;
51
- }
52
- catch (error) {
53
- throw `Error while setting favorite warehouse ${warehouse_id}: ${error}`;
54
- }
55
- };
56
- this.setDefaultSpaceId = async (active_space_id) => {
57
- try {
58
- //await this._user_ref.set({ active_space_id }, { merge: true })
59
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { active_space_id }, { merge: true });
60
- this._user = Object.assign(Object.assign({}, this._user), { active_space_id });
61
- return true;
62
- }
63
- catch (error) {
64
- throw `Error while setting default space ${active_space_id}: ${error}`;
65
- }
66
- };
67
- /**
68
- * Sets new nip value for given user.
69
- *
70
- * @param newNip
71
- * @param tempNipToken
72
- * Used in case of "forgot nip". Corresponds to the token sent by email to the user when they asked for a Nip reset.
73
- * If not provided and nip is defined for user, throws error.
74
- * @returns boolean (if successful)
75
- */
76
- this._setNip = async (newNip, token) => {
77
- try {
78
- // If nip exists in user, check token
79
- if (!!this._user.nip) {
80
- if (!!!token) {
81
- throw 'no token';
82
- }
83
- else {
84
- try {
85
- await app_1.default.auth().signInWithEmailAndPassword(this.data().email, token);
86
- }
87
- catch (e) {
88
- throw 'bad token';
89
- }
90
- }
91
- }
92
- // Set new nip and set last_nip_check to null
93
- //await this._user_ref.set({ nip: newNip, last_nip_check: null }, { merge: true })
94
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { nip: newNip, last_nip_check: null }, { merge: true });
95
- this._user = Object.assign(Object.assign({}, this._user), { nip: newNip, last_nip_check: null });
96
- return true;
97
- }
98
- catch (e) {
99
- throw e.toString();
100
- }
101
- };
102
- /**
103
- * Checks if nip provided is same as nip found in user.
104
- *
105
- * If user has no nip registered in database, throws an error (should call {@link this._setNip} instead)
106
- * If check successful and value returnOnly is false/undefined, saves new value for last_nip_checked.
107
- *
108
- * @param valueToCheck
109
- * @param returnOnly
110
- * @returns a promise withe the last nip check for the user
111
- */
112
- this._checkNip = async (valueToCheck, returnOnly) => {
113
- if (!!!this._user.nip)
114
- throw 'user has no nip';
115
- try {
116
- const isSame = valueToCheck === this._user.nip;
117
- if (!!!isSame)
118
- throw 'nip is different';
119
- const newToken = (0, uuid_1.v4)();
120
- const newLastCheck = { date: (0, moment_1.default)().toDate(), token: newToken };
121
- if (!!!returnOnly) {
122
- //await this._user_ref.set({ last_nip_check: newLastCheck }, { merge: true })
123
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: newLastCheck }, { merge: true });
124
- this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: newLastCheck });
125
- }
126
- return newLastCheck;
127
- }
128
- catch (e) {
129
- throw `Error while checking nip : ${e}`;
130
- }
131
- };
132
- this._checkToken = (valueToCheck) => {
133
- const currentToken = this._user.last_nip_check;
134
- if (!!!currentToken || !!!currentToken.token)
135
- return false;
136
- return valueToCheck === currentToken.token;
137
- };
138
- /**
139
- * Removes property last_nip_check from User
140
- * @returns boolean
141
- */
142
- this._removeLastChecked = async () => {
143
- try {
144
- //await this._user_ref.set({ last_nip_check: null }, { merge: true })
145
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: null }, { merge: true });
146
- this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: null });
147
- return true;
148
- }
149
- catch (e) {
150
- throw `Error while removing last checked : ${e}`;
151
- }
152
- };
153
- this._setLastNipCheck = async () => {
154
- if (!!!this._user.nip) {
155
- throw 'user has no nip';
156
- }
157
- try {
158
- const newToken = (0, uuid_1.v4)();
159
- const newLastCheck = { date: (0, moment_1.default)().toDate(), token: newToken };
160
- //await this._user_ref.set({ last_nip_check: newLastCheck }, { merge: true })
161
- await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: newLastCheck }, { merge: true });
162
- this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: newLastCheck });
163
- return newLastCheck;
164
- }
165
- catch (e) {
166
- throw `Error while setting last nip check : ${e}`;
167
- }
168
- };
169
- this.nip = {
170
- set: this._setNip,
171
- check: this._checkNip,
172
- checkToken: this._checkToken,
173
- removeLastChecked: this._removeLastChecked,
174
- setLastNipCheck: this._setLastNipCheck
175
- };
176
- this._user = user;
177
- this._user_ref = user_ref;
178
- }
179
- async disable() {
180
- await this.save({ disabled: true, active_space_id: '' });
181
- return this;
182
- }
183
- async enable(spaceID) {
184
- await this.save({ disabled: false, active_space_id: spaceID });
185
- return this;
186
- }
187
- async reinitPassword() {
188
- try {
189
- //const auth = this._user_ref.firestore.app.auth()
190
- const auth = app_1.default.auth();
191
- return await auth.sendPasswordResetEmail(this.data().email);
192
- }
193
- catch (error) {
194
- (0, console_1.errorMessage)(`error while reinit password of user: ${JSON.stringify(error)}`);
195
- throw error;
196
- }
197
- }
198
- }
199
- exports.default = User;
200
- _a = User;
201
- /**
202
- * Fetch user from database for current org
203
- * @param options - Parameters for database query. Only one will be checked at a time, in order of "importance" : email > username > external_id.
204
- * @param version - The app version to check
205
- * @param orgID - Optionnal, but must be provided if function is called from the backend (used to find user's organization).
206
- */
207
- User.FetchUser = async (options, version = version_1.currentVersion, orgID) => {
208
- var _b, _c;
209
- try {
210
- const f = app_1.default.app();
211
- if (!!!f) {
212
- (0, console_1.errorMessage)(`Can't acess database`);
213
- throw `Can't acess database`;
214
- }
215
- let organization_id = localStorage.getItem('organization_id');
216
- if (!!!organization_id && !!orgID)
217
- organization_id = orgID;
218
- if (!!__1.isTestEnv)
219
- console.log('orgID: ', orgID);
220
- (0, console_1.workingMessage)(`Org: ${organization_id}`);
221
- const userEmailToCheck = options.email;
222
- if (!!!organization_id && !!userEmailToCheck) {
223
- (0, console_1.workingMessage)(`No org found, looking for a UBO`);
224
- const foundUserOrgRelation = await User._getOrgRelationForUserEmail(userEmailToCheck);
225
- organization_id = foundUserOrgRelation;
226
- if (!!!organization_id) {
227
- (0, console_1.errorMessage)(`Can't acess organization. Please logout and try to login back`);
228
- throw `Can't acess organization. Please logout and try to login back`;
229
- }
230
- else {
231
- (0, console_1.workingMessage)(`We found the matching UBO: ${foundUserOrgRelation}`);
232
- }
233
- }
234
- const whereKey = !!options.email ? 'email' : !!options.external_id ? 'external_id' : 'username';
235
- const whereValue = (_c = (_b = options.email) !== null && _b !== void 0 ? _b : options.external_id) !== null && _c !== void 0 ? _c : options.username;
236
- (0, console_1.workingMessage)(`Fetching user with ${whereKey}: ${whereValue}`);
237
- if (!!!whereValue)
238
- throw `No valid value was provided for query.`;
239
- const usersRequest = await DatabaseService_1.default.getDocuments(`/the_beast/${version}/orgs/${organization_id}/users`, {
240
- query: [{ field: whereKey, operator: '==', value: whereValue }]
241
- });
242
- (0, console_1.workingMessage)(`Request SIZE: ${usersRequest.length}`);
243
- if (usersRequest.length == 0) {
244
- (0, console_1.errorMessage)(`Can't retrieve user with ${whereKey} ${whereValue} in database.`);
245
- if (!!organization_id) {
246
- (0, console_1.workingMessage)(`Clearing organization ID from local storage`);
247
- localStorage.removeItem('organization_id');
248
- (0, console_1.successMessage)(`Organization ID cleared!`);
249
- return await _a.FetchUser(options, version);
250
- }
251
- throw `Can't retrieve user with ${whereKey} ${whereValue} in database`;
252
- }
253
- // Make sure user was indeed returned by query (firebase can return multiple values if provided field can be undefined)
254
- const sameUser = usersRequest.find((d) => d.data[whereKey] === whereValue);
255
- if (!!!sameUser)
256
- throw `Correct user was not returned by query result.`;
257
- const userData = Object.assign({ id: sameUser.id }, sameUser.data);
258
- if (!!!userData) {
259
- (0, console_1.errorMessage)(`User has no data.`);
260
- throw `User has no data.`;
261
- }
262
- (0, console_1.successMessage)(`User found to be returned`);
263
- return userData;
264
- }
265
- catch (error) {
266
- throw `Error while processing: ${error}`;
267
- }
268
- };
269
- /**
270
- * Get org ID for a specified user email.
271
- * @param userEmail
272
- * @throws If relation could not be found for provided email
273
- * @returns Promise<string>
274
- */
275
- User._getOrgRelationForUserEmail = async (userEmail) => {
276
- const orgs = await DatabaseService_1.default.getDocumentByPath('/the_beast/rel_orgs_users');
277
- if (!!!orgs.exists)
278
- throw `Can't find organizations.`;
279
- const orgsData = orgs.data;
280
- if (!!!orgsData)
281
- throw `Can't access organizations relations.`;
282
- if (!!!orgsData.users_by_orgs)
283
- throw `Can't access organizations relations.`;
284
- const usersByOrgs = orgsData.users_by_orgs;
285
- if (usersByOrgs.length === 0)
286
- throw `There are no organizations yet.`;
287
- const matchingUBO = usersByOrgs.find((ubo) => ubo.users.find((u) => !!u.email && u.email === userEmail) || false);
288
- if (!!!matchingUBO)
289
- throw `Can't find associative organization to user ${userEmail}`;
290
- let orgId_ = '';
291
- if (typeof matchingUBO.org == 'string')
292
- orgId_ = matchingUBO.org.split('/').pop();
293
- else
294
- orgId_ = matchingUBO.org.id;
295
- return orgId_;
296
- };
297
- /**
298
- * Check if a given user email corresponds to a given org ID.
299
- * @param userEmail
300
- * @param orgId
301
- * @returns Promise<boolean>
302
- */
303
- User.checkIfUserExistsForOrg = async (userEmail, orgId) => {
304
- try {
305
- const foundUserOrgRelation = await User._getOrgRelationForUserEmail(userEmail);
306
- return orgId == foundUserOrgRelation;
307
- }
308
- catch (e) {
309
- console.log('Error on checking existing user in org: ', e.toString());
310
- return false;
311
- }
312
- };
313
- /**
314
- * Checks if last_nip_check.date is expired (more than lockTimeoutMinutes, default 30 minutes)
315
- * If lockTimeoutMinutes is null, the token never expires (no automatic lock)
316
- *
317
- * @param valueToCheck IUser['last_nip_check']
318
- * @param lockTimeoutMinutes Délai en minutes avant expiration (par défaut 30 minutes, null = aucun verrouillage)
319
- * @returns boolean
320
- */
321
- User.checkIfNipTokenHasExpired = (valueToCheck, lockTimeoutMinutes = 30) => {
322
- if (!!!valueToCheck || !!!valueToCheck.date)
323
- return true;
324
- // Si lockTimeoutMinutes est null, le token n'expire jamais (pas de verrouillage automatique)
325
- if (lockTimeoutMinutes === null)
326
- return false;
327
- return (0, moment_1.default)().isAfter((0, moment_1.default)((0, data_1.formatDate)(valueToCheck.date)).add(lockTimeoutMinutes, 'minutes'));
328
- };
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ var _a;
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ const app_1 = __importDefault(require("firebase/compat/app"));
8
+ const version_1 = require("../../constants/version");
9
+ const console_1 = require("../../utils/console");
10
+ const moment_1 = __importDefault(require("moment"));
11
+ const data_1 = require("../../utils/data");
12
+ const uuid_1 = require("uuid");
13
+ const __1 = require("../..");
14
+ const DatabaseService_1 = __importDefault(require("../../services/database/DatabaseService"));
15
+ /**
16
+ * User class
17
+ */
18
+ class User {
19
+ constructor(user, user_ref) {
20
+ this.getDefaultSpaceId = () => this._user.active_space_id;
21
+ this.getFullName = () => {
22
+ const nameArray = [];
23
+ if (!!this._user.firstname)
24
+ nameArray.push(this._user.firstname);
25
+ if (!!this._user.lastname)
26
+ nameArray.push(this._user.lastname);
27
+ return nameArray.join(' ');
28
+ };
29
+ this.getEmail = () => this._user.email;
30
+ this.data = () => this._user;
31
+ this.save = async (partial) => {
32
+ try {
33
+ this._user = Object.assign(Object.assign({}, this._user), partial);
34
+ //await this._user_ref.set(!!partial ? partial : {}, { merge: true })
35
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, !!partial ? partial : {}, {
36
+ merge: true
37
+ });
38
+ return true;
39
+ }
40
+ catch (err) {
41
+ console.log(err);
42
+ return false;
43
+ }
44
+ };
45
+ this.setFavoriteWarehouse = async (warehouse_id) => {
46
+ try {
47
+ //await this._user_ref.set({ favorite_warehouse_id: warehouse_id }, { merge: true })
48
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { favorite_warehouse_id: warehouse_id }, { merge: true });
49
+ this._user = Object.assign(Object.assign({}, this._user), { favorite_warehouse_id: warehouse_id });
50
+ return true;
51
+ }
52
+ catch (error) {
53
+ throw `Error while setting favorite warehouse ${warehouse_id}: ${error}`;
54
+ }
55
+ };
56
+ this.setDefaultSpaceId = async (active_space_id) => {
57
+ try {
58
+ //await this._user_ref.set({ active_space_id }, { merge: true })
59
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { active_space_id }, { merge: true });
60
+ this._user = Object.assign(Object.assign({}, this._user), { active_space_id });
61
+ return true;
62
+ }
63
+ catch (error) {
64
+ throw `Error while setting default space ${active_space_id}: ${error}`;
65
+ }
66
+ };
67
+ /**
68
+ * Sets new nip value for given user.
69
+ *
70
+ * @param newNip
71
+ * @param tempNipToken
72
+ * Used in case of "forgot nip". Corresponds to the token sent by email to the user when they asked for a Nip reset.
73
+ * If not provided and nip is defined for user, throws error.
74
+ * @returns boolean (if successful)
75
+ */
76
+ this._setNip = async (newNip, token) => {
77
+ try {
78
+ // If nip exists in user, check token
79
+ if (!!this._user.nip) {
80
+ if (!!!token) {
81
+ throw 'no token';
82
+ }
83
+ else {
84
+ try {
85
+ await app_1.default.auth().signInWithEmailAndPassword(this.data().email, token);
86
+ }
87
+ catch (e) {
88
+ throw 'bad token';
89
+ }
90
+ }
91
+ }
92
+ // Set new nip and set last_nip_check to null
93
+ //await this._user_ref.set({ nip: newNip, last_nip_check: null }, { merge: true })
94
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { nip: newNip, last_nip_check: null }, { merge: true });
95
+ this._user = Object.assign(Object.assign({}, this._user), { nip: newNip, last_nip_check: null });
96
+ return true;
97
+ }
98
+ catch (e) {
99
+ throw e.toString();
100
+ }
101
+ };
102
+ /**
103
+ * Checks if nip provided is same as nip found in user.
104
+ *
105
+ * If user has no nip registered in database, throws an error (should call {@link this._setNip} instead)
106
+ * If check successful and value returnOnly is false/undefined, saves new value for last_nip_checked.
107
+ *
108
+ * @param valueToCheck
109
+ * @param returnOnly
110
+ * @returns a promise withe the last nip check for the user
111
+ */
112
+ this._checkNip = async (valueToCheck, returnOnly) => {
113
+ if (!!!this._user.nip)
114
+ throw 'user has no nip';
115
+ try {
116
+ const isSame = valueToCheck === this._user.nip;
117
+ if (!!!isSame)
118
+ throw 'nip is different';
119
+ const newToken = (0, uuid_1.v4)();
120
+ const newLastCheck = { date: (0, moment_1.default)().toDate(), token: newToken };
121
+ if (!!!returnOnly) {
122
+ //await this._user_ref.set({ last_nip_check: newLastCheck }, { merge: true })
123
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: newLastCheck }, { merge: true });
124
+ this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: newLastCheck });
125
+ }
126
+ return newLastCheck;
127
+ }
128
+ catch (e) {
129
+ throw `Error while checking nip : ${e}`;
130
+ }
131
+ };
132
+ this._checkToken = (valueToCheck) => {
133
+ const currentToken = this._user.last_nip_check;
134
+ if (!!!currentToken || !!!currentToken.token)
135
+ return false;
136
+ return valueToCheck === currentToken.token;
137
+ };
138
+ /**
139
+ * Removes property last_nip_check from User
140
+ * @returns boolean
141
+ */
142
+ this._removeLastChecked = async () => {
143
+ try {
144
+ //await this._user_ref.set({ last_nip_check: null }, { merge: true })
145
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: null }, { merge: true });
146
+ this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: null });
147
+ return true;
148
+ }
149
+ catch (e) {
150
+ throw `Error while removing last checked : ${e}`;
151
+ }
152
+ };
153
+ this._setLastNipCheck = async () => {
154
+ if (!!!this._user.nip) {
155
+ throw 'user has no nip';
156
+ }
157
+ try {
158
+ const newToken = (0, uuid_1.v4)();
159
+ const newLastCheck = { date: (0, moment_1.default)().toDate(), token: newToken };
160
+ //await this._user_ref.set({ last_nip_check: newLastCheck }, { merge: true })
161
+ await DatabaseService_1.default.saveDocument(this._user_ref.path, this._user_ref.id, 0, { last_nip_check: newLastCheck }, { merge: true });
162
+ this._user = Object.assign(Object.assign({}, this._user), { last_nip_check: newLastCheck });
163
+ return newLastCheck;
164
+ }
165
+ catch (e) {
166
+ throw `Error while setting last nip check : ${e}`;
167
+ }
168
+ };
169
+ this.nip = {
170
+ set: this._setNip,
171
+ check: this._checkNip,
172
+ checkToken: this._checkToken,
173
+ removeLastChecked: this._removeLastChecked,
174
+ setLastNipCheck: this._setLastNipCheck
175
+ };
176
+ this._user = user;
177
+ this._user_ref = user_ref;
178
+ }
179
+ async disable() {
180
+ await this.save({ disabled: true, active_space_id: '' });
181
+ return this;
182
+ }
183
+ async enable(spaceID) {
184
+ await this.save({ disabled: false, active_space_id: spaceID });
185
+ return this;
186
+ }
187
+ async reinitPassword() {
188
+ try {
189
+ //const auth = this._user_ref.firestore.app.auth()
190
+ const auth = app_1.default.auth();
191
+ return await auth.sendPasswordResetEmail(this.data().email);
192
+ }
193
+ catch (error) {
194
+ (0, console_1.errorMessage)(`error while reinit password of user: ${JSON.stringify(error)}`);
195
+ throw error;
196
+ }
197
+ }
198
+ }
199
+ exports.default = User;
200
+ _a = User;
201
+ /**
202
+ * Fetch user from database for current org
203
+ * @param options - Parameters for database query. Only one will be checked at a time, in order of "importance" : email > username > external_id.
204
+ * @param version - The app version to check
205
+ * @param orgID - Optionnal, but must be provided if function is called from the backend (used to find user's organization).
206
+ */
207
+ User.FetchUser = async (options, version = version_1.currentVersion, orgID) => {
208
+ var _b, _c;
209
+ try {
210
+ const f = app_1.default.app();
211
+ if (!!!f) {
212
+ (0, console_1.errorMessage)(`Can't acess database`);
213
+ throw `Can't acess database`;
214
+ }
215
+ let organization_id = localStorage.getItem('organization_id');
216
+ if (!!!organization_id && !!orgID)
217
+ organization_id = orgID;
218
+ if (!!__1.isTestEnv)
219
+ console.log('orgID: ', orgID);
220
+ (0, console_1.workingMessage)(`Org: ${organization_id}`);
221
+ const userEmailToCheck = options.email;
222
+ if (!!!organization_id && !!userEmailToCheck) {
223
+ (0, console_1.workingMessage)(`No org found, looking for a UBO`);
224
+ const foundUserOrgRelation = await User._getOrgRelationForUserEmail(userEmailToCheck);
225
+ organization_id = foundUserOrgRelation;
226
+ if (!!!organization_id) {
227
+ (0, console_1.errorMessage)(`Can't acess organization. Please logout and try to login back`);
228
+ throw `Can't acess organization. Please logout and try to login back`;
229
+ }
230
+ else {
231
+ (0, console_1.workingMessage)(`We found the matching UBO: ${foundUserOrgRelation}`);
232
+ }
233
+ }
234
+ const whereKey = !!options.email ? 'email' : !!options.external_id ? 'external_id' : 'username';
235
+ const whereValue = (_c = (_b = options.email) !== null && _b !== void 0 ? _b : options.external_id) !== null && _c !== void 0 ? _c : options.username;
236
+ (0, console_1.workingMessage)(`Fetching user with ${whereKey}: ${whereValue}`);
237
+ if (!!!whereValue)
238
+ throw `No valid value was provided for query.`;
239
+ const usersRequest = await DatabaseService_1.default.getDocuments(`/the_beast/${version}/orgs/${organization_id}/users`, {
240
+ query: [{ field: whereKey, operator: '==', value: whereValue }]
241
+ });
242
+ (0, console_1.workingMessage)(`Request SIZE: ${usersRequest.length}`);
243
+ if (usersRequest.length == 0) {
244
+ (0, console_1.errorMessage)(`Can't retrieve user with ${whereKey} ${whereValue} in database.`);
245
+ if (!!organization_id) {
246
+ (0, console_1.workingMessage)(`Clearing organization ID from local storage`);
247
+ localStorage.removeItem('organization_id');
248
+ (0, console_1.successMessage)(`Organization ID cleared!`);
249
+ return await _a.FetchUser(options, version);
250
+ }
251
+ throw `Can't retrieve user with ${whereKey} ${whereValue} in database`;
252
+ }
253
+ // Make sure user was indeed returned by query (firebase can return multiple values if provided field can be undefined)
254
+ const sameUser = usersRequest.find((d) => d.data[whereKey] === whereValue);
255
+ if (!!!sameUser)
256
+ throw `Correct user was not returned by query result.`;
257
+ const userData = Object.assign({ id: sameUser.id }, sameUser.data);
258
+ if (!!!userData) {
259
+ (0, console_1.errorMessage)(`User has no data.`);
260
+ throw `User has no data.`;
261
+ }
262
+ (0, console_1.successMessage)(`User found to be returned`);
263
+ return userData;
264
+ }
265
+ catch (error) {
266
+ throw `Error while processing: ${error}`;
267
+ }
268
+ };
269
+ /**
270
+ * Get org ID for a specified user email.
271
+ * @param userEmail
272
+ * @throws If relation could not be found for provided email
273
+ * @returns Promise<string>
274
+ */
275
+ User._getOrgRelationForUserEmail = async (userEmail) => {
276
+ const orgs = await DatabaseService_1.default.getDocumentByPath('/the_beast/rel_orgs_users');
277
+ if (!!!orgs.exists)
278
+ throw `Can't find organizations.`;
279
+ const orgsData = orgs.data;
280
+ if (!!!orgsData)
281
+ throw `Can't access organizations relations.`;
282
+ if (!!!orgsData.users_by_orgs)
283
+ throw `Can't access organizations relations.`;
284
+ const usersByOrgs = orgsData.users_by_orgs;
285
+ if (usersByOrgs.length === 0)
286
+ throw `There are no organizations yet.`;
287
+ const matchingUBO = usersByOrgs.find((ubo) => ubo.users.find((u) => !!u.email && u.email === userEmail) || false);
288
+ if (!!!matchingUBO)
289
+ throw `Can't find associative organization to user ${userEmail}`;
290
+ let orgId_ = '';
291
+ if (typeof matchingUBO.org == 'string')
292
+ orgId_ = matchingUBO.org.split('/').pop();
293
+ else
294
+ orgId_ = matchingUBO.org.id;
295
+ return orgId_;
296
+ };
297
+ /**
298
+ * Check if a given user email corresponds to a given org ID.
299
+ * @param userEmail
300
+ * @param orgId
301
+ * @returns Promise<boolean>
302
+ */
303
+ User.checkIfUserExistsForOrg = async (userEmail, orgId) => {
304
+ try {
305
+ const foundUserOrgRelation = await User._getOrgRelationForUserEmail(userEmail);
306
+ return orgId == foundUserOrgRelation;
307
+ }
308
+ catch (e) {
309
+ console.log('Error on checking existing user in org: ', e.toString());
310
+ return false;
311
+ }
312
+ };
313
+ /**
314
+ * Checks if last_nip_check.date is expired (more than lockTimeoutMinutes, default 30 minutes)
315
+ * If lockTimeoutMinutes is null, the token never expires (no automatic lock)
316
+ *
317
+ * @param valueToCheck IUser['last_nip_check']
318
+ * @param lockTimeoutMinutes Délai en minutes avant expiration (par défaut 30 minutes, null = aucun verrouillage)
319
+ * @returns boolean
320
+ */
321
+ User.checkIfNipTokenHasExpired = (valueToCheck, lockTimeoutMinutes = 30) => {
322
+ if (!!!valueToCheck || !!!valueToCheck.date)
323
+ return true;
324
+ // Si lockTimeoutMinutes est null, le token n'expire jamais (pas de verrouillage automatique)
325
+ if (lockTimeoutMinutes === null)
326
+ return false;
327
+ return (0, moment_1.default)().isAfter((0, moment_1.default)((0, data_1.formatDate)(valueToCheck.date)).add(lockTimeoutMinutes, 'minutes'));
328
+ };
329
329
  //# sourceMappingURL=index.js.map