@stamhoofd/models 2.1.1

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 (481) hide show
  1. package/dist/src/assets/Metropolis-Black.woff2 +0 -0
  2. package/dist/src/assets/Metropolis-BlackItalic.woff2 +0 -0
  3. package/dist/src/assets/Metropolis-Bold.woff2 +0 -0
  4. package/dist/src/assets/Metropolis-BoldItalic.woff2 +0 -0
  5. package/dist/src/assets/Metropolis-ExtraBold.woff2 +0 -0
  6. package/dist/src/assets/Metropolis-ExtraBoldItalic.woff2 +0 -0
  7. package/dist/src/assets/Metropolis-ExtraLight.woff2 +0 -0
  8. package/dist/src/assets/Metropolis-ExtraLightItalic.woff2 +0 -0
  9. package/dist/src/assets/Metropolis-Light.woff2 +0 -0
  10. package/dist/src/assets/Metropolis-LightItalic.woff2 +0 -0
  11. package/dist/src/assets/Metropolis-Medium.woff2 +0 -0
  12. package/dist/src/assets/Metropolis-MediumItalic.woff2 +0 -0
  13. package/dist/src/assets/Metropolis-Regular.woff2 +0 -0
  14. package/dist/src/assets/Metropolis-RegularItalic.woff2 +0 -0
  15. package/dist/src/assets/Metropolis-SemiBold.woff2 +0 -0
  16. package/dist/src/assets/Metropolis-SemiBoldItalic.woff2 +0 -0
  17. package/dist/src/assets/Metropolis-Thin.woff2 +0 -0
  18. package/dist/src/assets/Metropolis-ThinItalic.woff2 +0 -0
  19. package/dist/src/assets/assets/Metropolis-Black.woff2 +0 -0
  20. package/dist/src/assets/assets/Metropolis-BlackItalic.woff2 +0 -0
  21. package/dist/src/assets/assets/Metropolis-Bold.woff2 +0 -0
  22. package/dist/src/assets/assets/Metropolis-BoldItalic.woff2 +0 -0
  23. package/dist/src/assets/assets/Metropolis-ExtraBold.woff2 +0 -0
  24. package/dist/src/assets/assets/Metropolis-ExtraBoldItalic.woff2 +0 -0
  25. package/dist/src/assets/assets/Metropolis-ExtraLight.woff2 +0 -0
  26. package/dist/src/assets/assets/Metropolis-ExtraLightItalic.woff2 +0 -0
  27. package/dist/src/assets/assets/Metropolis-Light.woff2 +0 -0
  28. package/dist/src/assets/assets/Metropolis-LightItalic.woff2 +0 -0
  29. package/dist/src/assets/assets/Metropolis-Medium.woff2 +0 -0
  30. package/dist/src/assets/assets/Metropolis-MediumItalic.woff2 +0 -0
  31. package/dist/src/assets/assets/Metropolis-Regular.woff2 +0 -0
  32. package/dist/src/assets/assets/Metropolis-RegularItalic.woff2 +0 -0
  33. package/dist/src/assets/assets/Metropolis-SemiBold.woff2 +0 -0
  34. package/dist/src/assets/assets/Metropolis-SemiBoldItalic.woff2 +0 -0
  35. package/dist/src/assets/assets/Metropolis-Thin.woff2 +0 -0
  36. package/dist/src/assets/assets/Metropolis-ThinItalic.woff2 +0 -0
  37. package/dist/src/assets/assets/logo.png +0 -0
  38. package/dist/src/assets/logo.png +0 -0
  39. package/dist/src/factories/AddressFactory.d.ts +10 -0
  40. package/dist/src/factories/AddressFactory.d.ts.map +1 -0
  41. package/dist/src/factories/AddressFactory.js +42 -0
  42. package/dist/src/factories/AddressFactory.js.map +1 -0
  43. package/dist/src/factories/EmergencyContactFactory.d.ts +9 -0
  44. package/dist/src/factories/EmergencyContactFactory.d.ts.map +1 -0
  45. package/dist/src/factories/EmergencyContactFactory.js +42 -0
  46. package/dist/src/factories/EmergencyContactFactory.js.map +1 -0
  47. package/dist/src/factories/GroupFactory.d.ts +19 -0
  48. package/dist/src/factories/GroupFactory.d.ts.map +1 -0
  49. package/dist/src/factories/GroupFactory.js +52 -0
  50. package/dist/src/factories/GroupFactory.js.map +1 -0
  51. package/dist/src/factories/MemberFactory.d.ts +16 -0
  52. package/dist/src/factories/MemberFactory.d.ts.map +1 -0
  53. package/dist/src/factories/MemberFactory.js +98 -0
  54. package/dist/src/factories/MemberFactory.js.map +1 -0
  55. package/dist/src/factories/OrganizationFactory.d.ts +16 -0
  56. package/dist/src/factories/OrganizationFactory.d.ts.map +1 -0
  57. package/dist/src/factories/OrganizationFactory.js +40 -0
  58. package/dist/src/factories/OrganizationFactory.js.map +1 -0
  59. package/dist/src/factories/ParentFactory.d.ts +10 -0
  60. package/dist/src/factories/ParentFactory.d.ts.map +1 -0
  61. package/dist/src/factories/ParentFactory.js +44 -0
  62. package/dist/src/factories/ParentFactory.js.map +1 -0
  63. package/dist/src/factories/RecordFactory.d.ts +10 -0
  64. package/dist/src/factories/RecordFactory.d.ts.map +1 -0
  65. package/dist/src/factories/RecordFactory.js +14 -0
  66. package/dist/src/factories/RecordFactory.js.map +1 -0
  67. package/dist/src/factories/RegisterCodeFactory.d.ts +18 -0
  68. package/dist/src/factories/RegisterCodeFactory.d.ts.map +1 -0
  69. package/dist/src/factories/RegisterCodeFactory.js +19 -0
  70. package/dist/src/factories/RegisterCodeFactory.js.map +1 -0
  71. package/dist/src/factories/RegistrationFactory.d.ts +14 -0
  72. package/dist/src/factories/RegistrationFactory.d.ts.map +1 -0
  73. package/dist/src/factories/RegistrationFactory.js +26 -0
  74. package/dist/src/factories/RegistrationFactory.js.map +1 -0
  75. package/dist/src/factories/UserFactory.d.ts +21 -0
  76. package/dist/src/factories/UserFactory.d.ts.map +1 -0
  77. package/dist/src/factories/UserFactory.js +41 -0
  78. package/dist/src/factories/UserFactory.js.map +1 -0
  79. package/dist/src/factories/WebshopFactory.d.ts +16 -0
  80. package/dist/src/factories/WebshopFactory.d.ts.map +1 -0
  81. package/dist/src/factories/WebshopFactory.js +35 -0
  82. package/dist/src/factories/WebshopFactory.js.map +1 -0
  83. package/dist/src/helpers/DNSValidator.d.ts +6 -0
  84. package/dist/src/helpers/DNSValidator.d.ts.map +1 -0
  85. package/dist/src/helpers/DNSValidator.js +144 -0
  86. package/dist/src/helpers/DNSValidator.js.map +1 -0
  87. package/dist/src/helpers/EmailBuilder.d.ts +22 -0
  88. package/dist/src/helpers/EmailBuilder.d.ts.map +1 -0
  89. package/dist/src/helpers/EmailBuilder.js +100 -0
  90. package/dist/src/helpers/EmailBuilder.js.map +1 -0
  91. package/dist/src/helpers/GroupBuilder.d.ts +9 -0
  92. package/dist/src/helpers/GroupBuilder.d.ts.map +1 -0
  93. package/dist/src/helpers/GroupBuilder.js +382 -0
  94. package/dist/src/helpers/GroupBuilder.js.map +1 -0
  95. package/dist/src/helpers/Handlebars.d.ts +2 -0
  96. package/dist/src/helpers/Handlebars.d.ts.map +1 -0
  97. package/dist/src/helpers/Handlebars.js +192 -0
  98. package/dist/src/helpers/Handlebars.js.map +1 -0
  99. package/dist/src/helpers/InvoiceBuilder.d.ts +29 -0
  100. package/dist/src/helpers/InvoiceBuilder.d.ts.map +1 -0
  101. package/dist/src/helpers/InvoiceBuilder.js +406 -0
  102. package/dist/src/helpers/InvoiceBuilder.js.map +1 -0
  103. package/dist/src/helpers/InvoiceBuilder.test.d.ts +2 -0
  104. package/dist/src/helpers/InvoiceBuilder.test.d.ts.map +1 -0
  105. package/dist/src/helpers/InvoiceBuilder.test.js +52 -0
  106. package/dist/src/helpers/InvoiceBuilder.test.js.map +1 -0
  107. package/dist/src/helpers/RateLimiter.d.ts +27 -0
  108. package/dist/src/helpers/RateLimiter.d.ts.map +1 -0
  109. package/dist/src/helpers/RateLimiter.js +57 -0
  110. package/dist/src/helpers/RateLimiter.js.map +1 -0
  111. package/dist/src/helpers/WebshopCounter.d.ts +6 -0
  112. package/dist/src/helpers/WebshopCounter.d.ts.map +1 -0
  113. package/dist/src/helpers/WebshopCounter.js +36 -0
  114. package/dist/src/helpers/WebshopCounter.js.map +1 -0
  115. package/dist/src/helpers/WebshopCounter.test.d.ts +2 -0
  116. package/dist/src/helpers/WebshopCounter.test.d.ts.map +1 -0
  117. package/dist/src/helpers/WebshopCounter.test.js +17 -0
  118. package/dist/src/helpers/WebshopCounter.test.js.map +1 -0
  119. package/dist/src/index.d.ts +18 -0
  120. package/dist/src/index.d.ts.map +1 -0
  121. package/dist/src/index.js +23 -0
  122. package/dist/src/index.js.map +1 -0
  123. package/dist/src/migrations/1593773929-create-initial-tables.sql +634 -0
  124. package/dist/src/migrations/1605261999-gemeenten-tmp.sql +2820 -0
  125. package/dist/src/migrations/1605262045-import-postcodes.d.ts +16 -0
  126. package/dist/src/migrations/1605262045-import-postcodes.d.ts.map +1 -0
  127. package/dist/src/migrations/1605262045-import-postcodes.js +116 -0
  128. package/dist/src/migrations/1605262045-import-postcodes.js.map +1 -0
  129. package/dist/src/migrations/1605262046-import-postcodes-nl.d.ts +4 -0
  130. package/dist/src/migrations/1605262046-import-postcodes-nl.d.ts.map +1 -0
  131. package/dist/src/migrations/1605262046-import-postcodes-nl.js +83 -0
  132. package/dist/src/migrations/1605262046-import-postcodes-nl.js.map +1 -0
  133. package/dist/src/migrations/1605279038-drop-gemeenten-tmp.sql +1 -0
  134. package/dist/src/migrations/1648392491-default-templates.sql +9 -0
  135. package/dist/src/migrations/1651245707-default-templates-reminders.sql +6 -0
  136. package/dist/src/migrations/1708607340-tickets-deleted-at.sql +1 -0
  137. package/dist/src/migrations/1710459176-register-code-invoices.sql +3 -0
  138. package/dist/src/migrations/1712158247-discount-codes.sql +17 -0
  139. package/dist/src/migrations/1713178665-drop-invites.sql +1 -0
  140. package/dist/src/migrations/1713178666-drop-keychain.sql +1 -0
  141. package/dist/src/migrations/1713178667-drop-challenges.sql +1 -0
  142. package/dist/src/migrations/1713178668-drop-user-keys.sql +7 -0
  143. package/dist/src/migrations/1713178669-drop-organization-key.sql +2 -0
  144. package/dist/src/migrations/data/postcodes/nl/Drenthe +291 -0
  145. package/dist/src/migrations/data/postcodes/nl/Flevoland +107 -0
  146. package/dist/src/migrations/data/postcodes/nl/Friesland +518 -0
  147. package/dist/src/migrations/data/postcodes/nl/Gelderland +601 -0
  148. package/dist/src/migrations/data/postcodes/nl/Groningen +279 -0
  149. package/dist/src/migrations/data/postcodes/nl/Limburg +324 -0
  150. package/dist/src/migrations/data/postcodes/nl/Noord-Brabant +620 -0
  151. package/dist/src/migrations/data/postcodes/nl/Noord-Holland +566 -0
  152. package/dist/src/migrations/data/postcodes/nl/Overrijsel +344 -0
  153. package/dist/src/migrations/data/postcodes/nl/Utrecht +278 -0
  154. package/dist/src/migrations/data/postcodes/nl/Zeeland +179 -0
  155. package/dist/src/migrations/data/postcodes/nl/Zuid-Holland +662 -0
  156. package/dist/src/models/BalanceItem.d.ts +57 -0
  157. package/dist/src/models/BalanceItem.d.ts.map +1 -0
  158. package/dist/src/models/BalanceItem.js +346 -0
  159. package/dist/src/models/BalanceItem.js.map +1 -0
  160. package/dist/src/models/BalanceItemPayment.d.ts +31 -0
  161. package/dist/src/models/BalanceItemPayment.d.ts.map +1 -0
  162. package/dist/src/models/BalanceItemPayment.js +101 -0
  163. package/dist/src/models/BalanceItemPayment.js.map +1 -0
  164. package/dist/src/models/BuckarooPayment.d.ts +8 -0
  165. package/dist/src/models/BuckarooPayment.d.ts.map +1 -0
  166. package/dist/src/models/BuckarooPayment.js +24 -0
  167. package/dist/src/models/BuckarooPayment.js.map +1 -0
  168. package/dist/src/models/Document.d.ts +44 -0
  169. package/dist/src/models/Document.d.ts.map +1 -0
  170. package/dist/src/models/Document.js +194 -0
  171. package/dist/src/models/Document.js.map +1 -0
  172. package/dist/src/models/DocumentTemplate.d.ts +45 -0
  173. package/dist/src/models/DocumentTemplate.d.ts.map +1 -0
  174. package/dist/src/models/DocumentTemplate.js +533 -0
  175. package/dist/src/models/DocumentTemplate.js.map +1 -0
  176. package/dist/src/models/EmailTemplate.d.ts +22 -0
  177. package/dist/src/models/EmailTemplate.d.ts.map +1 -0
  178. package/dist/src/models/EmailTemplate.js +70 -0
  179. package/dist/src/models/EmailTemplate.js.map +1 -0
  180. package/dist/src/models/EmailVerificationCode.d.ts +60 -0
  181. package/dist/src/models/EmailVerificationCode.d.ts.map +1 -0
  182. package/dist/src/models/EmailVerificationCode.js +307 -0
  183. package/dist/src/models/EmailVerificationCode.js.map +1 -0
  184. package/dist/src/models/Group.d.ts +36 -0
  185. package/dist/src/models/Group.d.ts.map +1 -0
  186. package/dist/src/models/Group.js +231 -0
  187. package/dist/src/models/Group.js.map +1 -0
  188. package/dist/src/models/Image.d.ts +12 -0
  189. package/dist/src/models/Image.d.ts.map +1 -0
  190. package/dist/src/models/Image.js +137 -0
  191. package/dist/src/models/Image.js.map +1 -0
  192. package/dist/src/models/Member.d.ts +66 -0
  193. package/dist/src/models/Member.d.ts.map +1 -0
  194. package/dist/src/models/Member.js +309 -0
  195. package/dist/src/models/Member.js.map +1 -0
  196. package/dist/src/models/MemberResponsibilityRecord.d.ts +11 -0
  197. package/dist/src/models/MemberResponsibilityRecord.d.ts.map +1 -0
  198. package/dist/src/models/MemberResponsibilityRecord.js +47 -0
  199. package/dist/src/models/MemberResponsibilityRecord.js.map +1 -0
  200. package/dist/src/models/MolliePayment.d.ts +8 -0
  201. package/dist/src/models/MolliePayment.d.ts.map +1 -0
  202. package/dist/src/models/MolliePayment.js +24 -0
  203. package/dist/src/models/MolliePayment.js.map +1 -0
  204. package/dist/src/models/MollieToken.d.ts +45 -0
  205. package/dist/src/models/MollieToken.d.ts.map +1 -0
  206. package/dist/src/models/MollieToken.js +333 -0
  207. package/dist/src/models/MollieToken.js.map +1 -0
  208. package/dist/src/models/OneTimeToken.d.ts +38 -0
  209. package/dist/src/models/OneTimeToken.d.ts.map +1 -0
  210. package/dist/src/models/OneTimeToken.js +126 -0
  211. package/dist/src/models/OneTimeToken.js.map +1 -0
  212. package/dist/src/models/Order.d.ts +99 -0
  213. package/dist/src/models/Order.d.ts.map +1 -0
  214. package/dist/src/models/Order.js +912 -0
  215. package/dist/src/models/Order.js.map +1 -0
  216. package/dist/src/models/Organization.d.ts +119 -0
  217. package/dist/src/models/Organization.d.ts.map +1 -0
  218. package/dist/src/models/Organization.js +900 -0
  219. package/dist/src/models/Organization.js.map +1 -0
  220. package/dist/src/models/OrganizationRegistrationPeriod.d.ts +14 -0
  221. package/dist/src/models/OrganizationRegistrationPeriod.d.ts.map +1 -0
  222. package/dist/src/models/OrganizationRegistrationPeriod.js +62 -0
  223. package/dist/src/models/OrganizationRegistrationPeriod.js.map +1 -0
  224. package/dist/src/models/PasswordToken.d.ts +29 -0
  225. package/dist/src/models/PasswordToken.d.ts.map +1 -0
  226. package/dist/src/models/PasswordToken.js +118 -0
  227. package/dist/src/models/PasswordToken.js.map +1 -0
  228. package/dist/src/models/PayconiqPayment.d.ts +18 -0
  229. package/dist/src/models/PayconiqPayment.d.ts.map +1 -0
  230. package/dist/src/models/PayconiqPayment.js +216 -0
  231. package/dist/src/models/PayconiqPayment.js.map +1 -0
  232. package/dist/src/models/Payment.d.ts +62 -0
  233. package/dist/src/models/Payment.d.ts.map +1 -0
  234. package/dist/src/models/Payment.js +199 -0
  235. package/dist/src/models/Payment.js.map +1 -0
  236. package/dist/src/models/Platform.d.ts +15 -0
  237. package/dist/src/models/Platform.d.ts.map +1 -0
  238. package/dist/src/models/Platform.js +77 -0
  239. package/dist/src/models/Platform.js.map +1 -0
  240. package/dist/src/models/RegisterCode.d.ts +27 -0
  241. package/dist/src/models/RegisterCode.d.ts.map +1 -0
  242. package/dist/src/models/RegisterCode.js +162 -0
  243. package/dist/src/models/RegisterCode.js.map +1 -0
  244. package/dist/src/models/Registration.d.ts +47 -0
  245. package/dist/src/models/Registration.d.ts.map +1 -0
  246. package/dist/src/models/Registration.js +369 -0
  247. package/dist/src/models/Registration.js.map +1 -0
  248. package/dist/src/models/RegistrationPeriod.d.ts +15 -0
  249. package/dist/src/models/RegistrationPeriod.d.ts.map +1 -0
  250. package/dist/src/models/RegistrationPeriod.js +64 -0
  251. package/dist/src/models/RegistrationPeriod.js.map +1 -0
  252. package/dist/src/models/STCredit.d.ts +20 -0
  253. package/dist/src/models/STCredit.d.ts.map +1 -0
  254. package/dist/src/models/STCredit.js +129 -0
  255. package/dist/src/models/STCredit.js.map +1 -0
  256. package/dist/src/models/STInvoice.d.ts +51 -0
  257. package/dist/src/models/STInvoice.d.ts.map +1 -0
  258. package/dist/src/models/STInvoice.js +453 -0
  259. package/dist/src/models/STInvoice.js.map +1 -0
  260. package/dist/src/models/STPackage.d.ts +36 -0
  261. package/dist/src/models/STPackage.d.ts.map +1 -0
  262. package/dist/src/models/STPackage.js +300 -0
  263. package/dist/src/models/STPackage.js.map +1 -0
  264. package/dist/src/models/STPendingInvoice.d.ts +45 -0
  265. package/dist/src/models/STPendingInvoice.d.ts.map +1 -0
  266. package/dist/src/models/STPendingInvoice.js +284 -0
  267. package/dist/src/models/STPendingInvoice.js.map +1 -0
  268. package/dist/src/models/StripeAccount.d.ts +17 -0
  269. package/dist/src/models/StripeAccount.d.ts.map +1 -0
  270. package/dist/src/models/StripeAccount.js +81 -0
  271. package/dist/src/models/StripeAccount.js.map +1 -0
  272. package/dist/src/models/StripeCheckoutSession.d.ts +9 -0
  273. package/dist/src/models/StripeCheckoutSession.d.ts.map +1 -0
  274. package/dist/src/models/StripeCheckoutSession.js +31 -0
  275. package/dist/src/models/StripeCheckoutSession.js.map +1 -0
  276. package/dist/src/models/StripePaymentIntent.d.ts +9 -0
  277. package/dist/src/models/StripePaymentIntent.d.ts.map +1 -0
  278. package/dist/src/models/StripePaymentIntent.js +31 -0
  279. package/dist/src/models/StripePaymentIntent.js.map +1 -0
  280. package/dist/src/models/Ticket.d.ts +61 -0
  281. package/dist/src/models/Ticket.d.ts.map +1 -0
  282. package/dist/src/models/Ticket.js +143 -0
  283. package/dist/src/models/Ticket.js.map +1 -0
  284. package/dist/src/models/Token.d.ts +49 -0
  285. package/dist/src/models/Token.d.ts.map +1 -0
  286. package/dist/src/models/Token.js +218 -0
  287. package/dist/src/models/Token.js.map +1 -0
  288. package/dist/src/models/Token.test.d.ts +2 -0
  289. package/dist/src/models/Token.test.d.ts.map +1 -0
  290. package/dist/src/models/Token.test.js +60 -0
  291. package/dist/src/models/Token.test.js.map +1 -0
  292. package/dist/src/models/UsedRegisterCode.d.ts +22 -0
  293. package/dist/src/models/UsedRegisterCode.d.ts.map +1 -0
  294. package/dist/src/models/UsedRegisterCode.js +158 -0
  295. package/dist/src/models/UsedRegisterCode.js.map +1 -0
  296. package/dist/src/models/User.d.ts +55 -0
  297. package/dist/src/models/User.d.ts.map +1 -0
  298. package/dist/src/models/User.js +314 -0
  299. package/dist/src/models/User.js.map +1 -0
  300. package/dist/src/models/UserPermissions.d.ts +15 -0
  301. package/dist/src/models/UserPermissions.d.ts.map +1 -0
  302. package/dist/src/models/UserPermissions.js +57 -0
  303. package/dist/src/models/UserPermissions.js.map +1 -0
  304. package/dist/src/models/Webshop.d.ts +44 -0
  305. package/dist/src/models/Webshop.d.ts.map +1 -0
  306. package/dist/src/models/Webshop.js +184 -0
  307. package/dist/src/models/Webshop.js.map +1 -0
  308. package/dist/src/models/WebshopDiscountCode.d.ts +18 -0
  309. package/dist/src/models/WebshopDiscountCode.d.ts.map +1 -0
  310. package/dist/src/models/WebshopDiscountCode.js +88 -0
  311. package/dist/src/models/WebshopDiscountCode.js.map +1 -0
  312. package/dist/src/models/addresses/City.d.ts +14 -0
  313. package/dist/src/models/addresses/City.d.ts.map +1 -0
  314. package/dist/src/models/addresses/City.js +37 -0
  315. package/dist/src/models/addresses/City.js.map +1 -0
  316. package/dist/src/models/addresses/PostalCode.d.ts +20 -0
  317. package/dist/src/models/addresses/PostalCode.d.ts.map +1 -0
  318. package/dist/src/models/addresses/PostalCode.js +138 -0
  319. package/dist/src/models/addresses/PostalCode.js.map +1 -0
  320. package/dist/src/models/addresses/PostalCode.test.d.ts +2 -0
  321. package/dist/src/models/addresses/PostalCode.test.d.ts.map +1 -0
  322. package/dist/src/models/addresses/PostalCode.test.js +98 -0
  323. package/dist/src/models/addresses/PostalCode.test.js.map +1 -0
  324. package/dist/src/models/addresses/Province.d.ts +9 -0
  325. package/dist/src/models/addresses/Province.d.ts.map +1 -0
  326. package/dist/src/models/addresses/Province.js +24 -0
  327. package/dist/src/models/addresses/Province.js.map +1 -0
  328. package/dist/src/models/addresses/Street.d.ts +10 -0
  329. package/dist/src/models/addresses/Street.d.ts.map +1 -0
  330. package/dist/src/models/addresses/Street.js +26 -0
  331. package/dist/src/models/addresses/Street.js.map +1 -0
  332. package/dist/src/models/index.d.ts +37 -0
  333. package/dist/src/models/index.d.ts.map +1 -0
  334. package/dist/src/models/index.js +53 -0
  335. package/dist/src/models/index.js.map +1 -0
  336. package/dist/src/structures/OrganizationServerMetaData.d.ts +43 -0
  337. package/dist/src/structures/OrganizationServerMetaData.d.ts.map +1 -0
  338. package/dist/src/structures/OrganizationServerMetaData.js +128 -0
  339. package/dist/src/structures/OrganizationServerMetaData.js.map +1 -0
  340. package/dist/tests/jest.global.setup.d.ts +3 -0
  341. package/dist/tests/jest.global.setup.d.ts.map +1 -0
  342. package/dist/tests/jest.global.setup.js +20 -0
  343. package/dist/tests/jest.global.setup.js.map +1 -0
  344. package/dist/tests/jest.setup.d.ts +2 -0
  345. package/dist/tests/jest.setup.d.ts.map +1 -0
  346. package/dist/tests/jest.setup.js +15 -0
  347. package/dist/tests/jest.setup.js.map +1 -0
  348. package/package.json +30 -0
  349. package/src/assets/Metropolis-Black.woff2 +0 -0
  350. package/src/assets/Metropolis-BlackItalic.woff2 +0 -0
  351. package/src/assets/Metropolis-Bold.woff2 +0 -0
  352. package/src/assets/Metropolis-BoldItalic.woff2 +0 -0
  353. package/src/assets/Metropolis-ExtraBold.woff2 +0 -0
  354. package/src/assets/Metropolis-ExtraBoldItalic.woff2 +0 -0
  355. package/src/assets/Metropolis-ExtraLight.woff2 +0 -0
  356. package/src/assets/Metropolis-ExtraLightItalic.woff2 +0 -0
  357. package/src/assets/Metropolis-Light.woff2 +0 -0
  358. package/src/assets/Metropolis-LightItalic.woff2 +0 -0
  359. package/src/assets/Metropolis-Medium.woff2 +0 -0
  360. package/src/assets/Metropolis-MediumItalic.woff2 +0 -0
  361. package/src/assets/Metropolis-Regular.woff2 +0 -0
  362. package/src/assets/Metropolis-RegularItalic.woff2 +0 -0
  363. package/src/assets/Metropolis-SemiBold.woff2 +0 -0
  364. package/src/assets/Metropolis-SemiBoldItalic.woff2 +0 -0
  365. package/src/assets/Metropolis-Thin.woff2 +0 -0
  366. package/src/assets/Metropolis-ThinItalic.woff2 +0 -0
  367. package/src/assets/logo.png +0 -0
  368. package/src/factories/AddressFactory.ts +42 -0
  369. package/src/factories/EmergencyContactFactory.ts +43 -0
  370. package/src/factories/GroupFactory.ts +66 -0
  371. package/src/factories/MemberFactory.ts +122 -0
  372. package/src/factories/OrganizationFactory.ts +45 -0
  373. package/src/factories/ParentFactory.ts +49 -0
  374. package/src/factories/RecordFactory.ts +12 -0
  375. package/src/factories/RegisterCodeFactory.ts +25 -0
  376. package/src/factories/RegistrationFactory.ts +32 -0
  377. package/src/factories/UserFactory.ts +66 -0
  378. package/src/factories/WebshopFactory.ts +43 -0
  379. package/src/helpers/DNSValidator.ts +153 -0
  380. package/src/helpers/EmailBuilder.ts +127 -0
  381. package/src/helpers/GroupBuilder.ts +438 -0
  382. package/src/helpers/Handlebars.ts +203 -0
  383. package/src/helpers/InvoiceBuilder.test.ts +57 -0
  384. package/src/helpers/InvoiceBuilder.ts +501 -0
  385. package/src/helpers/RateLimiter.ts +75 -0
  386. package/src/helpers/WebshopCounter.test.ts +16 -0
  387. package/src/helpers/WebshopCounter.ts +36 -0
  388. package/src/index.ts +21 -0
  389. package/src/migrations/1593773929-create-initial-tables.sql +634 -0
  390. package/src/migrations/1605261999-gemeenten-tmp.sql +2820 -0
  391. package/src/migrations/1605262045-import-postcodes.ts +132 -0
  392. package/src/migrations/1605262046-import-postcodes-nl.ts +97 -0
  393. package/src/migrations/1605279038-drop-gemeenten-tmp.sql +1 -0
  394. package/src/migrations/1648392491-default-templates.sql +9 -0
  395. package/src/migrations/1651245707-default-templates-reminders.sql +6 -0
  396. package/src/migrations/1708607340-tickets-deleted-at.sql +1 -0
  397. package/src/migrations/1710459176-register-code-invoices.sql +3 -0
  398. package/src/migrations/1712158247-discount-codes.sql +17 -0
  399. package/src/migrations/1713178665-drop-invites.sql +1 -0
  400. package/src/migrations/1713178666-drop-keychain.sql +1 -0
  401. package/src/migrations/1713178667-drop-challenges.sql +1 -0
  402. package/src/migrations/1713178668-drop-user-keys.sql +7 -0
  403. package/src/migrations/1713178669-drop-organization-key.sql +2 -0
  404. package/src/migrations/1714985451-user-nullable-organization-id.sql +2 -0
  405. package/src/migrations/1714985452-email-verification-code-nullable-organization-id.sql +2 -0
  406. package/src/migrations/1714985453-user-organization-permissions.sql +2 -0
  407. package/src/migrations/1714985454-user-organization-permissions.sql +2 -0
  408. package/src/migrations/1715079362-platform.sql +6 -0
  409. package/src/migrations/1715181649-registrations-organization-id.sql +2 -0
  410. package/src/migrations/1715181650-registrations-organization-id-fill.sql +1 -0
  411. package/src/migrations/1715181651-registrations-organization-id-drop-null.sql +2 -0
  412. package/src/migrations/1716117067-members-nullable-organization-id.sql +2 -0
  413. package/src/migrations/1719567581-registration-periods.sql +13 -0
  414. package/src/migrations/1719567582-organization-registration-periods.sql +13 -0
  415. package/src/migrations/1719567881-organization-periodId.sql +2 -0
  416. package/src/migrations/1719567882-groups-periodId.sql +2 -0
  417. package/src/migrations/1719567883-platform-periodId.sql +2 -0
  418. package/src/migrations/1719568079-default-period.sql +2 -0
  419. package/src/migrations/1719568080-set-default-period-platform.sql +1 -0
  420. package/src/migrations/1719568081-set-default-period-organizations.sql +1 -0
  421. package/src/migrations/1719568082-set-default-period-groups.sql +1 -0
  422. package/src/migrations/1719580828-registrations-periodId.sql +2 -0
  423. package/src/migrations/1719580829-set-default-period-registrations.sql +1 -0
  424. package/src/migrations/data/postcodes/nl/Drenthe +291 -0
  425. package/src/migrations/data/postcodes/nl/Flevoland +107 -0
  426. package/src/migrations/data/postcodes/nl/Friesland +518 -0
  427. package/src/migrations/data/postcodes/nl/Gelderland +601 -0
  428. package/src/migrations/data/postcodes/nl/Groningen +279 -0
  429. package/src/migrations/data/postcodes/nl/Limburg +324 -0
  430. package/src/migrations/data/postcodes/nl/Noord-Brabant +620 -0
  431. package/src/migrations/data/postcodes/nl/Noord-Holland +566 -0
  432. package/src/migrations/data/postcodes/nl/Overrijsel +344 -0
  433. package/src/migrations/data/postcodes/nl/Utrecht +278 -0
  434. package/src/migrations/data/postcodes/nl/Zeeland +179 -0
  435. package/src/migrations/data/postcodes/nl/Zuid-Holland +662 -0
  436. package/src/models/BalanceItem.ts +392 -0
  437. package/src/models/BalanceItemPayment.ts +106 -0
  438. package/src/models/BuckarooPayment.ts +19 -0
  439. package/src/models/Document.ts +203 -0
  440. package/src/models/DocumentTemplate.ts +583 -0
  441. package/src/models/EmailTemplate.ts +64 -0
  442. package/src/models/EmailVerificationCode.ts +352 -0
  443. package/src/models/Group.ts +293 -0
  444. package/src/models/Image.ts +147 -0
  445. package/src/models/Member.ts +386 -0
  446. package/src/models/MemberResponsibilityRecord.ts +39 -0
  447. package/src/models/MolliePayment.ts +19 -0
  448. package/src/models/MollieToken.ts +369 -0
  449. package/src/models/OneTimeToken.ts +131 -0
  450. package/src/models/Order.ts +1030 -0
  451. package/src/models/Organization.ts +1085 -0
  452. package/src/models/OrganizationRegistrationPeriod.ts +54 -0
  453. package/src/models/PasswordToken.ts +139 -0
  454. package/src/models/PayconiqPayment.ts +241 -0
  455. package/src/models/Payment.ts +216 -0
  456. package/src/models/Platform.ts +76 -0
  457. package/src/models/RegisterCode.ts +164 -0
  458. package/src/models/Registration.ts +405 -0
  459. package/src/models/RegistrationPeriod.ts +55 -0
  460. package/src/models/STCredit.ts +134 -0
  461. package/src/models/STInvoice.ts +507 -0
  462. package/src/models/STPackage.ts +324 -0
  463. package/src/models/STPendingInvoice.ts +308 -0
  464. package/src/models/StripeAccount.ts +71 -0
  465. package/src/models/StripeCheckoutSession.ts +22 -0
  466. package/src/models/StripePaymentIntent.ts +22 -0
  467. package/src/models/Ticket.ts +145 -0
  468. package/src/models/Token.test.ts +69 -0
  469. package/src/models/Token.ts +269 -0
  470. package/src/models/UsedRegisterCode.ts +166 -0
  471. package/src/models/User.ts +445 -0
  472. package/src/models/UserPermissions.ts +54 -0
  473. package/src/models/Webshop.ts +206 -0
  474. package/src/models/WebshopDiscountCode.ts +81 -0
  475. package/src/models/addresses/City.ts +31 -0
  476. package/src/models/addresses/PostalCode.test.ts +117 -0
  477. package/src/models/addresses/PostalCode.ts +164 -0
  478. package/src/models/addresses/Province.ts +20 -0
  479. package/src/models/addresses/Street.ts +25 -0
  480. package/src/models/index.ts +49 -0
  481. package/src/structures/OrganizationServerMetaData.ts +117 -0
@@ -0,0 +1,54 @@
1
+ import { column, Model } from '@simonbackx/simple-database';
2
+ import { Group as GroupStruct, OrganizationRegistrationPeriodSettings, OrganizationRegistrationPeriod as OrganizationRegistrationPeriodStruct } from '@stamhoofd/structures';
3
+ import { v4 as uuidv4 } from "uuid";
4
+ import { Group, RegistrationPeriod } from '.';
5
+
6
+ export class OrganizationRegistrationPeriod extends Model {
7
+ static table = "organization_registration_periods";
8
+
9
+ @column({
10
+ primary: true, type: "string", beforeSave(value) {
11
+ return value ?? uuidv4();
12
+ }
13
+ })
14
+ id!: string;
15
+
16
+ @column({ type: "string", nullable: true })
17
+ organizationId: string | null = null;
18
+
19
+ @column({ type: "string" })
20
+ periodId: string
21
+
22
+ @column({ type: "json", decoder: OrganizationRegistrationPeriodSettings })
23
+ settings = OrganizationRegistrationPeriodSettings.create({})
24
+
25
+ @column({
26
+ type: "datetime", beforeSave(old?: any) {
27
+ if (old !== undefined) {
28
+ return old;
29
+ }
30
+ const date = new Date()
31
+ date.setMilliseconds(0)
32
+ return date
33
+ }
34
+ })
35
+ createdAt: Date
36
+
37
+ @column({
38
+ type: "datetime", beforeSave() {
39
+ const date = new Date()
40
+ date.setMilliseconds(0)
41
+ return date
42
+ },
43
+ skipUpdate: true
44
+ })
45
+ updatedAt: Date
46
+
47
+ getStructure(this: OrganizationRegistrationPeriod, period: RegistrationPeriod, groups: Group[]) {
48
+ return OrganizationRegistrationPeriodStruct.create({
49
+ ...this,
50
+ period: period.getStructure(),
51
+ groups: groups.map(g => g.getStructure()).sort(GroupStruct.defaultSort)
52
+ })
53
+ }
54
+ }
@@ -0,0 +1,139 @@
1
+
2
+ import { column, Database, ManyToOneRelation, Model } from "@simonbackx/simple-database";
3
+ import { I18n } from "@stamhoofd/backend-i18n";
4
+ import basex from "base-x";
5
+ import crypto from "crypto";
6
+
7
+ import { Organization, User } from "./";
8
+ const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'
9
+ const bs58 = basex(ALPHABET)
10
+
11
+ export type PasswordTokenWithUser = PasswordToken & { user: User };
12
+
13
+ async function randomBytes(size: number): Promise<Buffer> {
14
+ return new Promise((resolve, reject) => {
15
+ crypto.randomBytes(size, (err: Error | null, buf: Buffer) => {
16
+ if (err) {
17
+ reject(err);
18
+ return;
19
+ }
20
+ resolve(buf);
21
+ });
22
+ });
23
+ }
24
+
25
+ export class PasswordToken extends Model {
26
+ static table = "password_tokens";
27
+
28
+ // Columns
29
+ @column({ primary: true, type: "string" })
30
+ token: string;
31
+
32
+ @column({ type: "datetime" })
33
+ validUntil: Date;
34
+
35
+ @column({
36
+ type: "datetime", beforeSave(old?: any) {
37
+ if (old !== undefined) {
38
+ return old;
39
+ }
40
+ const date = new Date()
41
+ date.setMilliseconds(0)
42
+ return date
43
+ }
44
+ })
45
+ createdAt: Date
46
+
47
+ @column({ type: "string", foreignKey: PasswordToken.user })
48
+ userId: string;
49
+
50
+ static user = new ManyToOneRelation(User, "user");
51
+
52
+ isExpired(): boolean {
53
+ return this.validUntil < new Date()
54
+ }
55
+
56
+ /**
57
+ * Get a token
58
+ * @param token
59
+ * @param ignoreExpireDate: do not return if it is expired
60
+ */
61
+ static async getToken(token: string, ignoreExpireDate = false): Promise<PasswordTokenWithUser | undefined> {
62
+ const [rows] = await Database.select(
63
+ `SELECT ${this.getDefaultSelect()}, ${User.getDefaultSelect("user")} FROM ${
64
+ this.table
65
+ } ${PasswordToken.user.joinQuery(this.table, "user")} WHERE ${this.primary.name} = ? LIMIT 1 `,
66
+ [token]
67
+ );
68
+
69
+ if (rows.length == 0) {
70
+ return undefined;
71
+ }
72
+
73
+ const passwordToken = this.fromRow(rows[0][this.table]);
74
+
75
+ if (!passwordToken) {
76
+ return undefined;
77
+ }
78
+
79
+ if (!ignoreExpireDate && passwordToken.isExpired()) {
80
+ // If the refresh token is invalid, do not return it
81
+ return undefined
82
+ }
83
+
84
+ const user = User.fromRow(rows[0]["user"]) || null;
85
+
86
+ if (!user) {
87
+ console.error("Password token without a valid user!");
88
+ return undefined;
89
+ }
90
+
91
+ return passwordToken.setRelation(PasswordToken.user, user);
92
+ }
93
+
94
+ /***
95
+ * Create a token without saving it
96
+ */
97
+ static async createToken<U extends User>(user: U, validUntil?: Date): Promise<PasswordTokenWithUser> {
98
+ const token = new PasswordToken().setRelation(PasswordToken.user, user);
99
+
100
+ if (validUntil) {
101
+ token.validUntil = new Date(validUntil)
102
+ } else {
103
+ token.validUntil = new Date();
104
+ token.validUntil.setTime(token.validUntil.getTime() + 3 * 3600 * 1000);
105
+ }
106
+ token.validUntil.setMilliseconds(0);
107
+ token.token = bs58.encode(await randomBytes(100)).toLowerCase();
108
+ await token.save();
109
+ return token;
110
+ }
111
+
112
+ static async getPasswordRecoveryUrl(user: User, organization: Organization|null, i18n: I18n, validUntil?: Date) {
113
+ if (user.organizationId !== null && ((user.organizationId ?? null) !== (organization?.id ?? null))) {
114
+ throw new Error('Unexpected mismatch in organization id for PasswordToken')
115
+ }
116
+ // Send an e-mail to say you already have an account + follow password forgot flow
117
+ const token = await PasswordToken.createToken(user, validUntil)
118
+
119
+ let host: string;
120
+ if (user.permissions || !organization || STAMHOOFD.userMode === "platform") {
121
+ host = "https://"+(STAMHOOFD.domains.dashboard)+"/"+i18n.locale
122
+ return host+"/reset-password"+((user.organizationId || organization) ? ("/"+encodeURIComponent(user.organizationId ?? organization!.id)) : "")+"?token="+encodeURIComponent(token.token);
123
+ }
124
+
125
+ host = "https://"+organization.getHost(i18n)
126
+ return host+"/reset-password?token="+encodeURIComponent(token.token);
127
+ }
128
+
129
+ static async getMagicSignInUrl(user: User, organization: Organization) {
130
+ // For now we don't add a token yet for security. We might add some sort of email validation thing later on
131
+ const host = "https://"+organization.getHost()
132
+ return Promise.resolve(host+"/login"+"?email="+encodeURIComponent(user.email)+"&hasAccount="+(user.hasAccount() ? 1 : 0));
133
+ }
134
+
135
+ static async clearFor(userId: string) {
136
+ const query = `DELETE from ${this.table} where userId = ?`;
137
+ await Database.delete(query, [userId])
138
+ }
139
+ }
@@ -0,0 +1,241 @@
1
+ import { column, Model } from "@simonbackx/simple-database";
2
+ import { SimpleError } from '@simonbackx/simple-errors';
3
+ import { PayconiqAccount, PaymentStatus, Version } from '@stamhoofd/structures';
4
+ import { IncomingMessage } from 'http';
5
+ import https from "https";
6
+ import { v4 as uuidv4 } from "uuid";
7
+
8
+ import { Organization, Payment } from './';
9
+
10
+ export class PayconiqPayment extends Model {
11
+ static table = "payconiq_payments";
12
+
13
+ @column({
14
+ primary: true, type: "string", beforeSave(value) {
15
+ return value ?? uuidv4();
16
+ }
17
+ })
18
+ id!: string;
19
+
20
+ @column({ type: "string" })
21
+ paymentId: string;
22
+
23
+ @column({ type: "string" })
24
+ payconiqId: string;
25
+
26
+ async getStatus(organization: Organization): Promise<PaymentStatus> {
27
+ const apiKey = organization.privateMeta.payconiqApiKey
28
+ if (!apiKey) {
29
+ throw new SimpleError({
30
+ code: "",
31
+ message: "Payconiq API key missing to check the status of the payment"
32
+ })
33
+ }
34
+
35
+ const response = await PayconiqPayment.request("GET", "/v3/payments/"+this.payconiqId, {}, apiKey, organization.privateMeta.useTestPayments ?? STAMHOOFD.environment != 'production')
36
+ if (response.status) {
37
+ switch (response.status) {
38
+ case "AUTHORIZED": return PaymentStatus.Pending;
39
+ case "PENDING": return PaymentStatus.Created;
40
+
41
+ case "IDENTIFIED": return PaymentStatus.Pending; // Code has been scanned!
42
+
43
+ case "AUTHORIZATION_FAILED": return PaymentStatus.Failed;
44
+ case "EXPIRED": return PaymentStatus.Failed;
45
+ case "FAILED": return PaymentStatus.Failed;
46
+ case "CANCELLED": return PaymentStatus.Failed;
47
+
48
+ case "SUCCEEDED": return PaymentStatus.Succeeded;
49
+ }
50
+ return PaymentStatus.Pending // default to pending
51
+ }
52
+ throw new SimpleError({
53
+ code: "",
54
+ message: "Status missing in response"
55
+ })
56
+ }
57
+
58
+ async cancel(organization: Organization): Promise<boolean> {
59
+ const apiKey = organization.privateMeta.payconiqApiKey
60
+ if (!apiKey) {
61
+ throw new SimpleError({
62
+ code: "",
63
+ message: "Payconiq API key missing to check the status of the payment"
64
+ })
65
+ }
66
+
67
+ // Throws on failure
68
+ try {
69
+ await PayconiqPayment.request("DELETE", "/v3/payments/"+this.payconiqId, {}, apiKey, organization.privateMeta.useTestPayments ?? STAMHOOFD.environment != 'production')
70
+ return true;
71
+ } catch (e) {
72
+ console.error('Failed to cancel Payconiq payment', this.id, this.payconiqId, e)
73
+ return false;
74
+ }
75
+ }
76
+
77
+ static async createTest(organization: Organization, payconiqAccount: PayconiqAccount): Promise<undefined|object> {
78
+ const apiKey = payconiqAccount.apiKey
79
+ if (!apiKey) {
80
+ return
81
+ }
82
+
83
+ try {
84
+ const response = await this.request("POST", "/v3/payments", {
85
+ reference: "test-"+(new Date().getTime()), // 36 chars, max length is 35...
86
+ amount: 1,
87
+ currency: "EUR",
88
+ callbackUrl: 'https://'+organization.getApiHost(),
89
+ description: "Key validation test",
90
+
91
+ }, apiKey, organization.privateMeta.useTestPayments ?? STAMHOOFD.environment != 'production')
92
+ return response;
93
+ } catch (e) {
94
+ return;
95
+ }
96
+ }
97
+
98
+
99
+ static async createPayment(payment: Payment, organization: Organization, description: string, returnUrl?: string, callbackUrl?: string) {
100
+ const apiKey = organization.privateMeta.payconiqApiKey
101
+ if (!apiKey) {
102
+ throw new SimpleError({
103
+ code: "",
104
+ message: "Betaling via Payconiq is tijdelijk onbeschikbaar"
105
+ })
106
+ }
107
+
108
+ const response = await this.request("POST", "/v3/payments", {
109
+ reference: payment.id.replace("-", ""), // 36 chars, max length is 35...
110
+ amount: payment.price,
111
+ currency: "EUR",
112
+ callbackUrl: callbackUrl ?? 'https://'+organization.getApiHost()+"/v"+Version+"/payments/"+encodeURIComponent(payment.id)+"?exchange=true",
113
+ returnUrl,
114
+ description
115
+ }, apiKey, organization.privateMeta.useTestPayments ?? STAMHOOFD.environment != 'production')
116
+
117
+ const payconiqPayment = new PayconiqPayment()
118
+ payconiqPayment.paymentId = payment.id
119
+ payconiqPayment.payconiqId = response.paymentId
120
+
121
+ // Read link (currently we use checkout!)
122
+ let link = response._links.checkout.href as string;
123
+
124
+ if (organization.privateMeta.useTestPayments ?? STAMHOOFD.environment != 'production') {
125
+ // For checkout only!
126
+ // We get the wrong link in development mode
127
+ link = link.replace('https://payconiq.com/', 'https://ext.payconiq.com/');
128
+ }
129
+
130
+ await payconiqPayment.save();
131
+
132
+ return link;
133
+ }
134
+
135
+ /**
136
+ * Do a post request on the API.
137
+ */
138
+ private static request(method: string, path: string, data = {}, auth: string | null = null, testMode: boolean): Promise<any> {
139
+ return new Promise((resolve, reject) => {
140
+ const jsonData = JSON.stringify(data);
141
+ const hostname = !testMode ? "api.payconiq.com" : "api.ext.payconiq.com"
142
+ const base = "https://"+hostname
143
+
144
+ // Log all communication
145
+ console.log(method+" "+base+path+"\n"+jsonData);
146
+ console.log(jsonData);
147
+
148
+ const headers = {
149
+ "Content-Type": "application/json; charset=utf-8",
150
+ "Content-Length": Buffer.byteLength(jsonData),
151
+ };
152
+
153
+ if (auth) {
154
+ headers["Authorization"] = "Bearer "+auth
155
+ }
156
+
157
+ const req = https.request(
158
+ {
159
+ hostname: hostname,
160
+ path: path,
161
+ method: method,
162
+ headers: headers,
163
+ timeout: 10000,
164
+ },
165
+ (response: IncomingMessage) => {
166
+ console.log(`statusCode: ${response.statusCode ?? '/'}`);
167
+ console.log(`HEADERS: ${JSON.stringify(response.headers)}`);
168
+
169
+ const chunks: any[] = [];
170
+
171
+ response.on("data", (chunk) => {
172
+ chunks.push(chunk);
173
+ });
174
+
175
+ response.on("end", () => {
176
+ try {
177
+ if (!response.statusCode) {
178
+ reject(new Error("Unexpected order of events"));
179
+ return;
180
+ }
181
+ const body = Buffer.concat(chunks).toString();
182
+ console.log(body);
183
+
184
+ if (response.statusCode == 204) {
185
+ resolve(undefined);
186
+ return;
187
+ }
188
+
189
+ let json: any;
190
+ try {
191
+ json = JSON.parse(body);
192
+ } catch (error) {
193
+ console.error(error);
194
+
195
+ // invalid json
196
+ if (response.statusCode < 200 || response.statusCode >= 300) {
197
+ if (body.length == 0) {
198
+ console.error(response.statusCode);
199
+ reject(new Error("Status " + response.statusCode));
200
+ return;
201
+ }
202
+ console.error(response.statusCode + " " + body);
203
+ reject(new Error(body));
204
+ return;
205
+ } else {
206
+ // something wrong: throw parse error
207
+ reject(error);
208
+ return;
209
+ }
210
+ }
211
+
212
+ if (response.statusCode < 200 || response.statusCode >= 300) {
213
+ console.error(body);
214
+ reject(new Error(response.statusCode + " " + response.statusMessage));
215
+ return;
216
+ }
217
+
218
+ resolve(json);
219
+ } catch (error) {
220
+ console.error(error);
221
+ reject(error);
222
+ }
223
+ });
224
+ }
225
+ );
226
+
227
+ // use its "timeout" event to abort the request
228
+ req.on("timeout", () => {
229
+ req.abort();
230
+ });
231
+
232
+ req.on("error", (error) => {
233
+ console.error(error);
234
+ reject(error);
235
+ });
236
+
237
+ req.write(jsonData);
238
+ req.end();
239
+ });
240
+ }
241
+ }
@@ -0,0 +1,216 @@
1
+ import { column, ManyToOneRelation, Model } from '@simonbackx/simple-database';
2
+ import { BalanceItemDetailed, BalanceItemPaymentDetailed, Member as MemberStruct, Order as OrderStruct, PaymentGeneral, PaymentMethod, PaymentProvider, PaymentStatus, Settlement, TransferSettings } from '@stamhoofd/structures';
3
+ import { Formatter } from '@stamhoofd/utility';
4
+ import { v4 as uuidv4 } from "uuid";
5
+
6
+ import { Organization, Registration } from './';
7
+
8
+ export class Payment extends Model {
9
+ static table = "payments"
10
+
11
+ @column({
12
+ primary: true, type: "string", beforeSave(value) {
13
+ return value ?? uuidv4();
14
+ }
15
+ })
16
+ id!: string;
17
+
18
+ @column({ type: "string" })
19
+ method: PaymentMethod;
20
+
21
+ @column({ type: "string", nullable: true })
22
+ provider: PaymentProvider | null = null;
23
+
24
+ @column({ type: "string" })
25
+ status: PaymentStatus;
26
+
27
+ @column({ type: "string", nullable: true })
28
+ organizationId: string| null = null
29
+
30
+ // Link a user for debugging
31
+ @column({ type: "string", nullable: true })
32
+ userId: string | null = null;
33
+
34
+ // Link a user for debugging
35
+ @column({ type: "string", nullable: true })
36
+ stripeAccountId: string | null = null;
37
+
38
+ /**
39
+ * Total price
40
+ */
41
+ @column({ type: "integer" })
42
+ price: number;
43
+
44
+ /**
45
+ * Fee paid to the payment provider (if available, otherwise set to 0)
46
+ */
47
+ @column({ type: "integer" })
48
+ transferFee = 0
49
+
50
+ /**
51
+ * Included in the total price
52
+ */
53
+ @column({ type: "integer", nullable: true })
54
+ freeContribution: number | null = null;
55
+
56
+ @column({ type: "string", nullable: true })
57
+ transferDescription: string | null = null;
58
+
59
+ @column({ type: "json", nullable: true, decoder: TransferSettings })
60
+ transferSettings: TransferSettings | null = null;
61
+
62
+ @column({
63
+ type: "datetime", beforeSave(old?: any) {
64
+ if (old !== undefined) {
65
+ return old;
66
+ }
67
+ const date = new Date()
68
+ date.setMilliseconds(0)
69
+ return date
70
+ }
71
+ })
72
+ createdAt: Date
73
+
74
+ _forceUpdatedAt: Date | null = null
75
+
76
+ @column({
77
+ type: "datetime", beforeSave() {
78
+ if (this._forceUpdatedAt) {
79
+ return this._forceUpdatedAt
80
+ }
81
+ const date = new Date()
82
+ date.setMilliseconds(0)
83
+ return date
84
+ },
85
+ skipUpdate: true
86
+ })
87
+ updatedAt: Date
88
+
89
+ @column({ type: "datetime", nullable: true })
90
+ paidAt: Date | null = null
91
+
92
+ /// Settlement meta data
93
+ @column({ type: "json", decoder: Settlement, nullable: true })
94
+ settlement: Settlement | null = null;
95
+
96
+ @column({ type: "string", nullable: true })
97
+ iban: string | null = null;
98
+
99
+ @column({ type: "string", nullable: true })
100
+ ibanName: string | null = null;
101
+
102
+ generateDescription(organization: Organization, reference: string, replacements: { [key: string]: string } = {}) {
103
+ const settings = this.transferSettings ?? organization.meta.transferSettings
104
+ this.transferDescription = settings.generateDescription(reference, organization.address.country, replacements)
105
+ }
106
+
107
+ static async getGeneralStructure(payments: Payment[], includeSettlements = false): Promise<PaymentGeneral[]> {
108
+ if (payments.length === 0) {
109
+ return []
110
+ }
111
+
112
+ const {balanceItemPayments, balanceItems} = await Payment.loadBalanceItems(payments)
113
+ const {registrations, orders, members, groups} = await Payment.loadBalanceItemRelations(balanceItems);
114
+
115
+ return this.getGeneralStructureFromRelations({
116
+ payments,
117
+ registrations,
118
+ orders,
119
+ members,
120
+ balanceItemPayments,
121
+ balanceItems,
122
+ groups
123
+ }, includeSettlements)
124
+ }
125
+
126
+ static getGeneralStructureFromRelations({payments, registrations, orders, members, balanceItemPayments, balanceItems, groups}: {
127
+ payments: Payment[];
128
+ registrations: import("./Registration").Registration[];
129
+ orders: import("./Order").Order[];
130
+ members: import("./Member").Member[];
131
+ balanceItemPayments: import("./BalanceItemPayment").BalanceItemPayment[];
132
+ balanceItems: import("./BalanceItem").BalanceItem[];
133
+ groups: import("./Group").Group[];
134
+ }, includeSettlements = false): PaymentGeneral[] {
135
+ if (payments.length === 0) {
136
+ return []
137
+ }
138
+
139
+ return payments.map(payment => {
140
+ return PaymentGeneral.create({
141
+ ...payment,
142
+ balanceItemPayments: balanceItemPayments.filter(item => item.paymentId === payment.id).map((item) => {
143
+ const balanceItem = balanceItems.find(b => b.id === item.balanceItemId)
144
+ const registration = balanceItem?.registrationId && registrations.find(r => r.id === balanceItem.registrationId)
145
+ const member = balanceItem?.memberId ? members.find(r => r.id === balanceItem.memberId) : undefined
146
+ const order = balanceItem?.orderId && orders.find(r => r.id === balanceItem.orderId)
147
+ const group = registration && groups.find(g => g.id === registration.groupId)
148
+
149
+ if (!group) {
150
+ throw new Error("Group not found")
151
+ }
152
+
153
+ return BalanceItemPaymentDetailed.create({
154
+ ...item,
155
+ balanceItem: BalanceItemDetailed.create({
156
+ ...balanceItem,
157
+ registration: registration ? registration.setRelation(Registration.group, group).getStructure() : null,
158
+ member: member ? MemberStruct.create(member) : null,
159
+ order: order ? OrderStruct.create({...order, payment: null}) : null
160
+ })
161
+ })
162
+ }),
163
+ ...(!includeSettlements) ? {settlement: null, transferFee: 0, stripeAccountId: null} : {}
164
+ })
165
+ })
166
+ }
167
+
168
+ /**
169
+ *
170
+ * @param checkPermissions Only set to undefined when not returned in the API + not for public use
171
+ * @returns
172
+ */
173
+ async getGeneralStructure(): Promise<PaymentGeneral> {
174
+ return (await Payment.getGeneralStructure([this], false))[0]
175
+ }
176
+
177
+ static async loadBalanceItems(payments: Payment[]) {
178
+ if (payments.length === 0) {
179
+ return {balanceItemPayments: [], balanceItems: []}
180
+ }
181
+ const {BalanceItemPayment} = await import("./BalanceItemPayment");
182
+ const {BalanceItem} = await import("./BalanceItem");
183
+
184
+ // Load all the related models from the database so we can build the structures
185
+ const balanceItemPayments = await BalanceItemPayment.where({
186
+ paymentId: {
187
+ sign: 'IN',
188
+ value: payments.map(p => p.id)
189
+ }
190
+ })
191
+ const ids = Formatter.uniqueArray(balanceItemPayments.flatMap(p => p.balanceItemId));
192
+ const balanceItems = await BalanceItem.getByIDs(...ids);
193
+
194
+ return {balanceItemPayments, balanceItems}
195
+ }
196
+
197
+ static async loadBalanceItemRelations(balanceItems: import("./BalanceItem").BalanceItem[]) {
198
+ const {Registration} = await import("./Registration");
199
+ const {Order} = await import("./Order");
200
+ const {Member} = await import("./Member");
201
+
202
+ // Load members and orders
203
+ const registrationIds = Formatter.uniqueArray(balanceItems.flatMap(b => b.registrationId ? [b.registrationId] : []))
204
+ const orderIds = Formatter.uniqueArray(balanceItems.flatMap(b => b.orderId ? [b.orderId] : []))
205
+ const memberIds = Formatter.uniqueArray(balanceItems.flatMap(b => b.memberId ? [b.memberId] : []))
206
+
207
+ const registrations = await Registration.getByIDs(...registrationIds)
208
+ const orders = await Order.getByIDs(...orderIds)
209
+ const members = await Member.getByIDs(...memberIds)
210
+
211
+ const groupIds = Formatter.uniqueArray(registrations.map(r => r.groupId))
212
+ const groups = await (await import("./Group")).Group.getByIDs(...groupIds)
213
+
214
+ return {registrations, orders, members, groups}
215
+ }
216
+ }