@stamhoofd/backend 2.115.1 → 2.117.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 (284) hide show
  1. package/migrations.ts +1 -1
  2. package/package.json +10 -10
  3. package/src/audit-logs/DocumentTemplateLogger.ts +1 -1
  4. package/src/audit-logs/EmailAddressLogger.ts +1 -1
  5. package/src/audit-logs/EmailLogger.ts +1 -1
  6. package/src/audit-logs/EmailTemplateLogger.ts +1 -1
  7. package/src/audit-logs/EventLogger.ts +1 -1
  8. package/src/audit-logs/GroupLogger.ts +1 -1
  9. package/src/audit-logs/MemberLogger.ts +1 -1
  10. package/src/audit-logs/MemberPlatformMembershipLogger.ts +1 -1
  11. package/src/audit-logs/MemberResponsibilityRecordLogger.ts +1 -1
  12. package/src/audit-logs/ModelLogger.ts +27 -19
  13. package/src/audit-logs/OrderLogger.ts +1 -1
  14. package/src/audit-logs/OrganizationLogger.ts +23 -3
  15. package/src/audit-logs/OrganizationRegistrationPeriodLogger.ts +1 -1
  16. package/src/audit-logs/PaymentLogger.ts +1 -1
  17. package/src/audit-logs/PlatformLogger.ts +1 -1
  18. package/src/audit-logs/RegistrationLogger.ts +1 -1
  19. package/src/audit-logs/RegistrationPeriodLogger.ts +1 -1
  20. package/src/audit-logs/StripeAccountLogger.ts +1 -1
  21. package/src/audit-logs/UserLogger.ts +1 -1
  22. package/src/audit-logs/WebshopLogger.ts +1 -1
  23. package/src/audit-logs/init.ts +40 -0
  24. package/src/boot.ts +6 -4
  25. package/src/crons/amazon-ses.ts +1 -1
  26. package/src/crons/balance-emails.ts +1 -1
  27. package/src/crons/clearExcelCache.test.ts +1 -1
  28. package/src/crons/delete-archived-data.ts +47 -0
  29. package/src/crons/endFunctionsOfUsersWithoutRegistration.ts +1 -1
  30. package/src/crons/index.ts +1 -0
  31. package/src/crons.ts +3 -3
  32. package/src/debug.ts +230 -0
  33. package/src/email-recipient-loaders/documents.ts +1 -1
  34. package/src/email-recipient-loaders/members.ts +1 -1
  35. package/src/email-recipient-loaders/orders.ts +3 -3
  36. package/src/email-recipient-loaders/payments.ts +118 -353
  37. package/src/email-replacements/getEmailReplacementsForPayment.ts +321 -0
  38. package/src/endpoints/admin/members/ChargeMembersEndpoint.ts +9 -7
  39. package/src/endpoints/admin/memberships/ChargeMembershipsEndpoint.ts +2 -2
  40. package/src/endpoints/admin/memberships/GetChargeMembershipsSummaryEndpoint.ts +1 -1
  41. package/src/endpoints/admin/organizations/ChargeOrganizationsEndpoint.ts +16 -50
  42. package/src/endpoints/admin/organizations/GetOrganizationsCountEndpoint.ts +2 -2
  43. package/src/endpoints/admin/organizations/GetOrganizationsEndpoint.ts +4 -4
  44. package/src/endpoints/admin/organizations/PatchOrganizationsEndpoint.ts +21 -6
  45. package/src/endpoints/admin/registrations/ChargeRegistrationsEndpoint.ts +9 -7
  46. package/src/endpoints/auth/CreateAdminEndpoint.ts +2 -2
  47. package/src/endpoints/auth/CreateTokenEndpoint.test.ts +2 -2
  48. package/src/endpoints/auth/CreateTokenEndpoint.ts +1 -1
  49. package/src/endpoints/auth/DeleteTokenEndpoint.ts +1 -1
  50. package/src/endpoints/auth/DeleteUserEndpoint.ts +1 -1
  51. package/src/endpoints/auth/ForgotPasswordEndpoint.ts +1 -1
  52. package/src/endpoints/auth/GetOtherUserEndpoint.ts +2 -2
  53. package/src/endpoints/auth/GetUserEndpoint.test.ts +2 -2
  54. package/src/endpoints/auth/GetUserEndpoint.ts +2 -2
  55. package/src/endpoints/auth/OpenIDConnectAuthTokenEndpoint.ts +2 -2
  56. package/src/endpoints/auth/OpenIDConnectCallbackEndpoint.ts +2 -2
  57. package/src/endpoints/auth/OpenIDConnectStartEndpoint.ts +2 -2
  58. package/src/endpoints/auth/PatchUserEndpoint.ts +4 -4
  59. package/src/endpoints/auth/PollEmailVerificationEndpoint.ts +1 -1
  60. package/src/endpoints/auth/RetryEmailVerificationEndpoint.ts +1 -1
  61. package/src/endpoints/auth/SignupEndpoint.ts +1 -1
  62. package/src/endpoints/auth/VerifyEmailEndpoint.ts +1 -1
  63. package/src/endpoints/global/addresses/ValidateAddressEndpoint.ts +1 -1
  64. package/src/endpoints/global/audit-logs/GetAuditLogsEndpoint.ts +4 -4
  65. package/src/endpoints/global/billing/ActivatePackagesEndpoint.ts +191 -7
  66. package/src/endpoints/global/billing/DeactivatePackageEndpoint.ts +64 -0
  67. package/src/endpoints/global/email/GetAdminEmailsEndpoint.test.ts +2 -2
  68. package/src/endpoints/global/email/GetAdminEmailsEndpoint.ts +3 -3
  69. package/src/endpoints/global/email/GetEmailAddressEndpoint.ts +1 -1
  70. package/src/endpoints/global/email/GetEmailEndpoint.ts +1 -1
  71. package/src/endpoints/global/email/GetUserEmailsEndpoint.test.ts +2 -2
  72. package/src/endpoints/global/email/GetUserEmailsEndpoint.ts +3 -3
  73. package/src/endpoints/global/email/ManageEmailAddressEndpoint.ts +62 -16
  74. package/src/endpoints/global/email/PatchEmailEndpoint.test.ts +6 -6
  75. package/src/endpoints/global/email-recipients/GetEmailRecipientsCountEndpoint.ts +2 -2
  76. package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.test.ts +2 -2
  77. package/src/endpoints/global/email-recipients/GetEmailRecipientsEndpoint.ts +4 -4
  78. package/src/endpoints/global/email-recipients/RetryEmailRecipientEndpoint.ts +1 -1
  79. package/src/endpoints/global/email-recipients/helpers/validateEmailRecipientFilter.ts +1 -1
  80. package/src/endpoints/global/events/GetEventNotificationsCountEndpoint.ts +2 -2
  81. package/src/endpoints/global/events/GetEventNotificationsEndpoint.ts +4 -4
  82. package/src/endpoints/global/events/GetEventsEndpoint.ts +4 -4
  83. package/src/endpoints/global/events/PatchEventNotificationsEndpoint.test.ts +2 -2
  84. package/src/endpoints/global/events/PatchEventNotificationsEndpoint.ts +3 -3
  85. package/src/endpoints/global/events/PatchEventsEndpoint.test.ts +2 -2
  86. package/src/endpoints/global/events/PatchEventsEndpoint.ts +5 -5
  87. package/src/endpoints/global/files/ExportToExcelEndpoint.ts +4 -4
  88. package/src/endpoints/global/files/GetFileCache.ts +2 -2
  89. package/src/endpoints/global/files/UploadFile.ts +2 -2
  90. package/src/endpoints/global/files/UploadImage.ts +1 -1
  91. package/src/endpoints/global/groups/GetGroupsEndpoint.test.ts +3 -3
  92. package/src/endpoints/global/groups/GetGroupsEndpoint.ts +4 -4
  93. package/src/endpoints/global/members/GetMemberFamilyEndpoint.ts +4 -4
  94. package/src/endpoints/global/members/GetMembersEndpoint.test.ts +3 -3
  95. package/src/endpoints/global/members/GetMembersEndpoint.ts +4 -16
  96. package/src/endpoints/global/members/PatchOrganizationMembersEndpoint.ts +8 -7
  97. package/src/endpoints/global/members/helpers/validateGroupFilter.ts +1 -1
  98. package/src/endpoints/global/organizations/CreateOrganizationEndpoint.test.ts +2 -2
  99. package/src/endpoints/global/organizations/CreateOrganizationEndpoint.ts +23 -12
  100. package/src/endpoints/global/organizations/GetOrganizationFromDomainEndpoint.test.ts +2 -2
  101. package/src/endpoints/global/organizations/GetOrganizationFromDomainEndpoint.ts +1 -1
  102. package/src/endpoints/global/organizations/GetOrganizationFromUriEndpoint.ts +1 -1
  103. package/src/endpoints/global/organizations/SearchOrganizationEndpoint.test.ts +2 -2
  104. package/src/endpoints/global/organizations/SearchOrganizationEndpoint.ts +1 -1
  105. package/src/endpoints/global/payments/StripeWebhookEndpoint.ts +3 -3
  106. package/src/endpoints/global/platform/GetPlatformAdminsEndpoint.ts +1 -1
  107. package/src/endpoints/global/platform/GetPlatformEndpoint.test.ts +2 -2
  108. package/src/endpoints/global/platform/GetPlatformEndpoint.ts +1 -1
  109. package/src/endpoints/global/platform/PatchPlatformEnpoint.test.ts +2 -2
  110. package/src/endpoints/global/platform/PatchPlatformEnpoint.ts +7 -7
  111. package/src/endpoints/global/registration/GetRegistrationsEndpoint.test.ts +2 -2
  112. package/src/endpoints/global/registration/GetRegistrationsEndpoint.ts +1 -2
  113. package/src/endpoints/global/registration/GetUserDetailedPayableBalanceEndpoint.ts +2 -2
  114. package/src/endpoints/global/registration/GetUserDocumentsEndpoint.ts +2 -2
  115. package/src/endpoints/global/registration/GetUserMembersEndpoint.ts +2 -2
  116. package/src/endpoints/global/registration/GetUserPayableBalanceEndpoint.ts +2 -2
  117. package/src/endpoints/global/registration/RegisterMembersEndpoint.test.ts +2 -2
  118. package/src/endpoints/global/registration/RegisterMembersEndpoint.ts +24 -389
  119. package/src/endpoints/global/registration-periods/GetRegistrationPeriodsEndpoint.ts +3 -3
  120. package/src/endpoints/global/registration-periods/PatchRegistrationPeriodsEndpoint.ts +2 -2
  121. package/src/endpoints/global/sso/GetSSOEndpoint.ts +2 -2
  122. package/src/endpoints/global/sso/SetSSOEndpoint.ts +3 -3
  123. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemEndpoint.ts +55 -0
  124. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsCountEndpoint.ts +43 -0
  125. package/src/endpoints/organization/dashboard/balance-items/GetBalanceItemsEndpoint.ts +160 -0
  126. package/src/endpoints/organization/dashboard/{payments → balance-items}/PatchBalanceItemsEndpoint.ts +1 -1
  127. package/src/endpoints/organization/dashboard/billing/GetOrganizationDetailedPayableBalanceEndpoint.ts +2 -2
  128. package/src/endpoints/organization/dashboard/billing/GetOrganizationPayableBalanceEndpoint.ts +2 -2
  129. package/src/endpoints/organization/dashboard/billing/GetPackagesEndpoint.test.ts +3 -3
  130. package/src/endpoints/organization/dashboard/billing/GetPackagesEndpoint.ts +3 -3
  131. package/src/endpoints/organization/dashboard/documents/GetDocumentTemplateXML.ts +1 -1
  132. package/src/endpoints/organization/dashboard/documents/GetDocumentsCountEndpoint.ts +2 -2
  133. package/src/endpoints/organization/dashboard/documents/PatchDocumentEndpoint.ts +2 -2
  134. package/src/endpoints/organization/dashboard/email/CheckEmailBouncesEndpoint.ts +37 -6
  135. package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.test.ts +2 -2
  136. package/src/endpoints/organization/dashboard/email-templates/GetEmailTemplatesEndpoint.ts +3 -3
  137. package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.test.ts +2 -2
  138. package/src/endpoints/organization/dashboard/email-templates/PatchEmailTemplatesEndpoint.ts +1 -1
  139. package/src/endpoints/organization/dashboard/invoices/PatchInvoicesEndpoint.ts +53 -0
  140. package/src/endpoints/organization/dashboard/mollie/CheckMollieEndpoint.ts +2 -2
  141. package/src/endpoints/organization/dashboard/mollie/ConnectMollieEndpoint.ts +3 -3
  142. package/src/endpoints/organization/dashboard/mollie/DisconnectMollieEndpoint.ts +2 -2
  143. package/src/endpoints/organization/dashboard/mollie/GetMollieDashboardEndpoint.ts +1 -1
  144. package/src/endpoints/organization/dashboard/nolt/CreateNoltTokenEndpoint.ts +1 -1
  145. package/src/endpoints/organization/dashboard/organization/GetOrganizationArchivedGroups.ts +2 -2
  146. package/src/endpoints/organization/dashboard/organization/GetOrganizationDeletedGroups.ts +2 -2
  147. package/src/endpoints/organization/dashboard/organization/GetUitpasClientIdEndpoint.ts +2 -2
  148. package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.test.ts +2 -2
  149. package/src/endpoints/organization/dashboard/organization/PatchOrganizationEndpoint.ts +12 -1
  150. package/src/endpoints/organization/dashboard/organization/SearchUitpasOrganizersEndpoint.ts +2 -2
  151. package/src/endpoints/organization/dashboard/organization/SetOrganizationDomainEndpoint.ts +2 -2
  152. package/src/endpoints/organization/dashboard/organization/SetUitpasClientCredentialsEndpoint.ts +2 -2
  153. package/src/endpoints/organization/dashboard/payments/GetPaymentsCountEndpoint.ts +2 -2
  154. package/src/endpoints/organization/dashboard/payments/GetPaymentsEndpoint.ts +4 -4
  155. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalanceEndpoint.ts +12 -12
  156. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesCountEndpoint.ts +2 -2
  157. package/src/endpoints/organization/dashboard/receivable-balances/GetReceivableBalancesEndpoint.ts +4 -4
  158. package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.test.ts +2 -2
  159. package/src/endpoints/organization/dashboard/registration-periods/GetOrganizationRegistrationPeriodsEndpoint.ts +4 -4
  160. package/src/endpoints/organization/dashboard/registration-periods/MoveRegistrationPeriods.test.ts +2 -2
  161. package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.test.ts +2 -2
  162. package/src/endpoints/organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.ts +3 -3
  163. package/src/endpoints/organization/dashboard/registration-periods/SetupStepReviewEndpoint.ts +2 -2
  164. package/src/endpoints/organization/dashboard/stripe/ConnectStripeEndpoint.ts +3 -3
  165. package/src/endpoints/organization/dashboard/stripe/DeleteStripeAccountEndpoint.ts +3 -3
  166. package/src/endpoints/organization/dashboard/stripe/GetStripeAccountLinkEndpoint.ts +2 -2
  167. package/src/endpoints/organization/dashboard/stripe/GetStripeAccountsEndpoint.ts +1 -1
  168. package/src/endpoints/organization/dashboard/stripe/GetStripeLoginLinkEndpoint.ts +2 -2
  169. package/src/endpoints/organization/dashboard/stripe/UpdateStripeAccountEndpoint.ts +3 -3
  170. package/src/endpoints/organization/dashboard/users/CreateApiUserEndpoint.test.ts +3 -3
  171. package/src/endpoints/organization/dashboard/users/CreateApiUserEndpoint.ts +1 -1
  172. package/src/endpoints/organization/dashboard/users/DeleteUserEndpoint.ts +1 -1
  173. package/src/endpoints/organization/dashboard/users/GetApiUsersEndpoint.ts +1 -1
  174. package/src/endpoints/organization/dashboard/users/GetOrganizationAdminsEndpoint.ts +1 -1
  175. package/src/endpoints/organization/dashboard/users/PatchApiUserEndpoint.test.ts +3 -3
  176. package/src/endpoints/organization/dashboard/users/PatchApiUserEndpoint.ts +1 -1
  177. package/src/endpoints/organization/dashboard/webshops/CreateWebshopEndpoint.ts +1 -1
  178. package/src/endpoints/organization/dashboard/webshops/DeleteWebshopEndpoint.ts +2 -2
  179. package/src/endpoints/organization/dashboard/webshops/GetDiscountCodesEndpoint.ts +1 -1
  180. package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersCountEndpoint.ts +2 -2
  181. package/src/endpoints/organization/dashboard/webshops/GetWebshopOrdersEndpoint.ts +5 -5
  182. package/src/endpoints/organization/dashboard/webshops/GetWebshopTicketsEndpoint.ts +5 -5
  183. package/src/endpoints/organization/dashboard/webshops/GetWebshopUriAvailabilityEndpoint.ts +1 -1
  184. package/src/endpoints/organization/dashboard/webshops/PatchDiscountCodesEndpoint.ts +1 -1
  185. package/src/endpoints/organization/dashboard/webshops/PatchWebshopEndpoint.ts +1 -1
  186. package/src/endpoints/organization/dashboard/webshops/PatchWebshopOrdersEndpoint.ts +1 -1
  187. package/src/endpoints/organization/dashboard/webshops/PatchWebshopTicketsEndpoint.ts +1 -1
  188. package/src/endpoints/organization/dashboard/webshops/SearchUitpasEventsEndpoint.ts +2 -2
  189. package/src/endpoints/organization/dashboard/webshops/VerifyWebshopDomainEndpoint.ts +1 -1
  190. package/src/endpoints/organization/shared/ExchangePaymentEndpoint.ts +3 -3
  191. package/src/endpoints/organization/shared/GetDocumentHtml.ts +1 -1
  192. package/src/endpoints/organization/shared/GetPaymentEndpoint.ts +2 -2
  193. package/src/endpoints/organization/shared/auth/GetOrganizationEndpoint.test.ts +2 -2
  194. package/src/endpoints/organization/shared/auth/GetOrganizationEndpoint.ts +2 -2
  195. package/src/endpoints/organization/webshops/CheckWebshopDiscountCodesEndpoint.ts +1 -1
  196. package/src/endpoints/organization/webshops/GetOrderByPaymentEndpoint.ts +1 -1
  197. package/src/endpoints/organization/webshops/GetOrderEndpoint.ts +1 -1
  198. package/src/endpoints/organization/webshops/GetTicketsEndpoint.ts +1 -1
  199. package/src/endpoints/organization/webshops/GetWebshopEndpoint.test.ts +2 -2
  200. package/src/endpoints/organization/webshops/GetWebshopEndpoint.ts +2 -2
  201. package/src/endpoints/organization/webshops/PlaceOrderEndpoint.test.ts +4 -4
  202. package/src/excel-loaders/balance-items.ts +268 -0
  203. package/src/excel-loaders/event-notifications.ts +3 -3
  204. package/src/excel-loaders/index.ts +6 -5
  205. package/src/excel-loaders/organizations.ts +4 -4
  206. package/src/excel-loaders/payments.ts +11 -3
  207. package/src/excel-loaders/receivable-balances.ts +2 -2
  208. package/src/helpers/AddressValidator.test.ts +1 -1
  209. package/src/helpers/AddressValidator.ts +1 -1
  210. package/src/helpers/AdminPermissionChecker.ts +20 -17
  211. package/src/helpers/AuthenticatedStructures.ts +194 -109
  212. package/src/helpers/Context.ts +2 -0
  213. package/src/helpers/EmailResumer.ts +1 -1
  214. package/src/helpers/FlagMomentCleanup.ts +1 -1
  215. package/src/helpers/ForwardHandler.test.ts +1 -1
  216. package/src/helpers/ForwardHandler.ts +1 -1
  217. package/src/helpers/GlobalHelper.ts +4 -4
  218. package/src/helpers/GroupBuilder.ts +417 -0
  219. package/src/helpers/GroupedThrottledQueue.test.ts +1 -1
  220. package/src/helpers/GroupedThrottledQueue.ts +1 -1
  221. package/src/helpers/MemberUserSyncer.test.ts +1 -1
  222. package/src/helpers/MemberUserSyncer.ts +1 -1
  223. package/src/helpers/PeriodHelper.ts +5 -45
  224. package/src/helpers/ServiceFeeHelper.ts +5 -1
  225. package/src/helpers/SetupStepUpdater.ts +5 -4
  226. package/src/helpers/TagHelper.ts +1 -1
  227. package/src/helpers/ThrottledQueue.test.ts +1 -1
  228. package/src/helpers/ViesHelper.ts +9 -0
  229. package/src/helpers/email-html-helpers.ts +0 -41
  230. package/src/helpers/outstandingBalanceJoin.ts +3 -1
  231. package/src/middleware/ContextMiddleware.ts +1 -1
  232. package/src/seeds/1726572303-schedule-stock-updates.ts +1 -1
  233. package/src/seeds/1726847064-setup-steps.ts +1 -1
  234. package/src/seeds/1728928974-update-cached-outstanding-balance-from-items.ts +1 -1
  235. package/src/seeds/1740046783-update-membership.ts +1 -1
  236. package/src/seeds/1754560914-groups-prices.test.ts +1 -1
  237. package/src/seeds/1755876819-remove-duplicate-members.ts +1 -1
  238. package/src/seeds/1760702454-update-cached-outstanding-balance-from-items.ts +1 -1
  239. package/src/seeds/1761665607-sync-member-users.ts +1 -1
  240. package/src/seeds/data/default-email-templates.sql +1 -1
  241. package/src/seeds-temporary/1732117645-move-rrn.ts +1 -1
  242. package/src/services/AuditLogService.ts +1 -41
  243. package/src/services/BalanceItemPaymentService.ts +1 -1
  244. package/src/services/BalanceItemService.ts +12 -5
  245. package/src/services/EventNotificationService.ts +3 -3
  246. package/src/services/InvoiceService.ts +131 -17
  247. package/src/services/MemberRecordStore.ts +1 -1
  248. package/src/services/PaymentReallocationService.test.ts +9 -10
  249. package/src/services/PaymentReallocationService.ts +1 -1
  250. package/src/services/PaymentService.ts +560 -18
  251. package/src/services/PlatformMembershipService.ts +3 -3
  252. package/src/services/RegistrationService.ts +3 -3
  253. package/src/services/SSOService.ts +2 -2
  254. package/src/services/STPackageService.ts +241 -0
  255. package/src/services/uitpas/UitpasService.test.ts +1 -1
  256. package/src/sql-filters/balance-items.ts +56 -0
  257. package/src/sql-filters/emails.ts +1 -1
  258. package/src/sql-filters/event-notifications.ts +2 -2
  259. package/src/sql-filters/events.ts +51 -0
  260. package/src/sql-filters/members.ts +38 -2
  261. package/src/sql-filters/receivable-balances.ts +3 -3
  262. package/src/sql-filters/users.ts +10 -0
  263. package/src/sql-sorters/balance-items.ts +36 -0
  264. package/src/sql-sorters/document-templates.ts +2 -2
  265. package/src/sql-sorters/documents.ts +2 -2
  266. package/src/sql-sorters/event-notifications.ts +1 -1
  267. package/src/sql-sorters/members.ts +2 -2
  268. package/src/sql-sorters/orders.ts +2 -2
  269. package/src/sql-sorters/tickets.ts +2 -2
  270. package/tests/actions/patchOrganizationMember.ts +3 -3
  271. package/tests/actions/patchPaymentStatus.ts +3 -3
  272. package/tests/actions/patchUserMember.ts +2 -2
  273. package/tests/assertions/assertBalances.ts +1 -1
  274. package/tests/e2e/api-rate-limits.test.ts +3 -3
  275. package/tests/e2e/charge-members.test.ts +14 -14
  276. package/tests/e2e/documents.test.ts +8 -8
  277. package/tests/e2e/private-files.test.ts +4 -4
  278. package/tests/e2e/register.test.ts +10 -10
  279. package/tests/e2e/stock.test.ts +4 -4
  280. package/tests/e2e/tickets.test.ts +4 -4
  281. package/tests/helpers/TestServer.ts +2 -2
  282. package/tests/init/index.ts +7 -7
  283. package/tests/init/initAdmin.ts +1 -1
  284. package/src/endpoints/global/registration/GetPaymentRegistrations.ts +0 -67
@@ -4,15 +4,15 @@ import { Request } from '@simonbackx/simple-endpoints';
4
4
  import { Email, EmailRecipient, GroupFactory, MemberFactory, Organization, OrganizationFactory, RegistrationFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, User, UserFactory } from '@stamhoofd/models';
5
5
  import { AccessRight, EmailRecipientFilter, EmailRecipientFilterType, EmailRecipientSubfilter, EmailStatus, Email as EmailStruct, OrganizationEmail, Parent, PermissionLevel, Permissions, PermissionsResourceType, ResourcePermissions, UserPermissions, Version } from '@stamhoofd/structures';
6
6
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
7
- import { testServer } from '../../../../tests/helpers/TestServer';
8
- import { PatchEmailEndpoint } from './PatchEmailEndpoint';
7
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
8
+ import { PatchEmailEndpoint } from './PatchEmailEndpoint.js';
9
9
 
10
10
  // Import recipient loaders to initialize them
11
11
  import { Formatter } from '@stamhoofd/utility';
12
- import '../../../email-recipient-loaders/members';
13
- import '../../../email-recipient-loaders/orders';
14
- import '../../../email-recipient-loaders/receivable-balances';
15
- import '../../../email-recipient-loaders/registrations';
12
+ import '../../../email-recipient-loaders/members.js';
13
+ import '../../../email-recipient-loaders/orders.js';
14
+ import '../../../email-recipient-loaders/receivable-balances.js';
15
+ import '../../../email-recipient-loaders/registrations.js';
16
16
  import { EmailMocker } from '@stamhoofd/email';
17
17
 
18
18
  const baseUrl = `/v${Version}/email`;
@@ -2,8 +2,8 @@ import { Decoder } from '@simonbackx/simple-encoding';
2
2
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
3
3
  import { CountFilteredRequest, CountResponse } from '@stamhoofd/structures';
4
4
 
5
- import { Context } from '../../../helpers/Context';
6
- import { GetEmailRecipientsEndpoint } from './GetEmailRecipientsEndpoint';
5
+ import { Context } from '../../../helpers/Context.js';
6
+ import { GetEmailRecipientsEndpoint } from './GetEmailRecipientsEndpoint.js';
7
7
 
8
8
  type Params = Record<string, never>;
9
9
  type Query = CountFilteredRequest;
@@ -1,9 +1,9 @@
1
1
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
2
- import { GetEmailRecipientsEndpoint } from './GetEmailRecipientsEndpoint';
2
+ import { GetEmailRecipientsEndpoint } from './GetEmailRecipientsEndpoint.js';
3
3
  import { AccessRight, EmailStatus, LimitedFilteredRequest, OrganizationEmail, PermissionLevel, Permissions, PermissionsResourceType, ResourcePermissions } from '@stamhoofd/structures';
4
4
  import { Email, EmailRecipient, Organization, OrganizationFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, User, UserFactory } from '@stamhoofd/models';
5
5
  import { Request } from '@simonbackx/simple-endpoints';
6
- import { testServer } from '../../../../tests/helpers/TestServer';
6
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
7
7
 
8
8
  const baseUrl = `/email-recipients`;
9
9
 
@@ -5,10 +5,10 @@ import { Decoder } from '@simonbackx/simple-encoding';
5
5
  import { SimpleError } from '@simonbackx/simple-errors';
6
6
  import { EmailRecipient, fillRecipientReplacements } from '@stamhoofd/models';
7
7
  import { applySQLSorter, compileToSQLFilter, SQLFilterDefinitions, SQLSortDefinitions } from '@stamhoofd/sql';
8
- import { Context } from '../../../helpers/Context';
9
- import { emailRecipientsFilterCompilers } from '../../../sql-filters/email-recipients';
10
- import { emailRecipientSorters } from '../../../sql-sorters/email-recipients';
11
- import { validateEmailRecipientFilter } from './helpers/validateEmailRecipientFilter';
8
+ import { Context } from '../../../helpers/Context.js';
9
+ import { emailRecipientsFilterCompilers } from '../../../sql-filters/email-recipients.js';
10
+ import { emailRecipientSorters } from '../../../sql-sorters/email-recipients.js';
11
+ import { validateEmailRecipientFilter } from './helpers/validateEmailRecipientFilter.js';
12
12
 
13
13
  type Params = Record<string, never>;
14
14
  type Query = LimitedFilteredRequest;
@@ -3,7 +3,7 @@ import { Email, EmailRecipient } from '@stamhoofd/models';
3
3
  import { EmailRecipient as EmailRecipientStruct, EmailStatus, PermissionLevel } from '@stamhoofd/structures';
4
4
 
5
5
  import { SimpleError } from '@simonbackx/simple-errors';
6
- import { Context } from '../../../helpers/Context';
6
+ import { Context } from '../../../helpers/Context.js';
7
7
 
8
8
  type Params = { id: string };
9
9
  type Query = undefined;
@@ -1,7 +1,7 @@
1
1
  import { SimpleError } from '@simonbackx/simple-errors';
2
2
  import { Email } from '@stamhoofd/models';
3
3
  import { FilterWrapperMarker, PermissionLevel, StamhoofdFilter, unwrapFilter, WrapperFilter } from '@stamhoofd/structures';
4
- import { Context } from '../../../../helpers/Context';
4
+ import { Context } from '../../../../helpers/Context.js';
5
5
 
6
6
  export async function validateEmailRecipientFilter({ filter, permissionLevel }: { filter: StamhoofdFilter; permissionLevel: PermissionLevel }) {
7
7
  // Require presence of a filter
@@ -2,8 +2,8 @@ import { Decoder } from '@simonbackx/simple-encoding';
2
2
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
3
3
  import { CountFilteredRequest, CountResponse } from '@stamhoofd/structures';
4
4
 
5
- import { Context } from '../../../helpers/Context';
6
- import { GetEventNotificationsEndpoint } from './GetEventNotificationsEndpoint';
5
+ import { Context } from '../../../helpers/Context.js';
6
+ import { GetEventNotificationsEndpoint } from './GetEventNotificationsEndpoint.js';
7
7
 
8
8
  type Params = Record<string, never>;
9
9
  type Query = CountFilteredRequest;
@@ -6,10 +6,10 @@ import { SQL, SQLSortDefinitions, applySQLSorter, compileToSQLFilter } from '@st
6
6
  import { AccessRight, CountFilteredRequest, EventNotification as EventNotificationStruct, LimitedFilteredRequest, PaginatedResponse, StamhoofdFilter, assertSort, getSortFilter } from '@stamhoofd/structures';
7
7
 
8
8
  import { SQLResultNamespacedRow } from '@simonbackx/simple-database';
9
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
10
- import { Context } from '../../../helpers/Context';
11
- import { eventNotificationsFilterCompilers } from '../../../sql-filters/event-notifications';
12
- import { eventNotificationsSorters } from '../../../sql-sorters/event-notifications';
9
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
10
+ import { Context } from '../../../helpers/Context.js';
11
+ import { eventNotificationsFilterCompilers } from '../../../sql-filters/event-notifications.js';
12
+ import { eventNotificationsSorters } from '../../../sql-sorters/event-notifications.js';
13
13
 
14
14
  type Params = Record<string, never>;
15
15
  type Query = LimitedFilteredRequest;
@@ -5,10 +5,10 @@ import { Event } from '@stamhoofd/models';
5
5
  import { SQL, SQLSortDefinitions, applySQLSorter, compileToSQLFilter } from '@stamhoofd/sql';
6
6
  import { CountFilteredRequest, Event as EventStruct, LimitedFilteredRequest, PaginatedResponse, StamhoofdFilter, assertSort, getSortFilter } from '@stamhoofd/structures';
7
7
 
8
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
9
- import { Context } from '../../../helpers/Context';
10
- import { eventFilterCompilers } from '../../../sql-filters/events';
11
- import { eventSorters } from '../../../sql-sorters/events';
8
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
9
+ import { Context } from '../../../helpers/Context.js';
10
+ import { eventFilterCompilers } from '../../../sql-filters/events.js';
11
+ import { eventSorters } from '../../../sql-sorters/events.js';
12
12
 
13
13
  type Params = Record<string, never>;
14
14
  type Query = LimitedFilteredRequest;
@@ -4,8 +4,8 @@ import { EmailMocker } from '@stamhoofd/email';
4
4
  import { EmailTemplateFactory, EventFactory, EventNotification, EventNotificationFactory, EventNotificationTypeFactory, Organization, OrganizationFactory, Platform, RecordAnswerFactory, RecordCategoryFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, User, UserFactory } from '@stamhoofd/models';
5
5
  import { AccessRight, BaseOrganization, EmailTemplateType, Event, EventNotificationStatus, EventNotification as EventNotificationStruct, Permissions, PermissionsResourceType, RecordType, ResourcePermissions } from '@stamhoofd/structures';
6
6
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
7
- import { testServer } from '../../../../tests/helpers/TestServer';
8
- import { PatchEventNotificationsEndpoint } from './PatchEventNotificationsEndpoint';
7
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
8
+ import { PatchEventNotificationsEndpoint } from './PatchEventNotificationsEndpoint.js';
9
9
 
10
10
  const baseUrl = `/event-notifications`;
11
11
  const endpoint = new PatchEventNotificationsEndpoint();
@@ -4,9 +4,9 @@ import { Event, EventNotification, Platform, RegistrationPeriod } from '@stamhoo
4
4
  import { EmailTemplateType, EventNotificationStatus, EventNotification as EventNotificationStruct, PermissionLevel, RecordCategory } from '@stamhoofd/structures';
5
5
 
6
6
  import { isSimpleError, isSimpleErrors, SimpleError } from '@simonbackx/simple-errors';
7
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
8
- import { Context } from '../../../helpers/Context';
9
- import { EventNotificationService } from '../../../services/EventNotificationService';
7
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
8
+ import { Context } from '../../../helpers/Context.js';
9
+ import { EventNotificationService } from '../../../services/EventNotificationService.js';
10
10
 
11
11
  type Params = Record<string, never>;
12
12
  type Query = undefined;
@@ -3,8 +3,8 @@ import { Endpoint, Request } from '@simonbackx/simple-endpoints';
3
3
  import { EventFactory, Organization, OrganizationFactory, OrganizationRegistrationPeriodFactory, PlatformEventTypeFactory, RegistrationPeriodFactory, Token, User, UserFactory } from '@stamhoofd/models';
4
4
  import { AccessRight, Event, Group, GroupSettings, GroupType, PermissionLevel, Permissions, PermissionsResourceType, ResourcePermissions, TranslatedString } from '@stamhoofd/structures';
5
5
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
6
- import { testServer } from '../../../../tests/helpers/TestServer';
7
- import { PatchEventsEndpoint } from './PatchEventsEndpoint';
6
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
7
+ import { PatchEventsEndpoint } from './PatchEventsEndpoint.js';
8
8
 
9
9
  const baseUrl = `/events`;
10
10
  const endpoint = new PatchEventsEndpoint();
@@ -6,10 +6,10 @@ import { AuditLogSource, Event as EventStruct, Group as GroupStruct, GroupType,
6
6
  import { SimpleError } from '@simonbackx/simple-errors';
7
7
  import { SQL, SQLWhereSign } from '@stamhoofd/sql';
8
8
  import { Formatter } from '@stamhoofd/utility';
9
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
10
- import { Context } from '../../../helpers/Context';
11
- import { AuditLogService } from '../../../services/AuditLogService';
12
- import { PatchOrganizationRegistrationPeriodsEndpoint } from '../../organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint';
9
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
10
+ import { Context } from '../../../helpers/Context.js';
11
+ import { AuditLogService } from '../../../services/AuditLogService.js';
12
+ import { PatchOrganizationRegistrationPeriodsEndpoint } from '../../organization/dashboard/registration-periods/PatchOrganizationRegistrationPeriodsEndpoint.js';
13
13
 
14
14
  type Params = Record<string, never>;
15
15
  type Query = undefined;
@@ -450,7 +450,7 @@ export class PatchEventsEndpoint extends Endpoint<Params, Query, Body, ResponseB
450
450
  }
451
451
  }
452
452
 
453
- if (type.maximum && (!event.existsInDatabase || ('typeId' in (await event.getChangedDatabaseProperties()).fields))) {
453
+ if (type.maximum && (!event.existsInDatabase || ('typeId' in (event.getChangedDatabaseProperties()).fields))) {
454
454
  const currentPeriod = await RegistrationPeriod.getByDate(event.startDate, event.organizationId);
455
455
  console.log('event.startDate', event.startDate);
456
456
  if (currentPeriod) {
@@ -6,9 +6,9 @@ import { Platform, RateLimiter, sendEmailTemplate } from '@stamhoofd/models';
6
6
  import { QueueHandler } from '@stamhoofd/queues';
7
7
  import { EmailTemplateType, ExcelExportRequest, ExcelExportResponse, ExcelExportType, IPaginatedResponse, LimitedFilteredRequest, Replacement, Version } from '@stamhoofd/structures';
8
8
  import { sleep } from '@stamhoofd/utility';
9
- import { Context } from '../../../helpers/Context';
10
- import { fetchToAsyncIterator } from '../../../helpers/fetchToAsyncIterator';
11
- import { FileCache } from '../../../helpers/FileCache';
9
+ import { Context } from '../../../helpers/Context.js';
10
+ import { fetchToAsyncIterator } from '../../../helpers/fetchToAsyncIterator.js';
11
+ import { FileCache } from '../../../helpers/FileCache.js';
12
12
 
13
13
  type Params = { type: string };
14
14
  type Query = undefined;
@@ -149,7 +149,7 @@ export class ExportToExcelEndpoint extends Endpoint<Params, Query, Body, Respons
149
149
  const writer = new XlsxWriter(zipWriterAdapter);
150
150
 
151
151
  // Limit to pages of 100
152
- request.filter.limit = STAMHOOFD.environment === 'development' ? 1 : 100; // in development, we need to check if total count matches and pagination is working correctly
152
+ request.filter.limit = STAMHOOFD.environment === 'development' ? 1000 : 100; // in development, we need to check if total count matches and pagination is working correctly
153
153
 
154
154
  await exportToExcel({
155
155
  definitions: loader.sheets,
@@ -1,8 +1,8 @@
1
1
  import { AutoEncoder, Decoder, field, StringDecoder } from '@simonbackx/simple-encoding';
2
2
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
3
3
  import { Readable } from 'node:stream';
4
- import { Context } from '../../../helpers/Context';
5
- import { FileCache } from '../../../helpers/FileCache';
4
+ import { Context } from '../../../helpers/Context.js';
5
+ import { FileCache } from '../../../helpers/FileCache.js';
6
6
  import { Formatter } from '@stamhoofd/utility';
7
7
  import { RateLimiter } from '@stamhoofd/models';
8
8
 
@@ -8,8 +8,8 @@ import { promises as fs } from 'fs';
8
8
  import { v4 as uuidv4 } from 'uuid';
9
9
 
10
10
  import { AutoEncoder, BooleanDecoder, Decoder, field } from '@simonbackx/simple-encoding';
11
- import { Context } from '../../../helpers/Context';
12
- import { limiter } from './UploadImage';
11
+ import { Context } from '../../../helpers/Context.js';
12
+ import { limiter } from './UploadImage.js';
13
13
  import { Image } from '@stamhoofd/models';
14
14
 
15
15
  type Params = Record<string, never>;
@@ -6,7 +6,7 @@ import { Image as ImageStruct, ResolutionRequest } from '@stamhoofd/structures';
6
6
  import formidable from 'formidable';
7
7
  import { promises as fs } from 'fs';
8
8
 
9
- import { Context } from '../../../helpers/Context';
9
+ import { Context } from '../../../helpers/Context.js';
10
10
 
11
11
  type Params = Record<string, never>;
12
12
  class Query extends AutoEncoder {
@@ -2,9 +2,9 @@ import { Request } from '@simonbackx/simple-endpoints';
2
2
  import { GroupFactory, Organization, OrganizationFactory, OrganizationRegistrationPeriodFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, UserFactory } from '@stamhoofd/models';
3
3
  import { BundleDiscountGroupPriceSettings, GroupPrice, GroupType, LimitedFilteredRequest, StamhoofdFilter } from '@stamhoofd/structures';
4
4
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
5
- import { testServer } from '../../../../tests/helpers/TestServer';
6
- import { initAdmin, initBundleDiscount, initPlatformAdmin } from '../../../../tests/init';
7
- import { GetGroupsEndpoint } from './GetGroupsEndpoint';
5
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
6
+ import { initAdmin, initBundleDiscount, initPlatformAdmin } from '../../../../tests/init/index.js';
7
+ import { GetGroupsEndpoint } from './GetGroupsEndpoint.js';
8
8
  import { Database } from '@simonbackx/simple-database';
9
9
 
10
10
  const baseUrl = `/groups`;
@@ -5,10 +5,10 @@ import { Decoder } from '@simonbackx/simple-encoding';
5
5
  import { SimpleError } from '@simonbackx/simple-errors';
6
6
  import { Group } from '@stamhoofd/models';
7
7
  import { applySQLSorter, compileToSQLFilter, SQLFilterDefinitions, SQLSortDefinitions } from '@stamhoofd/sql';
8
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
9
- import { Context } from '../../../helpers/Context';
10
- import { groupFilterCompilers } from '../../../sql-filters/groups';
11
- import { groupSorters } from '../../../sql-sorters/groups';
8
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
9
+ import { Context } from '../../../helpers/Context.js';
10
+ import { groupFilterCompilers } from '../../../sql-filters/groups.js';
11
+ import { groupSorters } from '../../../sql-sorters/groups.js';
12
12
 
13
13
  type Params = Record<string, never>;
14
14
  type Query = LimitedFilteredRequest;
@@ -1,9 +1,9 @@
1
1
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
2
- import { Member, MemberWithRegistrations } from '@stamhoofd/models';
2
+ import { Member, MemberWithUsersRegistrationsAndGroups } from '@stamhoofd/models';
3
3
 
4
4
  import { MembersBlob } from '@stamhoofd/structures';
5
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
6
- import { Context } from '../../../helpers/Context';
5
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
6
+ import { Context } from '../../../helpers/Context.js';
7
7
  type Params = { id: string };
8
8
  type Query = undefined;
9
9
  type Body = undefined;
@@ -47,7 +47,7 @@ export class GetMemberFamilyEndpoint extends Endpoint<Params, Query, Body, Respo
47
47
 
48
48
  let foundMember = false;
49
49
 
50
- const validatedMembers: MemberWithRegistrations[] = [];
50
+ const validatedMembers: MemberWithUsersRegistrationsAndGroups[] = [];
51
51
 
52
52
  for (const member of members) {
53
53
  if (member.id === request.params.id) {
@@ -2,9 +2,9 @@ import { Endpoint, Request } from '@simonbackx/simple-endpoints';
2
2
  import { EventFactory, GroupFactory, MemberFactory, OrganizationFactory, RecordCategoryFactory, RegistrationFactory, RegistrationPeriod, RegistrationPeriodFactory, Token, UserFactory } from '@stamhoofd/models';
3
3
  import { AccessRight, EventMeta, GroupType, LimitedFilteredRequest, NamedObject, PermissionLevel, PermissionRoleDetailed, Permissions, PermissionsResourceType, RecordAnswer, RecordTextAnswer, RecordType, ResourcePermissions } from '@stamhoofd/structures';
4
4
  import { STExpect, TestUtils } from '@stamhoofd/test-utils';
5
- import { GetMembersEndpoint } from './GetMembersEndpoint';
6
- import { testServer } from '../../../../tests/helpers/TestServer';
7
- import { initPlatformRecordCategory } from '../../../../tests/init/initPlatformRecordCategory';
5
+ import { GetMembersEndpoint } from './GetMembersEndpoint.js';
6
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
7
+ import { initPlatformRecordCategory } from '../../../../tests/init/initPlatformRecordCategory.js';
8
8
 
9
9
  const baseUrl = `/members`;
10
10
  const endpoint = new GetMembersEndpoint();
@@ -126,10 +126,7 @@ export class GetMembersEndpoint extends Endpoint<Params, Query, Body, ResponseBo
126
126
  }
127
127
  }
128
128
 
129
- const query = SQL
130
- .select(
131
- SQL.column('members', 'id'),
132
- )
129
+ const query = Member.select()
133
130
  .setMaxExecutionTime(15 * 1000)
134
131
  .from(
135
132
  SQL.table('members'),
@@ -257,7 +254,7 @@ export class GetMembersEndpoint extends Endpoint<Params, Query, Body, ResponseBo
257
254
 
258
255
  static async buildData(requestQuery: LimitedFilteredRequest, permissionLevel = PermissionLevel.Read) {
259
256
  const query = await GetMembersEndpoint.buildQuery(requestQuery, permissionLevel);
260
- let data: SQLResultNamespacedRow[];
257
+ let data: Member[];
261
258
 
262
259
  try {
263
260
  data = await query.fetch();
@@ -273,16 +270,7 @@ export class GetMembersEndpoint extends Endpoint<Params, Query, Body, ResponseBo
273
270
  throw error;
274
271
  }
275
272
 
276
- const memberIds = data.map((r) => {
277
- if (typeof r.members.id === 'string') {
278
- return r.members.id;
279
- }
280
- throw new Error('Expected string');
281
- });
282
-
283
- const _members = await Member.getBlobByIds(...memberIds);
284
- // Make sure members is in same order as memberIds
285
- const members = memberIds.map(id => _members.find(m => m.id === id)!);
273
+ const members = await Member.loadRegistrationsAndUsers(data, true);
286
274
 
287
275
  for (const member of members) {
288
276
  if (!await Context.auth.canAccessMember(member, permissionLevel)) {
@@ -293,7 +281,7 @@ export class GetMembersEndpoint extends Endpoint<Params, Query, Body, ResponseBo
293
281
 
294
282
  let next: LimitedFilteredRequest | undefined;
295
283
 
296
- if (memberIds.length >= requestQuery.limit) {
284
+ if (members.length >= requestQuery.limit) {
297
285
  const lastObject = members[members.length - 1];
298
286
  const nextFilter = getSortFilter(lastObject, sorters, requestQuery.sort);
299
287
 
@@ -2,7 +2,7 @@ import { OneToManyRelation } from '@simonbackx/simple-database';
2
2
  import { AutoEncoderPatchType, ConvertArrayToPatchableArray, Decoder, isEmptyPatch, isPatchableArray, PatchableArray, PatchableArrayAutoEncoder, PatchableArrayDecoder, StringDecoder } from '@simonbackx/simple-encoding';
3
3
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
4
4
  import { SimpleError } from '@simonbackx/simple-errors';
5
- import { AuditLog, BalanceItem, Document, Group, Member, MemberFactory, MemberPlatformMembership, MemberResponsibilityRecord, MemberWithRegistrations, mergeTwoMembers, Organization, Platform, RateLimiter, Registration, RegistrationPeriod, User } from '@stamhoofd/models';
5
+ import { AuditLog, BalanceItem, Document, Group, Member, MemberFactory, MemberPlatformMembership, MemberResponsibilityRecord, MemberWithRegistrations, MemberWithUsersAndRegistrations, MemberWithUsersRegistrationsAndGroups, mergeTwoMembers, Organization, Platform, RateLimiter, Registration, RegistrationPeriod, User } from '@stamhoofd/models';
6
6
  import { AuditLogReplacement, AuditLogReplacementType, AuditLogSource, AuditLogType, EmergencyContact, GroupType, MemberDetails, MemberResponsibility, MembersBlob, MemberWithRegistrationsBlob, Parent, PermissionLevel, SetupStepType } from '@stamhoofd/structures';
7
7
  import { Formatter } from '@stamhoofd/utility';
8
8
 
@@ -72,7 +72,7 @@ export class PatchOrganizationMembersEndpoint extends Endpoint<Params, Query, Bo
72
72
  }
73
73
  }
74
74
 
75
- const members: MemberWithRegistrations[] = [];
75
+ const members: MemberWithUsersRegistrationsAndGroups[] = [];
76
76
 
77
77
  const platform = await Platform.getShared();
78
78
 
@@ -717,7 +717,7 @@ export class PatchOrganizationMembersEndpoint extends Endpoint<Params, Query, Bo
717
717
 
718
718
  // Loop all members one by one
719
719
  for (const id of ids) {
720
- const member = await Member.getWithRegistrations(id);
720
+ const member = await Member.getByIdWithUsersAndRegistrations(id);
721
721
  if (!member || !await Context.auth.canDeleteMember(member)) {
722
722
  throw Context.auth.error($t(`39f5696c-3755-429f-b0da-a0ca920ed11e`));
723
723
  }
@@ -754,9 +754,10 @@ export class PatchOrganizationMembersEndpoint extends Endpoint<Params, Query, Bo
754
754
  }
755
755
  }
756
756
 
757
- static async mergeDuplicateRelations(member: MemberWithRegistrations, patch: AutoEncoderPatchType<MemberDetails> | MemberDetails) {
758
- const _familyMembers = await Member.getFamilyWithRegistrations(member.id);
759
- const familyMembers: typeof _familyMembers = [];
757
+ static async mergeDuplicateRelations(member: Member, patch: AutoEncoderPatchType<MemberDetails> | MemberDetails) {
758
+ const __familyMembers = await Member.getFamily(member.id);
759
+ const _familyMembers = await Member.loadRegistrationsAndUsers(__familyMembers);
760
+ const familyMembers: Member[] = [];
760
761
  // Only modify members if we have write access to them (this avoids issues with overriding data)
761
762
  for (const member of _familyMembers) {
762
763
  if (await Context.auth.canAccessMember(member, PermissionLevel.Write)) {
@@ -901,7 +902,7 @@ export class PatchOrganizationMembersEndpoint extends Endpoint<Params, Query, Bo
901
902
  }
902
903
  }
903
904
 
904
- static async checkSecurityCode(member: MemberWithRegistrations, securityCode: string | null | undefined, type: 'put' | 'patch') {
905
+ static async checkSecurityCode(member: MemberWithUsersRegistrationsAndGroups, securityCode: string | null | undefined, type: 'put' | 'patch') {
905
906
  if ((type === 'put' && await member.isSafeToMergeDuplicateWithoutSecurityCode()) || await Context.auth.canAccessMember(member, PermissionLevel.Write)) {
906
907
  console.log('checkSecurityCode: without security code: allowed for ' + member.id);
907
908
  }
@@ -1,6 +1,6 @@
1
1
  import { SimpleError } from '@simonbackx/simple-errors';
2
2
  import { FilterWrapperMarker, PermissionLevel, StamhoofdFilter, unwrapFilter, WrapperFilter } from '@stamhoofd/structures';
3
- import { Context } from '../../../../helpers/Context';
3
+ import { Context } from '../../../../helpers/Context.js';
4
4
 
5
5
  export async function validateGroupFilter({ filter, permissionLevel, key }: { filter: StamhoofdFilter; permissionLevel: PermissionLevel; key: string | null }) {
6
6
  // Require presence of a filter
@@ -1,8 +1,8 @@
1
1
  import { Request } from '@simonbackx/simple-endpoints';
2
2
  import { Address, Country, CreateOrganization, NewUser, Organization as OrganizationStruct, Version } from '@stamhoofd/structures';
3
3
 
4
- import { testServer } from '../../../../tests/helpers/TestServer';
5
- import { CreateOrganizationEndpoint } from './CreateOrganizationEndpoint';
4
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
5
+ import { CreateOrganizationEndpoint } from './CreateOrganizationEndpoint.js';
6
6
 
7
7
  describe.skip('Endpoint.CreateOrganization', () => {
8
8
  // Test endpoint
@@ -1,9 +1,10 @@
1
1
  import { Decoder } from '@simonbackx/simple-encoding';
2
2
  import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-endpoints';
3
3
  import { SimpleError } from '@simonbackx/simple-errors';
4
- import { EmailVerificationCode, Organization, RegistrationPeriod, User } from '@stamhoofd/models';
5
- import { CreateOrganization, PermissionLevel, Permissions, RegistrationPeriodSettings, SignupResponse, UserPermissions } from '@stamhoofd/structures';
4
+ import { AuditLog, EmailVerificationCode, Organization, OrganizationRegistrationPeriod, RegistrationPeriod, User } from '@stamhoofd/models';
5
+ import { AuditLogSource, AuditLogType, CreateOrganization, PermissionLevel, Permissions, RegistrationPeriodSettings, SignupResponse, UserPermissions } from '@stamhoofd/structures';
6
6
  import { Formatter } from '@stamhoofd/utility';
7
+ import { AuditLogService } from '../../../services/AuditLogService.js';
7
8
 
8
9
  type Params = Record<string, never>;
9
10
  type Query = undefined;
@@ -85,15 +86,14 @@ export class CreateOrganizationEndpoint extends Endpoint<Params, Query, Body, Re
85
86
  organization.address = request.body.organization.address;
86
87
  organization.privateMeta.acquisitionTypes = request.body.organization.privateMeta?.acquisitionTypes ?? [];
87
88
 
88
- const period = new RegistrationPeriod();
89
+ const period = await AuditLogService.setContext({ source: AuditLogSource.System }, async () => {
90
+ const period = new RegistrationPeriod();
91
+ period.configureForNewOrganization();
89
92
 
90
- // WIP
91
- period.settings = RegistrationPeriodSettings.create({});
92
- period.startDate = new Date();
93
- period.endDate = new Date(Date.now() + 1000 * 60 * 60 * 24 * 31); // 1 month
94
-
95
- await period.save();
96
- organization.periodId = period.id;
93
+ await period.save();
94
+ organization.periodId = period.id;
95
+ return period;
96
+ });
97
97
 
98
98
  try {
99
99
  await organization.save();
@@ -106,8 +106,16 @@ export class CreateOrganizationEndpoint extends Endpoint<Params, Query, Body, Re
106
106
  statusCode: 500,
107
107
  });
108
108
  }
109
- period.organizationId = organization.id;
110
- await period.save();
109
+
110
+ await AuditLogService.setContext({ source: AuditLogSource.System }, async () => {
111
+ period.organizationId = organization.id;
112
+ await period.save();
113
+
114
+ const organizationPeriod = new OrganizationRegistrationPeriod();
115
+ organizationPeriod.organizationId = organization.id;
116
+ organizationPeriod.periodId = organization.periodId;
117
+ await organizationPeriod.save();
118
+ });
111
119
 
112
120
  const user = await User.register(
113
121
  organization,
@@ -127,6 +135,9 @@ export class CreateOrganizationEndpoint extends Endpoint<Params, Query, Body, Re
127
135
  user.permissions.organizationPermissions.set(organization.id, Permissions.create({ level: PermissionLevel.Full }));
128
136
  await user.save();
129
137
 
138
+ // Correctly assign creation
139
+ await AuditLog.update().where('type', AuditLogType.OrganizationAdded).where('objectId', organization.id).set('userId', user.id).set('source', AuditLogSource.User).update();
140
+
130
141
  const code = await EmailVerificationCode.createFor(user, user.email);
131
142
  code.send(user, organization, request.i18n).catch(console.error);
132
143
 
@@ -2,8 +2,8 @@ import { Request } from '@simonbackx/simple-endpoints';
2
2
  import { OrganizationFactory } from '@stamhoofd/models';
3
3
  import { Organization } from '@stamhoofd/structures';
4
4
 
5
- import { testServer } from '../../../../tests/helpers/TestServer';
6
- import { GetOrganizationFromDomainEndpoint } from './GetOrganizationFromDomainEndpoint';
5
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
6
+ import { GetOrganizationFromDomainEndpoint } from './GetOrganizationFromDomainEndpoint.js';
7
7
 
8
8
  describe('Endpoint.GetOrganizationFromDomain', () => {
9
9
  // Test endpoint
@@ -4,7 +4,7 @@ import { SimpleError } from '@simonbackx/simple-errors';
4
4
  import { Organization } from '@stamhoofd/models';
5
5
  import { Organization as OrganizationStruct } from '@stamhoofd/structures';
6
6
  import { GoogleTranslateHelper } from '@stamhoofd/utility';
7
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
7
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
8
8
  type Params = Record<string, never>;
9
9
 
10
10
  class Query extends AutoEncoder {
@@ -3,7 +3,7 @@ import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-
3
3
  import { SimpleError } from '@simonbackx/simple-errors';
4
4
  import { Organization } from '@stamhoofd/models';
5
5
  import { Organization as OrganizationStruct } from '@stamhoofd/structures';
6
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
6
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
7
7
  type Params = Record<string, never>;
8
8
 
9
9
  class Query extends AutoEncoder {
@@ -3,8 +3,8 @@ import { OrganizationFactory } from '@stamhoofd/models';
3
3
  import { v4 as uuidv4 } from 'uuid';
4
4
 
5
5
  import { Database } from '@simonbackx/simple-database';
6
- import { testServer } from '../../../../tests/helpers/TestServer';
7
- import { SearchOrganizationEndpoint } from './SearchOrganizationEndpoint';
6
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
7
+ import { SearchOrganizationEndpoint } from './SearchOrganizationEndpoint.js';
8
8
 
9
9
  describe('Endpoint.SearchOrganization', () => {
10
10
  // Test endpoint
@@ -3,7 +3,7 @@ import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-
3
3
  import { Organization } from '@stamhoofd/models';
4
4
  import { scalarToSQLExpression, SQL, SQLMatch, SQLWhere, SQLWhereLike } from '@stamhoofd/sql';
5
5
  import { Organization as OrganizationStruct } from '@stamhoofd/structures';
6
- import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures';
6
+ import { AuthenticatedStructures } from '../../../helpers/AuthenticatedStructures.js';
7
7
 
8
8
  type Params = Record<string, never>;
9
9
 
@@ -4,10 +4,10 @@ import { SimpleError } from '@simonbackx/simple-errors';
4
4
  import { Organization, StripeAccount, StripeCheckoutSession, StripePaymentIntent } from '@stamhoofd/models';
5
5
  import { isDebouncedError, QueueHandler } from '@stamhoofd/queues';
6
6
 
7
- import { StripeHelper } from '../../../helpers/StripeHelper';
8
- import { PaymentService } from '../../../services/PaymentService';
7
+ import { StripeHelper } from '../../../helpers/StripeHelper.js';
8
+ import { PaymentService } from '../../../services/PaymentService.js';
9
9
  import { AuditLog, AuditLogSource } from '@stamhoofd/structures';
10
- import { AuditLogService } from '../../../services/AuditLogService';
10
+ import { AuditLogService } from '../../../services/AuditLogService.js';
11
11
 
12
12
  type Params = Record<string, never>;
13
13
  class Body extends AutoEncoder {
@@ -2,7 +2,7 @@ import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-
2
2
  import { User } from '@stamhoofd/models';
3
3
  import { OrganizationAdmins } from '@stamhoofd/structures';
4
4
 
5
- import { Context } from '../../../helpers/Context';
5
+ import { Context } from '../../../helpers/Context.js';
6
6
 
7
7
  type Params = Record<string, never>;
8
8
  type Query = undefined;
@@ -3,8 +3,8 @@ import { Token, UserFactory } from '@stamhoofd/models';
3
3
  import { PermissionLevel, Permissions, Version } from '@stamhoofd/structures';
4
4
 
5
5
  import { TestUtils } from '@stamhoofd/test-utils';
6
- import { testServer } from '../../../../tests/helpers/TestServer';
7
- import { GetPlatformEndpoint } from './GetPlatformEndpoint';
6
+ import { testServer } from '../../../../tests/helpers/TestServer.js';
7
+ import { GetPlatformEndpoint } from './GetPlatformEndpoint.js';
8
8
 
9
9
  describe('Endpoint.GetPlatformEndpoint', () => {
10
10
  const endpoint = new GetPlatformEndpoint();
@@ -2,7 +2,7 @@ import { DecodedRequest, Endpoint, Request, Response } from '@simonbackx/simple-
2
2
  import { Platform } from '@stamhoofd/models';
3
3
  import { Platform as PlatformStruct } from '@stamhoofd/structures';
4
4
 
5
- import { Context } from '../../../helpers/Context';
5
+ import { Context } from '../../../helpers/Context.js';
6
6
 
7
7
  type Params = Record<string, never>;
8
8
  type Query = undefined;