@stamhoofd/backend 2.118.1 → 2.120.0

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 (362) hide show
  1. package/package.json +32 -22
  2. package/src/audit-logs/ModelLogger.ts +4 -2
  3. package/src/audit-logs/OrderLogger.ts +1 -1
  4. package/src/boot.ts +32 -14
  5. package/src/crons/balance-emails.ts +4 -2
  6. package/src/crons/clearExcelCache.test.ts +8 -8
  7. package/src/crons/update-cached-balances.ts +40 -14
  8. package/src/debug.ts +3 -2
  9. package/src/decoders/StringArrayDecoder.ts +1 -1
  10. package/src/decoders/StringNullableDecoder.ts +1 -1
  11. package/src/email-recipient-loaders/documents.ts +2 -1
  12. package/src/email-recipient-loaders/members.ts +2 -1
  13. package/src/email-recipient-loaders/orders.ts +2 -1
  14. package/src/email-recipient-loaders/payments.ts +6 -3
  15. package/src/email-recipient-loaders/receivable-balances.ts +2 -1
  16. package/src/email-recipient-loaders/registrations.ts +2 -1
  17. package/src/email-replacements/getEmailReplacementsForPayment.ts +8 -7
  18. package/src/endpoints/admin/members/ChargeMembersEndpoint.ts +7 -6
  19. package/src/endpoints/admin/memberships/ChargeMembershipsEndpoint.ts +3 -2
  20. package/src/endpoints/admin/memberships/GetChargeMembershipsSummaryEndpoint.ts +2 -1
  21. package/src/endpoints/admin/organizations/ChargeOrganizationsEndpoint.ts +4 -3
  22. package/src/endpoints/admin/organizations/GetOrganizationsCountEndpoint.ts +3 -2
  23. package/src/endpoints/admin/organizations/GetOrganizationsEndpoint.ts +7 -5
  24. package/src/endpoints/admin/organizations/PatchOrganizationsEndpoint.ts +12 -10
  25. package/src/endpoints/admin/registrations/ChargeRegistrationsEndpoint.ts +4 -3
  26. package/src/endpoints/auth/CreateAdminEndpoint.ts +8 -6
  27. package/src/endpoints/auth/CreateTokenEndpoint.ts +14 -12
  28. package/src/endpoints/auth/DeleteTokenEndpoint.ts +2 -1
  29. package/src/endpoints/auth/DeleteUserEndpoint.ts +2 -1
  30. package/src/endpoints/auth/ForgotPasswordEndpoint.ts +5 -4
  31. package/src/endpoints/auth/GetOtherUserEndpoint.ts +3 -2
  32. package/src/endpoints/auth/GetUserEndpoint.ts +3 -2
  33. package/src/endpoints/auth/OpenIDConnectAuthTokenEndpoint.ts +2 -1
  34. package/src/endpoints/auth/OpenIDConnectCallbackEndpoint.ts +4 -2
  35. package/src/endpoints/auth/OpenIDConnectStartEndpoint.ts +3 -2
  36. package/src/endpoints/auth/PatchUserEndpoint.ts +15 -12
  37. package/src/endpoints/auth/PollEmailVerificationEndpoint.ts +3 -2
  38. package/src/endpoints/auth/RetryEmailVerificationEndpoint.ts +3 -2
  39. package/src/endpoints/auth/SignupEndpoint.ts +5 -4
  40. package/src/endpoints/auth/VerifyEmailEndpoint.ts +6 -5
  41. package/src/endpoints/frontend/FrontendEnvironmentEndpoint.ts +3 -2
  42. package/src/endpoints/global/addresses/SearchRegionsEndpoint.ts +8 -5
  43. package/src/endpoints/global/addresses/ValidateAddressEndpoint.ts +5 -3
  44. package/src/endpoints/global/audit-logs/GetAuditLogsEndpoint.ts +8 -5
  45. package/src/endpoints/global/billing/ActivatePackagesEndpoint.ts +9 -7
  46. package/src/endpoints/global/billing/DeactivatePackageEndpoint.ts +4 -3
  47. package/src/endpoints/global/caddy/CheckDomainCertEndpoint.ts +4 -2
  48. package/src/endpoints/global/email/CreateEmailEndpoint.ts +9 -7
  49. package/src/endpoints/global/email/GetAdminEmailsEndpoint.test.ts +2 -1
  50. package/src/endpoints/global/email/GetAdminEmailsEndpoint.ts +22 -19
  51. package/src/endpoints/global/email/GetEmailAddressEndpoint.ts +6 -4
  52. package/src/endpoints/global/email/GetEmailEndpoint.ts +4 -3
  53. package/src/endpoints/global/email/GetUserEmailsEndpoint.test.ts +3 -2
  54. package/src/endpoints/global/email/GetUserEmailsEndpoint.ts +7 -4
  55. package/src/endpoints/global/email/ManageEmailAddressEndpoint.ts +7 -5
  56. package/src/endpoints/global/email/PatchEmailEndpoint.test.ts +11 -11
  57. package/src/endpoints/global/email/PatchEmailEndpoint.ts +14 -11
  58. package/src/endpoints/global/email-recipients/GetEmailRecipientsCountEndpoint.ts +3 -2
  59. package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.test.ts +2 -1
  60. package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.ts +8 -5
  61. package/src/endpoints/global/email-recipients/RetryEmailRecipientEndpoint.ts +7 -5
  62. package/src/endpoints/global/email-recipients/helpers/validateEmailRecipientFilter.ts +4 -3
  63. package/src/endpoints/global/events/GetEventNotificationsCountEndpoint.ts +3 -2
  64. package/src/endpoints/global/events/GetEventNotificationsEndpoint.ts +9 -6
  65. package/src/endpoints/global/events/GetEventsEndpoint.ts +7 -4
  66. package/src/endpoints/global/events/PatchEventNotificationsEndpoint.test.ts +4 -2
  67. package/src/endpoints/global/events/PatchEventNotificationsEndpoint.ts +17 -15
  68. package/src/endpoints/global/events/PatchEventsEndpoint.test.ts +4 -2
  69. package/src/endpoints/global/events/PatchEventsEndpoint.ts +28 -26
  70. package/src/endpoints/global/files/ExportToExcelEndpoint.ts +8 -5
  71. package/src/endpoints/global/files/GetFileCache.ts +5 -3
  72. package/src/endpoints/global/files/UploadFile.ts +10 -4
  73. package/src/endpoints/global/files/UploadImage.ts +4 -2
  74. package/src/endpoints/global/groups/GetGroupsEndpoint.test.ts +4 -2
  75. package/src/endpoints/global/groups/GetGroupsEndpoint.ts +8 -5
  76. package/src/endpoints/global/members/GetMemberFamilyEndpoint.ts +7 -5
  77. package/src/endpoints/global/members/GetMembersCountEndpoint.ts +3 -2
  78. package/src/endpoints/global/members/GetMembersEndpoint.test.ts +4 -2
  79. package/src/endpoints/global/members/GetMembersEndpoint.ts +10 -8
  80. package/src/endpoints/global/members/PatchOrganizationMembersEndpoint.test.ts +257 -6
  81. package/src/endpoints/global/members/PatchOrganizationMembersEndpoint.ts +162 -107
  82. package/src/endpoints/global/members/helpers/validateGroupFilter.ts +4 -3
  83. package/src/endpoints/global/members/shouldCheckIfMemberIsDuplicate.ts +3 -2
  84. package/src/endpoints/global/organizations/CheckRegisterCodeEndpoint.ts +3 -2
  85. package/src/endpoints/global/organizations/CreateOrganizationEndpoint.test.ts +3 -2
  86. package/src/endpoints/global/organizations/CreateOrganizationEndpoint.ts +8 -7
  87. package/src/endpoints/global/organizations/GetOrganizationFromDomainEndpoint.ts +5 -3
  88. package/src/endpoints/global/organizations/GetOrganizationFromUriEndpoint.ts +5 -3
  89. package/src/endpoints/global/organizations/SearchOrganizationEndpoint.ts +8 -5
  90. package/src/endpoints/global/payments/StripeWebhookEndpoint.ts +4 -2
  91. package/src/endpoints/global/platform/GetPlatformAdminsEndpoint.ts +2 -1
  92. package/src/endpoints/global/platform/GetPlatformEndpoint.ts +3 -2
  93. package/src/endpoints/global/platform/PatchPlatformEnpoint.test.ts +3 -2
  94. package/src/endpoints/global/platform/PatchPlatformEnpoint.ts +7 -4
  95. package/src/endpoints/global/platform-memberships/GetPlatformMembershipsCountEndpoint.ts +47 -0
  96. package/src/endpoints/global/platform-memberships/GetPlatformMembershipsEndpoint.ts +206 -0
  97. package/src/endpoints/global/registration/GetRegistrationsCountEndpoint.ts +3 -2
  98. package/src/endpoints/global/registration/GetRegistrationsEndpoint.test.ts +2 -1
  99. package/src/endpoints/global/registration/GetRegistrationsEndpoint.ts +10 -7
  100. package/src/endpoints/global/registration/GetUserDetailedPayableBalanceEndpoint.ts +4 -2
  101. package/src/endpoints/global/registration/GetUserDocumentsEndpoint.ts +4 -2
  102. package/src/endpoints/global/registration/GetUserMembersEndpoint.ts +3 -2
  103. package/src/endpoints/global/registration/GetUserPayableBalanceEndpoint.ts +2 -1
  104. package/src/endpoints/global/registration/PatchUserMembersEndpoint.test.ts +5 -3
  105. package/src/endpoints/global/registration/PatchUserMembersEndpoint.ts +13 -9
  106. package/src/endpoints/global/registration/RegisterMembersEndpoint.test.ts +50 -49
  107. package/src/endpoints/global/registration/RegisterMembersEndpoint.ts +25 -22
  108. package/src/endpoints/global/registration-periods/GetRegistrationPeriodsEndpoint.ts +8 -5
  109. package/src/endpoints/global/registration-periods/PatchRegistrationPeriodsEndpoint.ts +9 -7
  110. package/src/endpoints/global/sso/GetSSOEndpoint.ts +4 -2
  111. package/src/endpoints/global/sso/SetSSOEndpoint.ts +3 -2
  112. package/src/endpoints/global/webshops/GetWebshopFromDomainEndpoint.ts +4 -2
  113. package/src/endpoints/global/webshops/GetWebshopsCountEndpoint.ts +43 -0
  114. package/src/endpoints/global/webshops/GetWebshopsEndpoint.test.ts +808 -0
  115. package/src/endpoints/global/webshops/GetWebshopsEndpoint.ts +221 -0
  116. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemEndpoint.ts +4 -3
  117. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsCountEndpoint.ts +3 -2
  118. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsEndpoint.ts +6 -4
  119. package/src/endpoints/organization/dashboard/balance-items/PatchBalanceItemsEndpoint.ts +15 -13
  120. package/src/endpoints/organization/dashboard/billing/GetOrganizationDetailedPayableBalanceEndpoint.ts +4 -2
  121. package/src/endpoints/organization/dashboard/billing/GetOrganizationPayableBalanceEndpoint.ts +4 -2
  122. package/src/endpoints/organization/dashboard/billing/GetPackagesEndpoint.ts +2 -1
  123. package/src/endpoints/organization/dashboard/documents/GetDocumentTemplateXML.ts +3 -2
  124. package/src/endpoints/organization/dashboard/documents/GetDocumentTemplatesCountEndpoint.ts +3 -2
  125. package/src/endpoints/organization/dashboard/documents/GetDocumentTemplatesEndpoint.ts +7 -4
  126. package/src/endpoints/organization/dashboard/documents/GetDocumentsCountEndpoint.ts +3 -2
  127. package/src/endpoints/organization/dashboard/documents/GetDocumentsEndpoint.ts +7 -4
  128. package/src/endpoints/organization/dashboard/documents/PatchDocumentEndpoint.ts +9 -7
  129. package/src/endpoints/organization/dashboard/documents/PatchDocumentTemplatesEndpoint.test.ts +4 -2
  130. package/src/endpoints/organization/dashboard/documents/PatchDocumentTemplatesEndpoint.ts +7 -5
  131. package/src/endpoints/organization/dashboard/email/CheckEmailBouncesEndpoint.ts +3 -2
  132. package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.test.ts +36 -1
  133. package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.ts +13 -4
  134. package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.test.ts +4 -2
  135. package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.ts +7 -5
  136. package/src/endpoints/organization/dashboard/invoices/GetInvoicesCountEndpoint.ts +3 -2
  137. package/src/endpoints/organization/dashboard/invoices/GetInvoicesEndpoint.ts +6 -4
  138. package/src/endpoints/organization/dashboard/invoices/PatchInvoicesEndpoint.ts +5 -3
  139. package/src/endpoints/organization/dashboard/mollie/CheckMollieEndpoint.ts +4 -2
  140. package/src/endpoints/organization/dashboard/mollie/ConnectMollieEndpoint.ts +6 -3
  141. package/src/endpoints/organization/dashboard/mollie/DisconnectMollieEndpoint.ts +4 -2
  142. package/src/endpoints/organization/dashboard/mollie/GetMollieDashboardEndpoint.ts +2 -1
  143. package/src/endpoints/organization/dashboard/nolt/CreateNoltTokenEndpoint.ts +2 -1
  144. package/src/endpoints/organization/dashboard/organization/GetOrganizationArchivedGroups.ts +4 -2
  145. package/src/endpoints/organization/dashboard/organization/GetOrganizationDeletedGroups.ts +3 -2
  146. package/src/endpoints/organization/dashboard/organization/GetUitpasClientIdEndpoint.ts +2 -1
  147. package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.test.ts +5 -3
  148. package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.ts +22 -19
  149. package/src/endpoints/organization/dashboard/organization/SearchUitpasOrganizersEndpoint.ts +5 -3
  150. package/src/endpoints/organization/dashboard/organization/SetOrganizationDomainEndpoint.ts +11 -9
  151. package/src/endpoints/organization/dashboard/organization/SetUitpasClientCredentialsEndpoint.ts +8 -7
  152. package/src/endpoints/organization/dashboard/payments/GetMemberBalanceEndpoint.ts +2 -1
  153. package/src/endpoints/organization/dashboard/payments/GetPaymentsCountEndpoint.ts +3 -2
  154. package/src/endpoints/organization/dashboard/payments/GetPaymentsEndpoint.ts +7 -5
  155. package/src/endpoints/organization/dashboard/payments/PatchPaymentsEndpoint.ts +18 -16
  156. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalanceEndpoint.ts +2 -1
  157. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesCountEndpoint.ts +3 -2
  158. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesEndpoint.ts +5 -3
  159. package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.test.ts +2 -1
  160. package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.ts +8 -5
  161. package/src/endpoints/organization/dashboard/registration-periods/MoveRegistrationPeriods.test.ts +4 -2
  162. package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.test.ts +4 -2
  163. package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.ts +32 -29
  164. package/src/endpoints/organization/dashboard/registration-periods/SetupStepReviewEndpoint.ts +6 -3
  165. package/src/endpoints/organization/dashboard/stripe/ConnectStripeEndpoint.ts +3 -2
  166. package/src/endpoints/organization/dashboard/stripe/DeleteStripeAccountEndpoint.ts +3 -2
  167. package/src/endpoints/organization/dashboard/stripe/GetStripeAccountLinkEndpoint.ts +5 -3
  168. package/src/endpoints/organization/dashboard/stripe/GetStripeAccountsEndpoint.ts +2 -1
  169. package/src/endpoints/organization/dashboard/stripe/GetStripeLoginLinkEndpoint.ts +5 -3
  170. package/src/endpoints/organization/dashboard/stripe/UpdateStripeAccountEndpoint.ts +3 -2
  171. package/src/endpoints/organization/dashboard/users/CreateApiUserEndpoint.ts +4 -3
  172. package/src/endpoints/organization/dashboard/users/DeleteUserEndpoint.ts +4 -3
  173. package/src/endpoints/organization/dashboard/users/GetApiUsersEndpoint.ts +3 -2
  174. package/src/endpoints/organization/dashboard/users/GetOrganizationAdminsEndpoint.ts +2 -1
  175. package/src/endpoints/organization/dashboard/users/PatchApiUserEndpoint.ts +6 -4
  176. package/src/endpoints/organization/dashboard/webshops/CreateWebshopEndpoint.ts +7 -6
  177. package/src/endpoints/organization/dashboard/webshops/DeleteWebshopEndpoint.ts +3 -2
  178. package/src/endpoints/organization/dashboard/webshops/GetDiscountCodesEndpoint.ts +4 -2
  179. package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersCountEndpoint.ts +3 -2
  180. package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersEndpoint.ts +7 -4
  181. package/src/endpoints/organization/dashboard/webshops/{GetWebshopTicketsCountEndpoint → GetWebshopTicketsCountEndpoint.ts} +7 -7
  182. package/src/endpoints/organization/dashboard/webshops/GetWebshopTicketsEndpoint.ts +9 -6
  183. package/src/endpoints/organization/dashboard/webshops/GetWebshopUriAvailabilityEndpoint.ts +4 -2
  184. package/src/endpoints/organization/dashboard/webshops/PatchDiscountCodesEndpoint.ts +6 -4
  185. package/src/endpoints/organization/dashboard/webshops/PatchWebshopEndpoint.ts +13 -12
  186. package/src/endpoints/organization/dashboard/webshops/PatchWebshopOrdersEndpoint.ts +4 -2
  187. package/src/endpoints/organization/dashboard/webshops/PatchWebshopTicketsEndpoint.ts +5 -3
  188. package/src/endpoints/organization/dashboard/webshops/SearchUitpasEventsEndpoint.ts +6 -4
  189. package/src/endpoints/organization/dashboard/webshops/VerifyWebshopDomainEndpoint.ts +2 -1
  190. package/src/endpoints/organization/shared/ExchangePaymentEndpoint.ts +6 -4
  191. package/src/endpoints/organization/shared/GetDocumentHtml.ts +4 -3
  192. package/src/endpoints/organization/shared/GetPaymentEndpoint.ts +4 -3
  193. package/src/endpoints/organization/shared/GetUitpasNumberDetailsEndpoint.ts +3 -2
  194. package/src/endpoints/organization/shared/auth/GetOrganizationEndpoint.ts +3 -2
  195. package/src/endpoints/organization/webshops/CheckWebshopDiscountCodesEndpoint.ts +4 -3
  196. package/src/endpoints/organization/webshops/GetOrderByPaymentEndpoint.ts +5 -4
  197. package/src/endpoints/organization/webshops/GetOrderEndpoint.ts +4 -3
  198. package/src/endpoints/organization/webshops/GetTicketsEndpoint.ts +7 -5
  199. package/src/endpoints/organization/webshops/GetWebshopEndpoint.ts +4 -3
  200. package/src/endpoints/organization/webshops/PlaceOrderEndpoint.test.ts +7 -3
  201. package/src/endpoints/organization/webshops/PlaceOrderEndpoint.ts +11 -10
  202. package/src/endpoints/organization/webshops/RetrieveUitpasSocialTariffPriceEndpoint.ts +5 -4
  203. package/src/endpoints/system/HealthEndpoint.test.ts +44 -0
  204. package/src/endpoints/system/HealthEndpoint.ts +14 -6
  205. package/src/excel-loaders/balance-items.ts +19 -17
  206. package/src/excel-loaders/event-notifications.ts +15 -13
  207. package/src/excel-loaders/index.ts +1 -0
  208. package/src/excel-loaders/members.ts +45 -43
  209. package/src/excel-loaders/organizations.ts +26 -25
  210. package/src/excel-loaders/payments.ts +44 -42
  211. package/src/excel-loaders/platform-memberships.ts +202 -0
  212. package/src/excel-loaders/receivable-balances.ts +25 -23
  213. package/src/excel-loaders/registrations.ts +30 -28
  214. package/src/helpers/AddressValidator.test.ts +2 -1
  215. package/src/helpers/AddressValidator.ts +13 -10
  216. package/src/helpers/AdminPermissionChecker.ts +193 -95
  217. package/src/helpers/AuthenticatedStructures.ts +13 -11
  218. package/src/helpers/BuckarooHelper.ts +3 -2
  219. package/src/helpers/Context.ts +8 -6
  220. package/src/helpers/CookieHelper.ts +2 -2
  221. package/src/helpers/FileCache.ts +9 -9
  222. package/src/helpers/ForwardHandler.ts +3 -2
  223. package/src/helpers/GlobalHelper.ts +2 -0
  224. package/src/helpers/GroupBuilder.ts +2 -1
  225. package/src/helpers/GroupedThrottledQueue.test.ts +19 -19
  226. package/src/helpers/LimitedFilteredRequestHelper.ts +1 -1
  227. package/src/helpers/MemberCharger.ts +2 -1
  228. package/src/helpers/MemberUserSyncer.ts +6 -3
  229. package/src/helpers/MembershipCharger.ts +2 -2
  230. package/src/helpers/OrganizationCharger.ts +2 -1
  231. package/src/helpers/PeriodHelper.ts +2 -1
  232. package/src/helpers/SQLTranslatedString.ts +3 -2
  233. package/src/helpers/ServiceFeeHelper.ts +1 -1
  234. package/src/helpers/SetupStepUpdater.ts +6 -5
  235. package/src/helpers/StripeHelper.ts +9 -8
  236. package/src/helpers/TagHelper.test.ts +5 -5
  237. package/src/helpers/TagHelper.ts +2 -1
  238. package/src/helpers/TemporaryMemberAccess.ts +2 -1
  239. package/src/helpers/ThrottledQueue.test.ts +20 -20
  240. package/src/helpers/UitpasTokenRepository.ts +7 -7
  241. package/src/helpers/ViesHelper.ts +5 -4
  242. package/src/helpers/XlsxTransformerColumnHelper.ts +21 -19
  243. package/src/helpers/email-html-helpers.ts +13 -12
  244. package/src/helpers/fetchToAsyncIterator.ts +1 -1
  245. package/src/helpers/outstandingBalanceJoin.ts +2 -1
  246. package/src/helpers/updateMemberDetailsUitpasNumber.ts +5 -4
  247. package/src/middleware/ContextMiddleware.ts +1 -1
  248. package/src/migrate.ts +21 -4
  249. package/src/seeds/0000000003-default-email-templates.ts +1 -1
  250. package/src/seeds/0000000004-single-organization.ts +2 -1
  251. package/src/seeds/1752848561-groups-registration-periods.ts +3 -2
  252. package/src/seeds/1754560914-groups-prices.test.ts +2 -1
  253. package/src/seeds/1754560914-groups-prices.ts +2 -1
  254. package/src/seeds/1755790070-fill-email-recipient-errors.ts +6 -6
  255. package/src/seeds/1755876819-remove-duplicate-members.ts +2 -1
  256. package/src/seeds/1765896674-document-update-year.test.ts +2 -1
  257. package/src/seeds/1773754928-force-save-members.ts +15 -0
  258. package/src/services/AuditLogService.ts +3 -2
  259. package/src/services/BalanceItemPaymentService.ts +2 -2
  260. package/src/services/BalanceItemService.ts +2 -1
  261. package/src/services/BootChecksService.test.ts +33 -0
  262. package/src/services/BootChecksService.ts +21 -0
  263. package/src/services/DatabaseCollationService.test.ts +18 -0
  264. package/src/services/DatabaseCollationService.ts +81 -0
  265. package/src/services/DocumentService.ts +1 -1
  266. package/src/services/EventNotificationService.ts +5 -4
  267. package/src/services/FileSignService.ts +2 -2
  268. package/src/services/InvoiceService.ts +3 -3
  269. package/src/services/MemberNumberService.ts +6 -4
  270. package/src/services/MemberRecordStore.ts +28 -19
  271. package/src/services/PaymentReallocationService.test.ts +2 -1
  272. package/src/services/PaymentReallocationService.ts +2 -1
  273. package/src/services/PaymentService.ts +28 -26
  274. package/src/services/RegistrationService.ts +65 -3
  275. package/src/services/SSOService.ts +13 -9
  276. package/src/services/STPackageService.ts +7 -5
  277. package/src/services/StartupHealthService.ts +15 -0
  278. package/src/services/uitpas/PassholderEndpoints.ts +2 -2
  279. package/src/services/uitpas/UitpasService.ts +11 -8
  280. package/src/services/uitpas/cancelTicketSales.ts +1 -1
  281. package/src/services/uitpas/checkPermissionsFor.ts +9 -9
  282. package/src/services/uitpas/getSocialTariffForEvent.ts +4 -4
  283. package/src/services/uitpas/getSocialTariffForUitpasNumbers.ts +5 -5
  284. package/src/services/uitpas/handleUitpasResponse.ts +1 -1
  285. package/src/services/uitpas/registerTicketSales.ts +4 -4
  286. package/src/services/uitpas/searchUitpasEvents.ts +3 -3
  287. package/src/services/uitpas/searchUitpasOrganizers.ts +3 -3
  288. package/src/sql-filters/audit-logs.ts +2 -1
  289. package/src/sql-filters/balance-item-payments.ts +2 -1
  290. package/src/sql-filters/balance-items.ts +2 -1
  291. package/src/sql-filters/base-registration-filter-compilers.ts +6 -4
  292. package/src/sql-filters/document-templates.ts +2 -1
  293. package/src/sql-filters/documents.ts +2 -1
  294. package/src/sql-filters/email-recipients.ts +2 -1
  295. package/src/sql-filters/emails.ts +2 -1
  296. package/src/sql-filters/event-notifications.ts +2 -1
  297. package/src/sql-filters/events.ts +2 -1
  298. package/src/sql-filters/groups.ts +2 -1
  299. package/src/sql-filters/invoiced-balance-items.ts +2 -1
  300. package/src/sql-filters/invoices.ts +2 -1
  301. package/src/sql-filters/member-responsibility-records.ts +2 -1
  302. package/src/sql-filters/members.ts +8 -7
  303. package/src/sql-filters/orders.ts +3 -2
  304. package/src/sql-filters/organization-registration-periods.ts +2 -1
  305. package/src/sql-filters/organizations.ts +2 -1
  306. package/src/sql-filters/payments.ts +2 -1
  307. package/src/sql-filters/platform-memberships.ts +67 -0
  308. package/src/sql-filters/receivable-balances.ts +2 -1
  309. package/src/sql-filters/registration-periods.ts +2 -1
  310. package/src/sql-filters/registrations.ts +2 -1
  311. package/src/sql-filters/tickets.ts +2 -1
  312. package/src/sql-filters/users.ts +2 -1
  313. package/src/sql-filters/webshops.ts +38 -0
  314. package/src/sql-sorters/audit-logs.ts +3 -2
  315. package/src/sql-sorters/balance-items.ts +3 -2
  316. package/src/sql-sorters/document-templates.ts +3 -2
  317. package/src/sql-sorters/documents.ts +3 -2
  318. package/src/sql-sorters/email-recipients.ts +3 -2
  319. package/src/sql-sorters/emails.ts +3 -2
  320. package/src/sql-sorters/event-notifications.ts +3 -2
  321. package/src/sql-sorters/events.ts +3 -2
  322. package/src/sql-sorters/groups.ts +3 -2
  323. package/src/sql-sorters/invoices.ts +3 -2
  324. package/src/sql-sorters/members.ts +3 -2
  325. package/src/sql-sorters/orders.ts +3 -2
  326. package/src/sql-sorters/organization-registration-periods.ts +3 -2
  327. package/src/sql-sorters/organizations.ts +3 -2
  328. package/src/sql-sorters/payments.ts +3 -2
  329. package/src/sql-sorters/platform-memberships.ts +40 -0
  330. package/src/sql-sorters/receivable-balances.ts +3 -2
  331. package/src/sql-sorters/registration-periods.ts +3 -2
  332. package/src/sql-sorters/registrations.ts +3 -2
  333. package/src/sql-sorters/tickets.ts +3 -2
  334. package/src/sql-sorters/webshops.ts +40 -0
  335. package/tests/actions/patchOrganizationMember.ts +5 -4
  336. package/tests/actions/patchPaymentStatus.ts +2 -2
  337. package/tests/actions/patchUserMember.ts +6 -4
  338. package/tests/e2e/api-rate-limits.test.ts +4 -5
  339. package/tests/e2e/bundle-discounts.test.ts +3 -2
  340. package/tests/e2e/charge-members.test.ts +7 -5
  341. package/tests/e2e/documents.test.ts +3 -2
  342. package/tests/e2e/private-files.test.ts +11 -13
  343. package/tests/e2e/register.test.ts +6 -5
  344. package/tests/e2e/stock.test.ts +6 -8
  345. package/tests/e2e/tickets.test.ts +4 -2
  346. package/tests/helpers/StripeMocker.ts +3 -3
  347. package/tests/init/initAdmin.ts +4 -2
  348. package/tests/init/initBundleDiscount.ts +3 -2
  349. package/tests/init/initPayconiq.ts +1 -1
  350. package/tests/init/initPermissionRole.ts +4 -2
  351. package/tests/init/initPlatformRecordCategory.ts +1 -1
  352. package/tests/init/initStripe.ts +1 -1
  353. package/tests/vitest.global.setup.ts +26 -0
  354. package/tests/{jest.setup.ts → vitest.setup.ts} +4 -3
  355. package/tsconfig.build.json +17 -0
  356. package/tsconfig.json +10 -41
  357. package/tsconfig.test.json +17 -0
  358. package/vitest.config.js +13 -0
  359. package/eslint.config.mjs +0 -5
  360. package/jest.config.cjs +0 -27
  361. package/tests/jest.global.setup.ts +0 -33
  362. package/tests/toMatchMap.ts +0 -68
@@ -1,6 +1,7 @@
1
1
  import { SimpleError } from '@simonbackx/simple-errors';
2
2
  import { Email, Member, MemberUser } from '@stamhoofd/models';
3
- import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, createWildcardColumnFilter, SQL, SQLAge, SQLCast, SQLConcat, SQLFilterDefinitions, SQLJsonExtract, SQLScalar, SQLValueType } from '@stamhoofd/sql';
3
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
4
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, createWildcardColumnFilter, SQL, SQLAge, SQLCast, SQLConcat, SQLJsonExtract, SQLScalar, SQLValueType } from '@stamhoofd/sql';
4
5
  import { AccessRight } from '@stamhoofd/structures';
5
6
  import { Context } from '../helpers/Context.js';
6
7
  import { baseRegistrationFilterCompilers } from './base-registration-filter-compilers.js';
@@ -453,14 +454,14 @@ export const memberFilterCompilers: SQLFilterDefinitions = {
453
454
  throw new SimpleError({
454
455
  code: 'not_found',
455
456
  message: 'This email does not exist.',
456
- human: $t('491156e4-a75d-4487-a97e-b208cd3a1d11'),
457
+ human: $t('%1E5'),
457
458
  statusCode: 404,
458
459
  });
459
460
  }
460
461
  if (!await Context.auth.canAccessEmail(email)) {
461
462
  throw Context.auth.error({
462
463
  message: 'No permissions to access this email.',
463
- human: $t('be46002c-d77e-42ca-b163-23bde0bc628c'),
464
+ human: $t('%1E6'),
464
465
  });
465
466
  }
466
467
  },
@@ -500,7 +501,7 @@ export const memberFilterCompilers: SQLFilterDefinitions = {
500
501
  },
501
502
  value: createColumnFilter({
502
503
  expression: SQL.jsonExtract(SQL.column('details'), `$.value.recordAnswers.${SQLJsonExtract.escapePathComponent(key)}.value`, true),
503
- type: SQLValueType.JSONString,
504
+ type: SQLValueType.JSONScalar, // Can be string, number or boolean
504
505
  nullable: true,
505
506
  }),
506
507
  }),
@@ -511,7 +512,7 @@ export const memberFilterCompilers: SQLFilterDefinitions = {
511
512
  throw new SimpleError({
512
513
  code: 'permission_denied',
513
514
  message: 'No permissions to filter on record ' + key,
514
- human: result.record ? $t(`3560487e-3f2c-4cc9-ad7f-4e9a0fc1bbb8`, { recordName: result.record.name }) : $t(`Je hebt niet voldoende toegangsrechten om te filteren op dit gegevensveld`),
515
+ human: result.record ? $t(`%1Bc`, { recordName: result.record.name }) : $t(`Je hebt niet voldoende toegangsrechten om te filteren op dit gegevensveld`),
515
516
  statusCode: 400,
516
517
  });
517
518
  }
@@ -542,7 +543,7 @@ async function throwIfNoFinancialReadAccess() {
542
543
  throw new SimpleError({
543
544
  code: 'permission_denied',
544
545
  message: 'No permissions for financial support filter.',
545
- human: $t(`64d658fa-0727-4924-9448-b243fe8e10a1`),
546
+ human: $t(`%G2`),
546
547
  statusCode: 400,
547
548
  });
548
549
  }
@@ -555,7 +556,7 @@ async function throwIfNoFinancialReadAccess() {
555
556
  throw new SimpleError({
556
557
  code: 'permission_denied',
557
558
  message: 'No permissions for financial support filter (organization scope).',
558
- human: $t(`64d658fa-0727-4924-9448-b243fe8e10a1`),
559
+ human: $t(`%G2`),
559
560
  statusCode: 400,
560
561
  });
561
562
  }
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, createWildcardColumnFilter, SQL, SQLCast, SQLConcat, SQLFilterDefinitions, SQLJsonExtract, SQLJsonUnquote, SQLScalar, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, createWildcardColumnFilter, SQL, SQLCast, SQLConcat, SQLJsonExtract, SQLJsonUnquote, SQLScalar, SQLValueType } from '@stamhoofd/sql';
2
3
 
3
4
  export const orderFilterCompilers: SQLFilterDefinitions = {
4
5
  ...baseSQLFilterCompilers,
@@ -197,7 +198,7 @@ export const orderFilterCompilers: SQLFilterDefinitions = {
197
198
  },
198
199
  value: createColumnFilter({
199
200
  expression: SQL.jsonExtract(SQL.column('data'), `$.value.recordAnswers.${SQLJsonExtract.escapePathComponent(key)}.value`, true),
200
- type: SQLValueType.JSONString,
201
+ type: SQLValueType.JSONScalar, // Can be string, number or boolean
201
202
  nullable: true,
202
203
  }),
203
204
  }),
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLFilterDefinitions, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLValueType } from '@stamhoofd/sql';
2
3
 
3
4
  export const organizationRegistrationPeriodFilterCompilers: SQLFilterDefinitions = {
4
5
  ...baseSQLFilterCompilers,
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLConcat, SQLFilterDefinitions, SQLNow, SQLNull, SQLScalar, SQLValueType, SQLWhereEqual, SQLWhereOr, SQLWhereSign } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLConcat, SQLNow, SQLNull, SQLScalar, SQLValueType, SQLWhereEqual, SQLWhereOr, SQLWhereSign } from '@stamhoofd/sql';
2
3
  import { SetupStepType } from '@stamhoofd/structures';
3
4
 
4
5
  export const organizationFilterCompilers: SQLFilterDefinitions = {
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLCast, SQLConcat, SQLFilterDefinitions, SQLJsonUnquote, SQLScalar, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLCast, SQLConcat, SQLJsonUnquote, SQLScalar, SQLValueType } from '@stamhoofd/sql';
2
3
  import { balanceItemPaymentsCompilers } from './balance-item-payments.js';
3
4
 
4
5
  /**
@@ -0,0 +1,67 @@
1
+ import { MemberPlatformMembership } from '@stamhoofd/models';
2
+ import type { SQLFilterDefinitions } from '@stamhoofd/sql';
3
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLValueType } from '@stamhoofd/sql';
4
+ import { memberFilterCompilers } from './members.js';
5
+ import { organizationFilterCompilers } from './organizations.js';
6
+
7
+ export const platformMembershipFilterCompilers: SQLFilterDefinitions = {
8
+ ...baseSQLFilterCompilers,
9
+ id: createColumnFilter({
10
+ expression: SQL.column(MemberPlatformMembership.table, 'id'),
11
+ type: SQLValueType.String,
12
+ nullable: false,
13
+ }),
14
+ membershipTypeId: createColumnFilter({
15
+ expression: SQL.column(MemberPlatformMembership.table, 'membershipTypeId'),
16
+ type: SQLValueType.String,
17
+ nullable: false,
18
+ }),
19
+ periodId: createColumnFilter({
20
+ expression: SQL.column(MemberPlatformMembership.table, 'periodId'),
21
+ type: SQLValueType.String,
22
+ nullable: false,
23
+ }),
24
+ startDate: createColumnFilter({
25
+ expression: SQL.column(MemberPlatformMembership.table, 'startDate'),
26
+ type: SQLValueType.Datetime,
27
+ nullable: false,
28
+ }),
29
+ endDate: createColumnFilter({
30
+ expression: SQL.column(MemberPlatformMembership.table, 'endDate'),
31
+ type: SQLValueType.Datetime,
32
+ nullable: false,
33
+ }),
34
+ trialUntil: createColumnFilter({
35
+ expression: SQL.column(MemberPlatformMembership.table, 'trialUntil'),
36
+ type: SQLValueType.Datetime,
37
+ nullable: true,
38
+ }),
39
+ createdAt: createColumnFilter({
40
+ expression: SQL.column(MemberPlatformMembership.table, 'createdAt'),
41
+ type: SQLValueType.Datetime,
42
+ nullable: true,
43
+ }),
44
+ freeAmount: createColumnFilter({
45
+ expression: SQL.column(MemberPlatformMembership.table, 'freeAmount'),
46
+ type: SQLValueType.Number,
47
+ nullable: false,
48
+ }),
49
+ organization: createExistsFilter(
50
+ SQL.select()
51
+ .from(SQL.table('organizations'))
52
+ .where(
53
+ SQL.column('organizations', 'id'),
54
+ SQL.column(MemberPlatformMembership.table, 'organizationId'),
55
+ ),
56
+ organizationFilterCompilers
57
+ ),
58
+ member: createExistsFilter(
59
+ SQL.select()
60
+ .from(SQL.table('members'))
61
+ .where(
62
+ SQL.column('members', 'id'),
63
+ SQL.column(MemberPlatformMembership.table, 'memberId'),
64
+ ),
65
+ memberFilterCompilers
66
+ )
67
+ };
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLConcat, SQLFilterDefinitions, SQLValueType, SQLScalar } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, createExistsFilter, SQL, SQLConcat, SQLValueType, SQLScalar } from '@stamhoofd/sql';
2
3
  import { memberFilterCompilers } from './members.js';
3
4
  import { organizationFilterCompilers } from './organizations.js';
4
5
  import { EmailRelationFilterCompilers } from './shared/EmailRelationFilterCompilers.js';
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLFilterDefinitions, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLValueType } from '@stamhoofd/sql';
2
3
 
3
4
  export const registrationPeriodFilterCompilers: SQLFilterDefinitions = {
4
5
  ...baseSQLFilterCompilers,
@@ -1,5 +1,6 @@
1
1
  import { Group, Member, Organization, Registration } from '@stamhoofd/models';
2
- import { baseSQLFilterCompilers, createColumnFilter, createJoinedRelationFilter, SQL, SQLFilterDefinitions, SQLValueType } from '@stamhoofd/sql';
2
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
3
+ import { baseSQLFilterCompilers, createColumnFilter, createJoinedRelationFilter, SQL, SQLValueType } from '@stamhoofd/sql';
3
4
  import { SQLTranslatedString } from '../helpers/SQLTranslatedString.js';
4
5
  import { baseRegistrationFilterCompilers } from './base-registration-filter-compilers.js';
5
6
  import { memberFilterCompilers } from './members.js';
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLFilterDefinitions, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLValueType } from '@stamhoofd/sql';
2
3
 
3
4
  export const ticketFilterCompilers: SQLFilterDefinitions = {
4
5
  ...baseSQLFilterCompilers,
@@ -1,4 +1,5 @@
1
- import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLFilterDefinitions, SQLValueType } from '@stamhoofd/sql';
1
+ import type { SQLFilterDefinitions} from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, SQL, SQLValueType } from '@stamhoofd/sql';
2
3
 
3
4
  export const userFilterCompilers: SQLFilterDefinitions = {
4
5
  ...baseSQLFilterCompilers,
@@ -0,0 +1,38 @@
1
+ import type { SQLFilterDefinitions } from '@stamhoofd/sql';
2
+ import { baseSQLFilterCompilers, createColumnFilter, createJoinedRelationFilter, SQL, SQLValueType } from '@stamhoofd/sql';
3
+ import { organizationFilterCompilers } from './organizations.js';
4
+
5
+ export const organizationJoin = SQL.join('organizations').where(SQL.column('organizations', 'id'), SQL.column('webshops', 'organizationId'));
6
+
7
+ export const webshopFilterCompilers: SQLFilterDefinitions = {
8
+ ...baseSQLFilterCompilers,
9
+ id: createColumnFilter({
10
+ expression: SQL.column('webshops', 'id'),
11
+ type: SQLValueType.String,
12
+ nullable: false,
13
+ }),
14
+ organizationId: createColumnFilter({
15
+ expression: SQL.column('webshops', 'organizationId'),
16
+ type: SQLValueType.String,
17
+ nullable: false,
18
+ }),
19
+ name: createColumnFilter({
20
+ expression: SQL.jsonExtract(SQL.column('webshops', 'meta'), '$.value.name'),
21
+ type: SQLValueType.JSONString,
22
+ nullable: false,
23
+ }),
24
+ status: createColumnFilter({
25
+ expression: SQL.jsonExtract(SQL.column('webshops', 'meta'), '$.value.status'),
26
+ type: SQLValueType.JSONString,
27
+ nullable: false,
28
+ }),
29
+ organization: createJoinedRelationFilter(
30
+ organizationJoin,
31
+ organizationFilterCompilers,
32
+ ),
33
+ createdAt: createColumnFilter({
34
+ expression: SQL.column('createdAt'),
35
+ type: SQLValueType.Datetime,
36
+ nullable: false,
37
+ }),
38
+ };
@@ -1,5 +1,6 @@
1
- import { AuditLog } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { AuditLog } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
 
4
5
  export const auditLogSorters: SQLSortDefinitions<AuditLog> = {
5
6
  // WARNING! TEST NEW SORTERS THOROUGHLY!
@@ -1,5 +1,6 @@
1
- import { BalanceItem } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { BalanceItem } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const balanceItemSorters: SQLSortDefinitions<BalanceItem> = {
@@ -1,5 +1,6 @@
1
- import { DocumentTemplate } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { DocumentTemplate } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const documentTemplateSorters: SQLSortDefinitions<DocumentTemplate> = {
@@ -1,5 +1,6 @@
1
- import { Document } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Document } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const documentSorters: SQLSortDefinitions<Document> = {
@@ -1,5 +1,6 @@
1
- import { EmailRecipient } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { EmailRecipient } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const emailRecipientSorters: SQLSortDefinitions<EmailRecipient> = {
@@ -1,5 +1,6 @@
1
- import { Email } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Email } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const emailSorters: SQLSortDefinitions<Email> = {
@@ -1,5 +1,6 @@
1
- import { SQLResultNamespacedRow } from '@simonbackx/simple-database';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { SQLResultNamespacedRow } from '@simonbackx/simple-database';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
  import { organizationJoin } from '../sql-filters/event-notifications.js';
5
6
 
@@ -1,5 +1,6 @@
1
- import { Event } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Event } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const eventSorters: SQLSortDefinitions<Event> = {
@@ -1,5 +1,6 @@
1
- import { Group } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Group } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
 
4
5
  export const groupSorters: SQLSortDefinitions<Group> = {
5
6
  // WARNING! TEST NEW SORTERS THOROUGHLY!
@@ -1,5 +1,6 @@
1
- import { Invoice } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Invoice } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const invoiceSorters: SQLSortDefinitions<Invoice> = {
@@ -1,5 +1,6 @@
1
- import { MemberWithUsersRegistrationsAndGroups } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { MemberWithUsersRegistrationsAndGroups } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const memberSorters: SQLSortDefinitions<MemberWithUsersRegistrationsAndGroups> = {
@@ -1,5 +1,6 @@
1
- import { Order } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Order } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const orderSorters: SQLSortDefinitions<Order> = {
@@ -1,5 +1,6 @@
1
- import { OrganizationRegistrationPeriod } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { OrganizationRegistrationPeriod } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
 
4
5
  export const organizationRegistrationPeriodSorters: SQLSortDefinitions<OrganizationRegistrationPeriod> = {
5
6
  // WARNING! TEST NEW SORTERS THOROUGHLY!
@@ -1,5 +1,6 @@
1
- import { Organization } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Organization } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
 
4
5
  export const organizationSorters: SQLSortDefinitions<Organization> = {
5
6
  // WARNING! TEST NEW SORTERS THOROUGHLY!
@@ -1,5 +1,6 @@
1
- import { Payment } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Payment } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const paymentSorters: SQLSortDefinitions<Payment> = {
@@ -0,0 +1,40 @@
1
+ import type { PlainObject } from '@simonbackx/simple-encoding';
2
+ import type { SQLOrderByDirection, SQLSortDefinition, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
4
+ import type { PlatformMembership } from '@stamhoofd/structures';
5
+
6
+ type KeysOfType<T, V> = {
7
+ [K in keyof T]: T[K] extends V ? K : never
8
+ }[keyof T];
9
+
10
+ const columnsToFilterOn: (KeysOfType<PlatformMembership, PlainObject | Date>)[] = ['id','startDate','endDate','membershipTypeId', 'price', 'createdAt', 'trialUntil', 'freeAmount'];
11
+
12
+ export const platformMembershipSorters: SQLSortDefinitions<PlatformMembership> = {
13
+ // WARNING! TEST NEW SORTERS THOROUGHLY!
14
+ // Try to avoid creating sorters on fields that er not 1:1 with the database, that often causes pagination issues if not thought through
15
+ // An example: sorting on 'name' is not a good idea, because it is a concatenation of two fields.
16
+ // You might be tempted to use ORDER BY firstName, lastName, but that will not work as expected and it needs to be ORDER BY CONCAT(firstName, ' ', lastName)
17
+ // Why? Because ORDER BY firstName, lastName produces a different order dan ORDER BY CONCAT(firstName, ' ', lastName) if there are multiple people with spaces in the first name
18
+ // And that again causes issues with pagination because the next query will append a filter of name > 'John Doe' - causing duplicate and/or skipped results
19
+ // What if you need mapping? simply map the sorters in the frontend: name -> firstname, lastname, age -> birthDay, etc.
20
+ ...Object.fromEntries(columnsToFilterOn.map((column: KeysOfType<PlatformMembership, PlainObject | Date>) => [column, createColumnSortDefinition(column)]))
21
+ };
22
+
23
+ /**
24
+ * Create a basic sort definition from a column
25
+ * @param column
26
+ * @returns
27
+ */
28
+ function createColumnSortDefinition<K extends KeysOfType<PlatformMembership, PlainObject | Date>>(column: K): SQLSortDefinition<PlatformMembership, PlatformMembership[K]>{
29
+ return {
30
+ getValue(a: PlatformMembership) {
31
+ return a[column];
32
+ },
33
+ toSQL: (direction: SQLOrderByDirection): SQLOrderBy => {
34
+ return new SQLOrderBy({
35
+ column: SQL.column(column),
36
+ direction,
37
+ });
38
+ },
39
+ }
40
+ }
@@ -1,5 +1,6 @@
1
- import { CachedBalance } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { CachedBalance } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
 
4
5
  export const receivableBalanceSorters: SQLSortDefinitions<CachedBalance> = {
5
6
  // WARNING! TEST NEW SORTERS THOROUGHLY!
@@ -1,5 +1,6 @@
1
- import { RegistrationPeriod } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { RegistrationPeriod } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const registrationPeriodSorters: SQLSortDefinitions<RegistrationPeriod> = {
@@ -1,6 +1,7 @@
1
1
  import { Group, Member, Organization } from '@stamhoofd/models';
2
- import { SQL, SQLIfNull, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
- import { MemberWithRegistrationsBlob, Organization as OrganizationStruct, RegistrationWithMemberBlob } from '@stamhoofd/structures';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLIfNull, SQLOrderBy } from '@stamhoofd/sql';
4
+ import type { MemberWithRegistrationsBlob, Organization as OrganizationStruct, RegistrationWithMemberBlob } from '@stamhoofd/structures';
4
5
  import { Formatter } from '@stamhoofd/utility';
5
6
  import { memberCachedBalanceForOrganizationJoin, registrationCachedBalanceJoin } from '../helpers/outstandingBalanceJoin.js';
6
7
  import { SQLTranslatedString } from '../helpers/SQLTranslatedString.js';
@@ -1,5 +1,6 @@
1
- import { Ticket } from '@stamhoofd/models';
2
- import { SQL, SQLOrderBy, SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
1
+ import type { Ticket } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
3
4
  import { Formatter } from '@stamhoofd/utility';
4
5
 
5
6
  export const ticketSorters: SQLSortDefinitions<Ticket> = {
@@ -0,0 +1,40 @@
1
+ import type { Webshop } from '@stamhoofd/models';
2
+ import type { SQLOrderByDirection, SQLSortDefinitions } from '@stamhoofd/sql';
3
+ import { SQL, SQLOrderBy } from '@stamhoofd/sql';
4
+ import { Formatter } from '@stamhoofd/utility';
5
+
6
+ export const webshopSorters: SQLSortDefinitions<Webshop> = {
7
+ id: {
8
+ getValue(a) {
9
+ return a.id;
10
+ },
11
+ toSQL: (direction: SQLOrderByDirection): SQLOrderBy => {
12
+ return new SQLOrderBy({
13
+ column: SQL.column('id'),
14
+ direction,
15
+ });
16
+ },
17
+ },
18
+ name: {
19
+ getValue(a) {
20
+ return a.meta.name;
21
+ },
22
+ toSQL: (direction: SQLOrderByDirection): SQLOrderBy => {
23
+ return new SQLOrderBy({
24
+ column: SQL.jsonValue(SQL.column('meta'), '$.value.name', 'CHAR'),
25
+ direction,
26
+ });
27
+ },
28
+ },
29
+ createdAt: {
30
+ getValue(a) {
31
+ return Formatter.dateTimeIso(a.createdAt, 'UTC');
32
+ },
33
+ toSQL: (direction: SQLOrderByDirection): SQLOrderBy => {
34
+ return new SQLOrderBy({
35
+ column: SQL.column('createdAt'),
36
+ direction,
37
+ });
38
+ },
39
+ },
40
+ };
@@ -1,13 +1,14 @@
1
- import { AutoEncoderPatchType, PatchableArray } from '@simonbackx/simple-encoding';
1
+ import type { AutoEncoderPatchType} from '@simonbackx/simple-encoding';
2
+ import { PatchableArray } from '@simonbackx/simple-encoding';
2
3
  import { Request } from '@simonbackx/simple-endpoints';
3
- import { Organization } from '@stamhoofd/models';
4
- import { MemberWithRegistrationsBlob } from '@stamhoofd/structures';
4
+ import type { Organization } from '@stamhoofd/models';
5
+ import type { MemberWithRegistrationsBlob } from '@stamhoofd/structures';
5
6
  import { PatchOrganizationMembersEndpoint } from '../../src/endpoints/global/members/PatchOrganizationMembersEndpoint.js';
6
7
  import { testServer } from '../helpers/TestServer.js';
7
8
  import { initAdmin } from '../init/initAdmin.js';
8
9
 
9
10
  export async function patchOrganizationMember({ patch, organization }: { patch: AutoEncoderPatchType<MemberWithRegistrationsBlob>; organization: Organization }) {
10
- expect(patch.id).toBeString();
11
+ expect(patch.id).toEqual(expect.any(String));
11
12
  const { adminToken } = await initAdmin({ organization: organization });
12
13
 
13
14
  const arr = new PatchableArray();
@@ -3,11 +3,11 @@ import { PaymentStatus, PaymentGeneral } from '@stamhoofd/structures';
3
3
  import { PatchPaymentsEndpoint } from '../../src/endpoints/organization/dashboard/payments/PatchPaymentsEndpoint.js';
4
4
  import { testServer } from '../helpers/TestServer.js';
5
5
  import { Request } from '@simonbackx/simple-endpoints';
6
- import { Organization } from '@stamhoofd/models';
6
+ import type { Organization } from '@stamhoofd/models';
7
7
  import { initAdmin } from '../init/initAdmin.js';
8
8
 
9
9
  export async function changePaymentStatus({ payment, organization, status }: { payment: { id: string }; organization: Organization; status: PaymentStatus }) {
10
- expect(payment.id).toBeString();
10
+ expect(payment.id).toEqual(expect.any(String));
11
11
  const { adminToken } = await initAdmin({ organization: organization });
12
12
 
13
13
  const arr = new PatchableArray();
@@ -1,12 +1,14 @@
1
- import { AutoEncoderPatchType, PatchableArray } from '@simonbackx/simple-encoding';
1
+ import type { AutoEncoderPatchType} from '@simonbackx/simple-encoding';
2
+ import { PatchableArray } from '@simonbackx/simple-encoding';
2
3
  import { Request } from '@simonbackx/simple-endpoints';
3
- import { Organization, Token, User } from '@stamhoofd/models';
4
- import { MemberWithRegistrationsBlob } from '@stamhoofd/structures';
4
+ import type { Organization, User } from '@stamhoofd/models';
5
+ import { Token } from '@stamhoofd/models';
6
+ import type { MemberWithRegistrationsBlob } from '@stamhoofd/structures';
5
7
  import { PatchUserMembersEndpoint } from '../../src/endpoints/global/registration/PatchUserMembersEndpoint.js';
6
8
  import { testServer } from '../helpers/TestServer.js';
7
9
 
8
10
  export async function patchUserMember({ patch, organization, user }: { patch: AutoEncoderPatchType<MemberWithRegistrationsBlob>; organization: Organization; user: User }) {
9
- expect(patch.id).toBeString();
11
+ expect(patch.id).toEqual(expect.any(String));
10
12
 
11
13
  const token = await Token.createToken(user);
12
14
 
@@ -1,13 +1,12 @@
1
- /* eslint-disable jest/no-conditional-expect */
2
1
  import { Request } from '@simonbackx/simple-endpoints';
3
- import { Organization, OrganizationFactory, Token, UserFactory } from '@stamhoofd/models';
2
+ import type { Organization } from '@stamhoofd/models';
3
+ import { OrganizationFactory, Token, UserFactory } from '@stamhoofd/models';
4
4
 
5
- import { PatchMap } from '@simonbackx/simple-encoding';
6
- import { ApiUser, ApiUserRateLimits, PermissionLevel, Permissions, PermissionsResourceType, ResourcePermissions, UserMeta, UserPermissions } from '@stamhoofd/structures';
5
+ import { ApiUser, ApiUserRateLimits, PermissionLevel, Permissions, UserMeta, UserPermissions } from '@stamhoofd/structures';
7
6
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
7
+ import { GetUserEndpoint } from '../../src/endpoints/auth/GetUserEndpoint.js';
8
8
  import { CreateApiUserEndpoint } from '../../src/endpoints/organization/dashboard/users/CreateApiUserEndpoint.js';
9
9
  import { testServer } from '../helpers/TestServer.js';
10
- import { GetUserEndpoint } from '../../src/endpoints/auth/GetUserEndpoint.js';
11
10
 
12
11
  describe('E2E.APIRateLimits', () => {
13
12
  // Test endpoint
@@ -1,5 +1,6 @@
1
1
  import { Request } from '@simonbackx/simple-endpoints';
2
- import { BalanceItem, BalanceItemFactory, GroupFactory, MemberFactory, Organization, OrganizationFactory, OrganizationRegistrationPeriodFactory, Registration, RegistrationFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, UserFactory } from '@stamhoofd/models';
2
+ import type { BalanceItem, Organization, RegistrationPeriod} from '@stamhoofd/models';
3
+ import { BalanceItemFactory, GroupFactory, MemberFactory, OrganizationFactory, OrganizationRegistrationPeriodFactory, Registration, RegistrationFactory, RegistrationPeriodFactory, Token, UserFactory } from '@stamhoofd/models';
3
4
  import { AccessRight, AppliedRegistrationDiscount, BalanceItemRelation, BalanceItemRelationType, BalanceItemStatus, BalanceItemType, BooleanStatus, GroupPriceDiscount, GroupPriceDiscountType, IDRegisterCart, IDRegisterCheckout, IDRegisterItem, PaymentMethod, PermissionLevel, Permissions, PermissionsResourceType, ReduceablePrice, ResourcePermissions } from '@stamhoofd/structures';
4
5
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
5
6
  import { RegisterMembersEndpoint } from '../../src/endpoints/global/registration/RegisterMembersEndpoint.js';
@@ -46,7 +47,7 @@ describe('E2E.Bundle Discounts', () => {
46
47
  });
47
48
 
48
49
  afterEach(() => {
49
- jest.restoreAllMocks();
50
+ vitest.restoreAllMocks();
50
51
  });
51
52
 
52
53
  async function initData() {