@stamhoofd/models 2.119.0 → 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.
- package/dist/factories/AddressFactory.d.ts.map +1 -0
- package/dist/factories/AddressFactory.js +38 -0
- package/dist/factories/AddressFactory.js.map +1 -0
- package/dist/factories/BalanceItemFactory.d.ts +29 -0
- package/dist/factories/BalanceItemFactory.d.ts.map +1 -0
- package/dist/factories/BalanceItemFactory.js +56 -0
- package/dist/factories/BalanceItemFactory.js.map +1 -0
- package/dist/factories/DocumentTemplateFactory.d.ts +22 -0
- package/dist/factories/DocumentTemplateFactory.d.ts.map +1 -0
- package/dist/factories/DocumentTemplateFactory.js +145 -0
- package/dist/factories/DocumentTemplateFactory.js.map +1 -0
- package/dist/factories/EmailTemplateFactory.d.ts +18 -0
- package/dist/factories/EmailTemplateFactory.d.ts.map +1 -0
- package/dist/factories/EmailTemplateFactory.js +39 -0
- package/dist/factories/EmailTemplateFactory.js.map +1 -0
- package/dist/factories/EmergencyContactFactory.d.ts.map +1 -0
- package/dist/factories/EmergencyContactFactory.js +38 -0
- package/dist/factories/EmergencyContactFactory.js.map +1 -0
- package/dist/factories/EventFactory.d.ts +19 -0
- package/dist/factories/EventFactory.d.ts.map +1 -0
- package/dist/factories/EventFactory.js +31 -0
- package/dist/factories/EventFactory.js.map +1 -0
- package/dist/factories/EventNotificationFactory.d.ts +23 -0
- package/dist/factories/EventNotificationFactory.d.ts.map +1 -0
- package/dist/factories/EventNotificationFactory.js +40 -0
- package/dist/factories/EventNotificationFactory.js.map +1 -0
- package/dist/factories/EventNotificationTypeFactory.d.ts +12 -0
- package/dist/factories/EventNotificationTypeFactory.d.ts.map +1 -0
- package/dist/factories/EventNotificationTypeFactory.js +21 -0
- package/dist/factories/EventNotificationTypeFactory.js.map +1 -0
- package/dist/factories/GroupFactory.d.ts +27 -0
- package/dist/factories/GroupFactory.d.ts.map +1 -0
- package/dist/factories/GroupFactory.js +88 -0
- package/dist/factories/GroupFactory.js.map +1 -0
- package/dist/factories/MemberFactory.d.ts +26 -0
- package/dist/factories/MemberFactory.d.ts.map +1 -0
- package/dist/factories/MemberFactory.js +131 -0
- package/dist/factories/MemberFactory.js.map +1 -0
- package/dist/factories/MemberResponsibilityRecordFactory.d.ts +15 -0
- package/dist/factories/MemberResponsibilityRecordFactory.d.ts.map +1 -0
- package/dist/factories/MemberResponsibilityRecordFactory.js +30 -0
- package/dist/factories/MemberResponsibilityRecordFactory.js.map +1 -0
- package/dist/factories/OrganizationFactory.d.ts +20 -0
- package/dist/factories/OrganizationFactory.d.ts.map +1 -0
- package/dist/factories/OrganizationFactory.js +61 -0
- package/dist/factories/OrganizationFactory.js.map +1 -0
- package/dist/factories/OrganizationRegistrationPeriodFactory.d.ts +13 -0
- package/dist/factories/OrganizationRegistrationPeriodFactory.d.ts.map +1 -0
- package/dist/factories/OrganizationRegistrationPeriodFactory.js +16 -0
- package/dist/factories/OrganizationRegistrationPeriodFactory.js.map +1 -0
- package/dist/factories/OrganizationTagFactory.d.ts.map +1 -0
- package/dist/factories/OrganizationTagFactory.js +19 -0
- package/dist/factories/OrganizationTagFactory.js.map +1 -0
- package/dist/factories/ParentFactory.d.ts.map +1 -0
- package/dist/factories/ParentFactory.js +39 -0
- package/dist/factories/ParentFactory.js.map +1 -0
- package/dist/factories/PlatformEventTypeFactory.d.ts.map +1 -0
- package/dist/factories/PlatformEventTypeFactory.js +23 -0
- package/dist/factories/PlatformEventTypeFactory.js.map +1 -0
- package/dist/factories/PlatformResponsibilityFactory.d.ts.map +1 -0
- package/dist/factories/PlatformResponsibilityFactory.js +21 -0
- package/dist/factories/PlatformResponsibilityFactory.js.map +1 -0
- package/dist/factories/RecordAnswerFactory.d.ts +18 -0
- package/dist/factories/RecordAnswerFactory.d.ts.map +1 -0
- package/dist/factories/RecordAnswerFactory.js +91 -0
- package/dist/factories/RecordAnswerFactory.js.map +1 -0
- package/dist/factories/RecordCategoryFactory.d.ts +11 -0
- package/dist/factories/RecordCategoryFactory.d.ts.map +1 -0
- package/dist/factories/RecordCategoryFactory.js +19 -0
- package/dist/factories/RecordCategoryFactory.js.map +1 -0
- package/dist/factories/RecordFactory.d.ts.map +1 -0
- package/dist/factories/RecordFactory.js +16 -0
- package/dist/factories/RecordFactory.js.map +1 -0
- package/dist/factories/RegisterCodeFactory.d.ts.map +1 -0
- package/dist/factories/RegisterCodeFactory.js +14 -0
- package/dist/factories/RegisterCodeFactory.js.map +1 -0
- package/dist/factories/RegistrationFactory.d.ts +21 -0
- package/dist/factories/RegistrationFactory.d.ts.map +1 -0
- package/dist/factories/RegistrationFactory.js +21 -0
- package/dist/factories/RegistrationFactory.js.map +1 -0
- package/dist/factories/RegistrationPeriodFactory.d.ts +16 -0
- package/dist/factories/RegistrationPeriodFactory.d.ts.map +1 -0
- package/dist/factories/RegistrationPeriodFactory.js +30 -0
- package/dist/factories/RegistrationPeriodFactory.js.map +1 -0
- package/dist/factories/STPackageFactory.d.ts +15 -0
- package/dist/factories/STPackageFactory.d.ts.map +1 -0
- package/dist/factories/STPackageFactory.js +34 -0
- package/dist/factories/STPackageFactory.js.map +1 -0
- package/dist/factories/UserFactory.d.ts +22 -0
- package/dist/factories/UserFactory.d.ts.map +1 -0
- package/dist/factories/UserFactory.js +63 -0
- package/dist/factories/UserFactory.js.map +1 -0
- package/dist/factories/WebshopFactory.d.ts +17 -0
- package/dist/factories/WebshopFactory.d.ts.map +1 -0
- package/dist/factories/WebshopFactory.js +35 -0
- package/dist/factories/WebshopFactory.js.map +1 -0
- package/dist/factories/index.d.ts.map +1 -0
- package/dist/factories/index.js +27 -0
- package/dist/factories/index.js.map +1 -0
- package/dist/helpers/DNSValidator.d.ts +6 -0
- package/dist/helpers/DNSValidator.d.ts.map +1 -0
- package/dist/helpers/DNSValidator.js +142 -0
- package/dist/helpers/DNSValidator.js.map +1 -0
- package/dist/helpers/EmailBuilder.d.ts +88 -0
- package/dist/helpers/EmailBuilder.d.ts.map +1 -0
- package/dist/helpers/EmailBuilder.js +603 -0
- package/dist/helpers/EmailBuilder.js.map +1 -0
- package/dist/helpers/Handlebars.d.ts.map +1 -0
- package/dist/helpers/Handlebars.js +244 -0
- package/dist/helpers/Handlebars.js.map +1 -0
- package/dist/helpers/MemberMerger.d.ts.map +1 -0
- package/dist/helpers/MemberMerger.js +364 -0
- package/dist/helpers/MemberMerger.js.map +1 -0
- package/dist/helpers/RateLimiter.d.ts.map +1 -0
- package/dist/helpers/RateLimiter.js +64 -0
- package/dist/helpers/RateLimiter.js.map +1 -0
- package/dist/helpers/WebshopCounter.d.ts +8 -0
- package/dist/helpers/WebshopCounter.d.ts.map +1 -0
- package/dist/helpers/WebshopCounter.js +46 -0
- package/dist/helpers/WebshopCounter.js.map +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/migrations/1605262045-import-postcodes.d.ts.map +1 -0
- package/dist/migrations/1605262045-import-postcodes.js +117 -0
- package/dist/migrations/1605262045-import-postcodes.js.map +1 -0
- package/dist/migrations/1605262046-import-postcodes-nl.d.ts.map +1 -0
- package/dist/migrations/1605262046-import-postcodes-nl.js +80 -0
- package/dist/migrations/1605262046-import-postcodes-nl.js.map +1 -0
- package/dist/migrations/1720080976-convert-charset-leads.d.ts +10 -0
- package/dist/migrations/1720080976-convert-charset-leads.d.ts.map +1 -0
- package/dist/migrations/1720080976-convert-charset-leads.js +41 -0
- package/dist/migrations/1720080976-convert-charset-leads.js.map +1 -0
- package/dist/models/AuditLog.d.ts.map +1 -0
- package/dist/models/AuditLog.js +94 -0
- package/dist/models/AuditLog.js.map +1 -0
- package/dist/models/BalanceItem.d.ts +218 -0
- package/dist/models/BalanceItem.d.ts.map +1 -0
- package/dist/models/BalanceItem.js +626 -0
- package/dist/models/BalanceItem.js.map +1 -0
- package/dist/models/BalanceItemPayment.d.ts +24 -0
- package/dist/models/BalanceItemPayment.d.ts.map +1 -0
- package/dist/models/BalanceItemPayment.js +65 -0
- package/dist/models/BalanceItemPayment.js.map +1 -0
- package/dist/models/BuckarooPayment.d.ts.map +1 -0
- package/dist/models/BuckarooPayment.js +24 -0
- package/dist/models/BuckarooPayment.js.map +1 -0
- package/dist/models/CachedBalance.d.ts +51 -0
- package/dist/models/CachedBalance.d.ts.map +1 -0
- package/dist/models/CachedBalance.js +390 -0
- package/dist/models/CachedBalance.js.map +1 -0
- package/dist/models/Document.d.ts +41 -0
- package/dist/models/Document.d.ts.map +1 -0
- package/dist/models/Document.js +251 -0
- package/dist/models/Document.js.map +1 -0
- package/dist/models/DocumentTemplate.d.ts +56 -0
- package/dist/models/DocumentTemplate.d.ts.map +1 -0
- package/dist/models/DocumentTemplate.js +719 -0
- package/dist/models/DocumentTemplate.js.map +1 -0
- package/dist/models/Email.d.ts +141 -0
- package/dist/models/Email.d.ts.map +1 -0
- package/dist/models/Email.js +1341 -0
- package/dist/models/Email.js.map +1 -0
- package/dist/models/EmailRecipient.d.ts.map +1 -0
- package/dist/models/EmailRecipient.js +194 -0
- package/dist/models/EmailRecipient.js.map +1 -0
- package/dist/models/EmailTemplate.d.ts +24 -0
- package/dist/models/EmailTemplate.d.ts.map +1 -0
- package/dist/models/EmailTemplate.js +79 -0
- package/dist/models/EmailTemplate.js.map +1 -0
- package/dist/models/EmailVerificationCode.d.ts +61 -0
- package/dist/models/EmailVerificationCode.d.ts.map +1 -0
- package/dist/models/EmailVerificationCode.js +339 -0
- package/dist/models/EmailVerificationCode.js.map +1 -0
- package/dist/models/Event.d.ts.map +1 -0
- package/dist/models/Event.js +132 -0
- package/dist/models/Event.js.map +1 -0
- package/dist/models/EventNotification.d.ts +32 -0
- package/dist/models/EventNotification.d.ts.map +1 -0
- package/dist/models/EventNotification.js +98 -0
- package/dist/models/EventNotification.js.map +1 -0
- package/dist/models/Group.d.ts +46 -0
- package/dist/models/Group.d.ts.map +1 -0
- package/dist/models/Group.js +213 -0
- package/dist/models/Group.js.map +1 -0
- package/dist/models/Image.d.ts +17 -0
- package/dist/models/Image.d.ts.map +1 -0
- package/dist/models/Image.js +169 -0
- package/dist/models/Image.js.map +1 -0
- package/dist/models/Invoice.d.ts.map +1 -0
- package/dist/models/Invoice.js +186 -0
- package/dist/models/Invoice.js.map +1 -0
- package/dist/models/InvoicedBalanceItem.d.ts +66 -0
- package/dist/models/InvoicedBalanceItem.d.ts.map +1 -0
- package/dist/models/InvoicedBalanceItem.js +130 -0
- package/dist/models/InvoicedBalanceItem.js.map +1 -0
- package/dist/models/Member.d.ts +114 -0
- package/dist/models/Member.d.ts.map +1 -0
- package/dist/models/Member.js +415 -0
- package/dist/models/Member.js.map +1 -0
- package/dist/models/MemberPlatformMembership.d.ts +48 -0
- package/dist/models/MemberPlatformMembership.d.ts.map +1 -0
- package/dist/models/MemberPlatformMembership.js +377 -0
- package/dist/models/MemberPlatformMembership.js.map +1 -0
- package/dist/models/MemberResponsibilityRecord.d.ts +17 -0
- package/dist/models/MemberResponsibilityRecord.d.ts.map +1 -0
- package/dist/models/MemberResponsibilityRecord.js +65 -0
- package/dist/models/MemberResponsibilityRecord.js.map +1 -0
- package/dist/models/MemberUser.d.ts.map +1 -0
- package/dist/models/MemberUser.js +22 -0
- package/dist/models/MemberUser.js.map +1 -0
- package/dist/models/MergedMember.d.ts +23 -0
- package/dist/models/MergedMember.d.ts.map +1 -0
- package/dist/models/MergedMember.js +123 -0
- package/dist/models/MergedMember.js.map +1 -0
- package/dist/models/MolliePayment.d.ts.map +1 -0
- package/dist/models/MolliePayment.js +24 -0
- package/dist/models/MolliePayment.js.map +1 -0
- package/dist/models/MollieToken.d.ts +45 -0
- package/dist/models/MollieToken.d.ts.map +1 -0
- package/dist/models/MollieToken.js +330 -0
- package/dist/models/MollieToken.js.map +1 -0
- package/dist/models/OneTimeToken.d.ts +38 -0
- package/dist/models/OneTimeToken.d.ts.map +1 -0
- package/dist/models/OneTimeToken.js +125 -0
- package/dist/models/OneTimeToken.js.map +1 -0
- package/dist/models/Order.d.ts +115 -0
- package/dist/models/Order.d.ts.map +1 -0
- package/dist/models/Order.js +908 -0
- package/dist/models/Order.js.map +1 -0
- package/dist/models/Organization.d.ts +128 -0
- package/dist/models/Organization.d.ts.map +1 -0
- package/dist/models/Organization.js +846 -0
- package/dist/models/Organization.js.map +1 -0
- package/dist/models/OrganizationRegistrationPeriod.d.ts +22 -0
- package/dist/models/OrganizationRegistrationPeriod.d.ts.map +1 -0
- package/dist/models/OrganizationRegistrationPeriod.js +129 -0
- package/dist/models/OrganizationRegistrationPeriod.js.map +1 -0
- package/dist/models/PasswordToken.d.ts +31 -0
- package/dist/models/PasswordToken.d.ts.map +1 -0
- package/dist/models/PasswordToken.js +129 -0
- package/dist/models/PasswordToken.js.map +1 -0
- package/dist/models/PayconiqPayment.d.ts +24 -0
- package/dist/models/PayconiqPayment.d.ts.map +1 -0
- package/dist/models/PayconiqPayment.js +272 -0
- package/dist/models/PayconiqPayment.js.map +1 -0
- package/dist/models/Payment.d.ts +120 -0
- package/dist/models/Payment.d.ts.map +1 -0
- package/dist/models/Payment.js +289 -0
- package/dist/models/Payment.js.map +1 -0
- package/dist/models/Platform.d.ts.map +1 -0
- package/dist/models/Platform.js +178 -0
- package/dist/models/Platform.js.map +1 -0
- package/dist/models/RegisterCode.d.ts.map +1 -0
- package/dist/models/RegisterCode.js +76 -0
- package/dist/models/RegisterCode.js.map +1 -0
- package/dist/models/Registration.d.ts +85 -0
- package/dist/models/Registration.d.ts.map +1 -0
- package/dist/models/Registration.js +190 -0
- package/dist/models/Registration.js.map +1 -0
- package/dist/models/RegistrationPeriod.d.ts.map +1 -0
- package/dist/models/RegistrationPeriod.js +140 -0
- package/dist/models/RegistrationPeriod.js.map +1 -0
- package/dist/models/STCredit.d.ts.map +1 -0
- package/dist/models/STCredit.js +61 -0
- package/dist/models/STCredit.js.map +1 -0
- package/dist/models/STInvoice.d.ts +37 -0
- package/dist/models/STInvoice.d.ts.map +1 -0
- package/dist/models/STInvoice.js +139 -0
- package/dist/models/STInvoice.js.map +1 -0
- package/dist/models/STPackage.d.ts.map +1 -0
- package/dist/models/STPackage.js +276 -0
- package/dist/models/STPackage.js.map +1 -0
- package/dist/models/STPendingInvoice.d.ts +26 -0
- package/dist/models/STPendingInvoice.d.ts.map +1 -0
- package/dist/models/STPendingInvoice.js +68 -0
- package/dist/models/STPendingInvoice.js.map +1 -0
- package/dist/models/StripeAccount.d.ts.map +1 -0
- package/dist/models/StripeAccount.js +81 -0
- package/dist/models/StripeAccount.js.map +1 -0
- package/dist/models/StripeCheckoutSession.d.ts.map +1 -0
- package/dist/models/StripeCheckoutSession.js +35 -0
- package/dist/models/StripeCheckoutSession.js.map +1 -0
- package/dist/models/StripePaymentIntent.d.ts.map +1 -0
- package/dist/models/StripePaymentIntent.js +35 -0
- package/dist/models/StripePaymentIntent.js.map +1 -0
- package/dist/models/Ticket.d.ts +65 -0
- package/dist/models/Ticket.d.ts.map +1 -0
- package/dist/models/Ticket.js +157 -0
- package/dist/models/Ticket.js.map +1 -0
- package/dist/models/Token.d.ts +48 -0
- package/dist/models/Token.d.ts.map +1 -0
- package/dist/models/Token.js +208 -0
- package/dist/models/Token.js.map +1 -0
- package/dist/models/UitpasClientCredential.d.ts.map +1 -0
- package/dist/models/UitpasClientCredential.js +62 -0
- package/dist/models/UitpasClientCredential.js.map +1 -0
- package/dist/models/UsedRegisterCode.d.ts.map +1 -0
- package/dist/models/UsedRegisterCode.js +58 -0
- package/dist/models/UsedRegisterCode.js.map +1 -0
- package/dist/models/User.d.ts +76 -0
- package/dist/models/User.d.ts.map +1 -0
- package/dist/models/User.js +484 -0
- package/dist/models/User.js.map +1 -0
- package/dist/models/UserPermissions.d.ts +16 -0
- package/dist/models/UserPermissions.d.ts.map +1 -0
- package/dist/models/UserPermissions.js +56 -0
- package/dist/models/UserPermissions.js.map +1 -0
- package/dist/models/Webshop.d.ts +45 -0
- package/dist/models/Webshop.d.ts.map +1 -0
- package/dist/models/Webshop.js +187 -0
- package/dist/models/Webshop.js.map +1 -0
- package/dist/models/WebshopDiscountCode.d.ts.map +1 -0
- package/dist/models/WebshopDiscountCode.js +89 -0
- package/dist/models/WebshopDiscountCode.js.map +1 -0
- package/dist/models/WebshopUitpasNumber.d.ts.map +1 -0
- package/dist/models/WebshopUitpasNumber.js +91 -0
- package/dist/models/WebshopUitpasNumber.js.map +1 -0
- package/dist/models/_relations.d.ts +8 -0
- package/dist/models/_relations.d.ts.map +1 -0
- package/dist/models/_relations.js +110 -0
- package/dist/models/_relations.js.map +1 -0
- package/dist/models/addresses/City.d.ts +15 -0
- package/dist/models/addresses/City.d.ts.map +1 -0
- package/dist/models/addresses/City.js +35 -0
- package/dist/models/addresses/City.js.map +1 -0
- package/dist/models/addresses/PostalCode.d.ts +21 -0
- package/dist/models/addresses/PostalCode.d.ts.map +1 -0
- package/dist/models/addresses/PostalCode.js +139 -0
- package/dist/models/addresses/PostalCode.js.map +1 -0
- package/dist/models/addresses/Province.d.ts +9 -0
- package/dist/models/addresses/Province.d.ts.map +1 -0
- package/dist/models/addresses/Province.js +24 -0
- package/dist/models/addresses/Province.js.map +1 -0
- package/dist/models/addresses/Street.d.ts.map +1 -0
- package/dist/models/addresses/Street.js +26 -0
- package/dist/models/addresses/Street.js.map +1 -0
- package/dist/models/index.d.ts +55 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +55 -0
- package/dist/models/index.js.map +1 -0
- package/dist/structures/OrganizationServerMetaData.d.ts.map +1 -0
- package/dist/structures/OrganizationServerMetaData.js +130 -0
- package/dist/structures/OrganizationServerMetaData.js.map +1 -0
- package/package.json +13 -10
- package/src/factories/AddressFactory.ts +3 -2
- package/src/factories/BalanceItemFactory.ts +2 -1
- package/src/factories/DocumentTemplateFactory.ts +2 -1
- package/src/factories/EmailTemplateFactory.ts +3 -2
- package/src/factories/EmergencyContactFactory.ts +1 -1
- package/src/factories/EventFactory.ts +2 -2
- package/src/factories/EventNotificationFactory.ts +6 -4
- package/src/factories/EventNotificationTypeFactory.ts +2 -1
- package/src/factories/GroupFactory.ts +4 -3
- package/src/factories/MemberFactory.ts +6 -5
- package/src/factories/MemberResponsibilityRecordFactory.ts +3 -2
- package/src/factories/OrganizationFactory.ts +4 -2
- package/src/factories/OrganizationRegistrationPeriodFactory.ts +2 -2
- package/src/factories/ParentFactory.ts +1 -1
- package/src/factories/RecordAnswerFactory.ts +2 -1
- package/src/factories/RecordCategoryFactory.ts +4 -2
- package/src/factories/RegistrationFactory.ts +5 -4
- package/src/factories/RegistrationPeriodFactory.ts +2 -1
- package/src/factories/STPackageFactory.ts +1 -1
- package/src/factories/UserFactory.ts +3 -2
- package/src/factories/WebshopFactory.ts +3 -2
- package/src/helpers/DNSValidator.ts +2 -1
- package/src/helpers/EmailBuilder.ts +13 -4
- package/src/helpers/Handlebars.ts +3 -3
- package/src/helpers/MemberMerger.test.ts +1 -1
- package/src/helpers/MemberMerger.ts +5 -4
- package/src/helpers/WebshopCounter.ts +1 -1
- package/src/migrations/1605262045-import-postcodes.ts +1 -1
- package/src/migrations/1605262046-import-postcodes-nl.ts +2 -2
- package/src/migrations/1720080976-convert-charset-leads.ts +53 -0
- package/src/models/AuditLog.ts +2 -1
- package/src/models/BalanceItem.ts +4 -3
- package/src/models/BalanceItemPayment.ts +9 -6
- package/src/models/CachedBalance.test.ts +331 -0
- package/src/models/CachedBalance.ts +3 -2
- package/src/models/Document.ts +2 -2
- package/src/models/DocumentTemplate.ts +5 -3
- package/src/models/Email.test.ts +32 -31
- package/src/models/Email.ts +7 -4
- package/src/models/EmailTemplate.ts +2 -1
- package/src/models/EmailVerificationCode.ts +7 -5
- package/src/models/EventNotification.ts +3 -2
- package/src/models/Group.ts +5 -15
- package/src/models/Image.ts +2 -1
- package/src/models/InvoicedBalanceItem.ts +9 -8
- package/src/models/Member.ts +8 -4
- package/src/models/MemberPlatformMembership.ts +1 -1
- package/src/models/MemberResponsibilityRecord.ts +2 -1
- package/src/models/MergedMember.ts +1 -1
- package/src/models/MollieToken.ts +3 -3
- package/src/models/OneTimeToken.ts +1 -1
- package/src/models/Order.ts +17 -9
- package/src/models/Organization.ts +39 -11
- package/src/models/OrganizationRegistrationPeriod.ts +2 -2
- package/src/models/PasswordToken.ts +7 -5
- package/src/models/PayconiqPayment.ts +6 -3
- package/src/models/Payment.ts +8 -5
- package/src/models/Registration.ts +9 -97
- package/src/models/STInvoice.ts +1 -4
- package/src/models/STPackage.ts +1 -1
- package/src/models/STPendingInvoice.ts +5 -4
- package/src/models/Ticket.ts +11 -9
- package/src/models/Token.test.ts +2 -2
- package/src/models/Token.ts +6 -6
- package/src/models/User.ts +7 -8
- package/src/models/UserPermissions.ts +7 -6
- package/src/models/Webshop.ts +5 -5
- package/src/models/_relations.ts +133 -0
- package/src/models/addresses/City.ts +1 -1
- package/src/models/addresses/PostalCode.test.ts +1 -1
- package/src/models/addresses/PostalCode.ts +1 -1
- package/src/models/addresses/Province.ts +1 -1
- package/src/models/index.ts +22 -20
- package/src/node_modules/.vite/vitest/da39a3ee5e6b4b0d3255bfef95601890afd80709/results.json +1 -0
- package/dist/src/factories/AddressFactory.d.ts.map +0 -1
- package/dist/src/factories/AddressFactory.js +0 -42
- package/dist/src/factories/AddressFactory.js.map +0 -1
- package/dist/src/factories/BalanceItemFactory.d.ts +0 -28
- package/dist/src/factories/BalanceItemFactory.d.ts.map +0 -1
- package/dist/src/factories/BalanceItemFactory.js +0 -60
- package/dist/src/factories/BalanceItemFactory.js.map +0 -1
- package/dist/src/factories/DocumentTemplateFactory.d.ts +0 -21
- package/dist/src/factories/DocumentTemplateFactory.d.ts.map +0 -1
- package/dist/src/factories/DocumentTemplateFactory.js +0 -149
- package/dist/src/factories/DocumentTemplateFactory.js.map +0 -1
- package/dist/src/factories/EmailTemplateFactory.d.ts +0 -18
- package/dist/src/factories/EmailTemplateFactory.d.ts.map +0 -1
- package/dist/src/factories/EmailTemplateFactory.js +0 -43
- package/dist/src/factories/EmailTemplateFactory.js.map +0 -1
- package/dist/src/factories/EmergencyContactFactory.d.ts.map +0 -1
- package/dist/src/factories/EmergencyContactFactory.js +0 -42
- package/dist/src/factories/EmergencyContactFactory.js.map +0 -1
- package/dist/src/factories/EventFactory.d.ts +0 -19
- package/dist/src/factories/EventFactory.d.ts.map +0 -1
- package/dist/src/factories/EventFactory.js +0 -35
- package/dist/src/factories/EventFactory.js.map +0 -1
- package/dist/src/factories/EventNotificationFactory.d.ts +0 -21
- package/dist/src/factories/EventNotificationFactory.d.ts.map +0 -1
- package/dist/src/factories/EventNotificationFactory.js +0 -44
- package/dist/src/factories/EventNotificationFactory.js.map +0 -1
- package/dist/src/factories/EventNotificationTypeFactory.d.ts +0 -11
- package/dist/src/factories/EventNotificationTypeFactory.d.ts.map +0 -1
- package/dist/src/factories/EventNotificationTypeFactory.js +0 -25
- package/dist/src/factories/EventNotificationTypeFactory.js.map +0 -1
- package/dist/src/factories/GroupFactory.d.ts +0 -26
- package/dist/src/factories/GroupFactory.d.ts.map +0 -1
- package/dist/src/factories/GroupFactory.js +0 -92
- package/dist/src/factories/GroupFactory.js.map +0 -1
- package/dist/src/factories/MemberFactory.d.ts +0 -26
- package/dist/src/factories/MemberFactory.d.ts.map +0 -1
- package/dist/src/factories/MemberFactory.js +0 -135
- package/dist/src/factories/MemberFactory.js.map +0 -1
- package/dist/src/factories/MemberResponsibilityRecordFactory.d.ts +0 -14
- package/dist/src/factories/MemberResponsibilityRecordFactory.d.ts.map +0 -1
- package/dist/src/factories/MemberResponsibilityRecordFactory.js +0 -34
- package/dist/src/factories/MemberResponsibilityRecordFactory.js.map +0 -1
- package/dist/src/factories/OrganizationFactory.d.ts +0 -19
- package/dist/src/factories/OrganizationFactory.d.ts.map +0 -1
- package/dist/src/factories/OrganizationFactory.js +0 -64
- package/dist/src/factories/OrganizationFactory.js.map +0 -1
- package/dist/src/factories/OrganizationRegistrationPeriodFactory.d.ts +0 -13
- package/dist/src/factories/OrganizationRegistrationPeriodFactory.d.ts.map +0 -1
- package/dist/src/factories/OrganizationRegistrationPeriodFactory.js +0 -20
- package/dist/src/factories/OrganizationRegistrationPeriodFactory.js.map +0 -1
- package/dist/src/factories/OrganizationTagFactory.d.ts.map +0 -1
- package/dist/src/factories/OrganizationTagFactory.js +0 -23
- package/dist/src/factories/OrganizationTagFactory.js.map +0 -1
- package/dist/src/factories/ParentFactory.d.ts.map +0 -1
- package/dist/src/factories/ParentFactory.js +0 -43
- package/dist/src/factories/ParentFactory.js.map +0 -1
- package/dist/src/factories/PlatformEventTypeFactory.d.ts.map +0 -1
- package/dist/src/factories/PlatformEventTypeFactory.js +0 -27
- package/dist/src/factories/PlatformEventTypeFactory.js.map +0 -1
- package/dist/src/factories/PlatformResponsibilityFactory.d.ts.map +0 -1
- package/dist/src/factories/PlatformResponsibilityFactory.js +0 -25
- package/dist/src/factories/PlatformResponsibilityFactory.js.map +0 -1
- package/dist/src/factories/RecordAnswerFactory.d.ts +0 -17
- package/dist/src/factories/RecordAnswerFactory.d.ts.map +0 -1
- package/dist/src/factories/RecordAnswerFactory.js +0 -95
- package/dist/src/factories/RecordAnswerFactory.js.map +0 -1
- package/dist/src/factories/RecordCategoryFactory.d.ts +0 -11
- package/dist/src/factories/RecordCategoryFactory.d.ts.map +0 -1
- package/dist/src/factories/RecordCategoryFactory.js +0 -23
- package/dist/src/factories/RecordCategoryFactory.js.map +0 -1
- package/dist/src/factories/RecordFactory.d.ts.map +0 -1
- package/dist/src/factories/RecordFactory.js +0 -21
- package/dist/src/factories/RecordFactory.js.map +0 -1
- package/dist/src/factories/RegisterCodeFactory.d.ts.map +0 -1
- package/dist/src/factories/RegisterCodeFactory.js +0 -18
- package/dist/src/factories/RegisterCodeFactory.js.map +0 -1
- package/dist/src/factories/RegistrationFactory.d.ts +0 -21
- package/dist/src/factories/RegistrationFactory.d.ts.map +0 -1
- package/dist/src/factories/RegistrationFactory.js +0 -25
- package/dist/src/factories/RegistrationFactory.js.map +0 -1
- package/dist/src/factories/RegistrationPeriodFactory.d.ts +0 -15
- package/dist/src/factories/RegistrationPeriodFactory.d.ts.map +0 -1
- package/dist/src/factories/RegistrationPeriodFactory.js +0 -34
- package/dist/src/factories/RegistrationPeriodFactory.js.map +0 -1
- package/dist/src/factories/STPackageFactory.d.ts +0 -15
- package/dist/src/factories/STPackageFactory.d.ts.map +0 -1
- package/dist/src/factories/STPackageFactory.js +0 -38
- package/dist/src/factories/STPackageFactory.js.map +0 -1
- package/dist/src/factories/UserFactory.d.ts +0 -22
- package/dist/src/factories/UserFactory.d.ts.map +0 -1
- package/dist/src/factories/UserFactory.js +0 -67
- package/dist/src/factories/UserFactory.js.map +0 -1
- package/dist/src/factories/WebshopFactory.d.ts +0 -16
- package/dist/src/factories/WebshopFactory.d.ts.map +0 -1
- package/dist/src/factories/WebshopFactory.js +0 -39
- package/dist/src/factories/WebshopFactory.js.map +0 -1
- package/dist/src/factories/index.d.ts.map +0 -1
- package/dist/src/factories/index.js +0 -30
- package/dist/src/factories/index.js.map +0 -1
- package/dist/src/helpers/DNSValidator.d.ts +0 -6
- package/dist/src/helpers/DNSValidator.d.ts.map +0 -1
- package/dist/src/helpers/DNSValidator.js +0 -145
- package/dist/src/helpers/DNSValidator.js.map +0 -1
- package/dist/src/helpers/EmailBuilder.d.ts +0 -83
- package/dist/src/helpers/EmailBuilder.d.ts.map +0 -1
- package/dist/src/helpers/EmailBuilder.js +0 -646
- package/dist/src/helpers/EmailBuilder.js.map +0 -1
- package/dist/src/helpers/Handlebars.d.ts.map +0 -1
- package/dist/src/helpers/Handlebars.js +0 -248
- package/dist/src/helpers/Handlebars.js.map +0 -1
- package/dist/src/helpers/MemberMerger.d.ts.map +0 -1
- package/dist/src/helpers/MemberMerger.js +0 -371
- package/dist/src/helpers/MemberMerger.js.map +0 -1
- package/dist/src/helpers/MemberMerger.test.d.ts +0 -2
- package/dist/src/helpers/MemberMerger.test.d.ts.map +0 -1
- package/dist/src/helpers/MemberMerger.test.js +0 -644
- package/dist/src/helpers/MemberMerger.test.js.map +0 -1
- package/dist/src/helpers/RateLimiter.d.ts.map +0 -1
- package/dist/src/helpers/RateLimiter.js +0 -69
- package/dist/src/helpers/RateLimiter.js.map +0 -1
- package/dist/src/helpers/WebshopCounter.d.ts +0 -8
- package/dist/src/helpers/WebshopCounter.d.ts.map +0 -1
- package/dist/src/helpers/WebshopCounter.js +0 -50
- package/dist/src/helpers/WebshopCounter.js.map +0 -1
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/index.js +0 -14
- package/dist/src/index.js.map +0 -1
- package/dist/src/migrations/1605262045-import-postcodes.js +0 -121
- package/dist/src/migrations/1605262046-import-postcodes-nl.js +0 -83
- package/dist/src/models/AuditLog.d.ts.map +0 -1
- package/dist/src/models/AuditLog.js +0 -98
- package/dist/src/models/AuditLog.js.map +0 -1
- package/dist/src/models/BalanceItem.d.ts +0 -217
- package/dist/src/models/BalanceItem.d.ts.map +0 -1
- package/dist/src/models/BalanceItem.js +0 -630
- package/dist/src/models/BalanceItem.js.map +0 -1
- package/dist/src/models/BalanceItemPayment.d.ts +0 -23
- package/dist/src/models/BalanceItemPayment.d.ts.map +0 -1
- package/dist/src/models/BalanceItemPayment.js +0 -70
- package/dist/src/models/BalanceItemPayment.js.map +0 -1
- package/dist/src/models/BuckarooPayment.d.ts.map +0 -1
- package/dist/src/models/BuckarooPayment.js +0 -28
- package/dist/src/models/BuckarooPayment.js.map +0 -1
- package/dist/src/models/CachedBalance.d.ts +0 -50
- package/dist/src/models/CachedBalance.d.ts.map +0 -1
- package/dist/src/models/CachedBalance.js +0 -394
- package/dist/src/models/CachedBalance.js.map +0 -1
- package/dist/src/models/Document.d.ts +0 -41
- package/dist/src/models/Document.d.ts.map +0 -1
- package/dist/src/models/Document.js +0 -255
- package/dist/src/models/Document.js.map +0 -1
- package/dist/src/models/DocumentTemplate.d.ts +0 -55
- package/dist/src/models/DocumentTemplate.d.ts.map +0 -1
- package/dist/src/models/DocumentTemplate.js +0 -723
- package/dist/src/models/DocumentTemplate.js.map +0 -1
- package/dist/src/models/DocumentTemplate.test.d.ts +0 -2
- package/dist/src/models/DocumentTemplate.test.d.ts.map +0 -1
- package/dist/src/models/DocumentTemplate.test.js +0 -57
- package/dist/src/models/DocumentTemplate.test.js.map +0 -1
- package/dist/src/models/Email.d.ts +0 -140
- package/dist/src/models/Email.d.ts.map +0 -1
- package/dist/src/models/Email.js +0 -1345
- package/dist/src/models/Email.js.map +0 -1
- package/dist/src/models/Email.test.d.ts +0 -2
- package/dist/src/models/Email.test.d.ts.map +0 -1
- package/dist/src/models/Email.test.js +0 -1036
- package/dist/src/models/Email.test.js.map +0 -1
- package/dist/src/models/EmailRecipient.d.ts.map +0 -1
- package/dist/src/models/EmailRecipient.js +0 -198
- package/dist/src/models/EmailRecipient.js.map +0 -1
- package/dist/src/models/EmailTemplate.d.ts +0 -23
- package/dist/src/models/EmailTemplate.d.ts.map +0 -1
- package/dist/src/models/EmailTemplate.js +0 -83
- package/dist/src/models/EmailTemplate.js.map +0 -1
- package/dist/src/models/EmailVerificationCode.d.ts +0 -59
- package/dist/src/models/EmailVerificationCode.d.ts.map +0 -1
- package/dist/src/models/EmailVerificationCode.js +0 -343
- package/dist/src/models/EmailVerificationCode.js.map +0 -1
- package/dist/src/models/Event.d.ts.map +0 -1
- package/dist/src/models/Event.js +0 -136
- package/dist/src/models/Event.js.map +0 -1
- package/dist/src/models/EventNotification.d.ts +0 -31
- package/dist/src/models/EventNotification.d.ts.map +0 -1
- package/dist/src/models/EventNotification.js +0 -102
- package/dist/src/models/EventNotification.js.map +0 -1
- package/dist/src/models/Group.d.ts +0 -45
- package/dist/src/models/Group.d.ts.map +0 -1
- package/dist/src/models/Group.js +0 -228
- package/dist/src/models/Group.js.map +0 -1
- package/dist/src/models/Image.d.ts +0 -16
- package/dist/src/models/Image.d.ts.map +0 -1
- package/dist/src/models/Image.js +0 -173
- package/dist/src/models/Image.js.map +0 -1
- package/dist/src/models/Invoice.d.ts.map +0 -1
- package/dist/src/models/Invoice.js +0 -190
- package/dist/src/models/Invoice.js.map +0 -1
- package/dist/src/models/InvoicedBalanceItem.d.ts +0 -66
- package/dist/src/models/InvoicedBalanceItem.d.ts.map +0 -1
- package/dist/src/models/InvoicedBalanceItem.js +0 -136
- package/dist/src/models/InvoicedBalanceItem.js.map +0 -1
- package/dist/src/models/Member.d.ts +0 -112
- package/dist/src/models/Member.d.ts.map +0 -1
- package/dist/src/models/Member.js +0 -415
- package/dist/src/models/Member.js.map +0 -1
- package/dist/src/models/MemberPlatformMembership.d.ts +0 -48
- package/dist/src/models/MemberPlatformMembership.d.ts.map +0 -1
- package/dist/src/models/MemberPlatformMembership.js +0 -381
- package/dist/src/models/MemberPlatformMembership.js.map +0 -1
- package/dist/src/models/MemberResponsibilityRecord.d.ts +0 -16
- package/dist/src/models/MemberResponsibilityRecord.d.ts.map +0 -1
- package/dist/src/models/MemberResponsibilityRecord.js +0 -69
- package/dist/src/models/MemberResponsibilityRecord.js.map +0 -1
- package/dist/src/models/MemberUser.d.ts.map +0 -1
- package/dist/src/models/MemberUser.js +0 -26
- package/dist/src/models/MemberUser.js.map +0 -1
- package/dist/src/models/MergedMember.d.ts +0 -23
- package/dist/src/models/MergedMember.d.ts.map +0 -1
- package/dist/src/models/MergedMember.js +0 -127
- package/dist/src/models/MergedMember.js.map +0 -1
- package/dist/src/models/MolliePayment.d.ts.map +0 -1
- package/dist/src/models/MolliePayment.js +0 -28
- package/dist/src/models/MolliePayment.js.map +0 -1
- package/dist/src/models/MollieToken.d.ts +0 -45
- package/dist/src/models/MollieToken.d.ts.map +0 -1
- package/dist/src/models/MollieToken.js +0 -334
- package/dist/src/models/MollieToken.js.map +0 -1
- package/dist/src/models/OneTimeToken.d.ts +0 -38
- package/dist/src/models/OneTimeToken.d.ts.map +0 -1
- package/dist/src/models/OneTimeToken.js +0 -129
- package/dist/src/models/OneTimeToken.js.map +0 -1
- package/dist/src/models/Order.d.ts +0 -112
- package/dist/src/models/Order.d.ts.map +0 -1
- package/dist/src/models/Order.js +0 -906
- package/dist/src/models/Order.js.map +0 -1
- package/dist/src/models/Organization.d.ts +0 -120
- package/dist/src/models/Organization.d.ts.map +0 -1
- package/dist/src/models/Organization.js +0 -828
- package/dist/src/models/Organization.js.map +0 -1
- package/dist/src/models/OrganizationRegistrationPeriod.d.ts +0 -22
- package/dist/src/models/OrganizationRegistrationPeriod.d.ts.map +0 -1
- package/dist/src/models/OrganizationRegistrationPeriod.js +0 -133
- package/dist/src/models/OrganizationRegistrationPeriod.js.map +0 -1
- package/dist/src/models/PasswordToken.d.ts +0 -30
- package/dist/src/models/PasswordToken.d.ts.map +0 -1
- package/dist/src/models/PasswordToken.js +0 -133
- package/dist/src/models/PasswordToken.js.map +0 -1
- package/dist/src/models/PayconiqPayment.d.ts +0 -22
- package/dist/src/models/PayconiqPayment.d.ts.map +0 -1
- package/dist/src/models/PayconiqPayment.js +0 -276
- package/dist/src/models/PayconiqPayment.js.map +0 -1
- package/dist/src/models/Payment.d.ts +0 -117
- package/dist/src/models/Payment.d.ts.map +0 -1
- package/dist/src/models/Payment.js +0 -293
- package/dist/src/models/Payment.js.map +0 -1
- package/dist/src/models/Platform.d.ts.map +0 -1
- package/dist/src/models/Platform.js +0 -182
- package/dist/src/models/Platform.js.map +0 -1
- package/dist/src/models/Platform.test.d.ts +0 -2
- package/dist/src/models/Platform.test.d.ts.map +0 -1
- package/dist/src/models/Platform.test.js +0 -90
- package/dist/src/models/Platform.test.js.map +0 -1
- package/dist/src/models/RegisterCode.d.ts.map +0 -1
- package/dist/src/models/RegisterCode.js +0 -80
- package/dist/src/models/RegisterCode.js.map +0 -1
- package/dist/src/models/Registration.d.ts +0 -93
- package/dist/src/models/Registration.d.ts.map +0 -1
- package/dist/src/models/Registration.js +0 -267
- package/dist/src/models/Registration.js.map +0 -1
- package/dist/src/models/RegistrationPeriod.d.ts.map +0 -1
- package/dist/src/models/RegistrationPeriod.js +0 -144
- package/dist/src/models/RegistrationPeriod.js.map +0 -1
- package/dist/src/models/STCredit.d.ts.map +0 -1
- package/dist/src/models/STCredit.js +0 -65
- package/dist/src/models/STCredit.js.map +0 -1
- package/dist/src/models/STInvoice.d.ts +0 -37
- package/dist/src/models/STInvoice.d.ts.map +0 -1
- package/dist/src/models/STInvoice.js +0 -145
- package/dist/src/models/STInvoice.js.map +0 -1
- package/dist/src/models/STPackage.d.ts.map +0 -1
- package/dist/src/models/STPackage.js +0 -280
- package/dist/src/models/STPackage.js.map +0 -1
- package/dist/src/models/STPendingInvoice.d.ts +0 -26
- package/dist/src/models/STPendingInvoice.d.ts.map +0 -1
- package/dist/src/models/STPendingInvoice.js +0 -73
- package/dist/src/models/STPendingInvoice.js.map +0 -1
- package/dist/src/models/StripeAccount.d.ts.map +0 -1
- package/dist/src/models/StripeAccount.js +0 -85
- package/dist/src/models/StripeAccount.js.map +0 -1
- package/dist/src/models/StripeCheckoutSession.d.ts.map +0 -1
- package/dist/src/models/StripeCheckoutSession.js +0 -39
- package/dist/src/models/StripeCheckoutSession.js.map +0 -1
- package/dist/src/models/StripePaymentIntent.d.ts.map +0 -1
- package/dist/src/models/StripePaymentIntent.js +0 -39
- package/dist/src/models/StripePaymentIntent.js.map +0 -1
- package/dist/src/models/Ticket.d.ts +0 -63
- package/dist/src/models/Ticket.d.ts.map +0 -1
- package/dist/src/models/Ticket.js +0 -162
- package/dist/src/models/Ticket.js.map +0 -1
- package/dist/src/models/Token.d.ts +0 -48
- package/dist/src/models/Token.d.ts.map +0 -1
- package/dist/src/models/Token.js +0 -212
- package/dist/src/models/Token.js.map +0 -1
- package/dist/src/models/Token.test.d.ts +0 -2
- package/dist/src/models/Token.test.d.ts.map +0 -1
- package/dist/src/models/Token.test.js +0 -60
- package/dist/src/models/Token.test.js.map +0 -1
- package/dist/src/models/UitpasClientCredential.d.ts.map +0 -1
- package/dist/src/models/UitpasClientCredential.js +0 -66
- package/dist/src/models/UitpasClientCredential.js.map +0 -1
- package/dist/src/models/UsedRegisterCode.d.ts.map +0 -1
- package/dist/src/models/UsedRegisterCode.js +0 -62
- package/dist/src/models/UsedRegisterCode.js.map +0 -1
- package/dist/src/models/User.d.ts +0 -77
- package/dist/src/models/User.d.ts.map +0 -1
- package/dist/src/models/User.js +0 -490
- package/dist/src/models/User.js.map +0 -1
- package/dist/src/models/UserPermissions.d.ts +0 -16
- package/dist/src/models/UserPermissions.d.ts.map +0 -1
- package/dist/src/models/UserPermissions.js +0 -61
- package/dist/src/models/UserPermissions.js.map +0 -1
- package/dist/src/models/Webshop.d.ts +0 -45
- package/dist/src/models/Webshop.d.ts.map +0 -1
- package/dist/src/models/Webshop.js +0 -192
- package/dist/src/models/Webshop.js.map +0 -1
- package/dist/src/models/WebshopDiscountCode.d.ts.map +0 -1
- package/dist/src/models/WebshopDiscountCode.js +0 -93
- package/dist/src/models/WebshopDiscountCode.js.map +0 -1
- package/dist/src/models/WebshopUitpasNumber.d.ts.map +0 -1
- package/dist/src/models/WebshopUitpasNumber.js +0 -95
- package/dist/src/models/WebshopUitpasNumber.js.map +0 -1
- package/dist/src/models/addresses/City.d.ts +0 -15
- package/dist/src/models/addresses/City.d.ts.map +0 -1
- package/dist/src/models/addresses/City.js +0 -39
- package/dist/src/models/addresses/City.js.map +0 -1
- package/dist/src/models/addresses/PostalCode.d.ts +0 -21
- package/dist/src/models/addresses/PostalCode.d.ts.map +0 -1
- package/dist/src/models/addresses/PostalCode.js +0 -143
- package/dist/src/models/addresses/PostalCode.js.map +0 -1
- package/dist/src/models/addresses/PostalCode.test.d.ts +0 -2
- package/dist/src/models/addresses/PostalCode.test.d.ts.map +0 -1
- package/dist/src/models/addresses/PostalCode.test.js +0 -98
- package/dist/src/models/addresses/PostalCode.test.js.map +0 -1
- package/dist/src/models/addresses/Province.d.ts +0 -9
- package/dist/src/models/addresses/Province.d.ts.map +0 -1
- package/dist/src/models/addresses/Province.js +0 -28
- package/dist/src/models/addresses/Province.js.map +0 -1
- package/dist/src/models/addresses/Street.d.ts.map +0 -1
- package/dist/src/models/addresses/Street.js +0 -30
- package/dist/src/models/addresses/Street.js.map +0 -1
- package/dist/src/models/index.d.ts +0 -54
- package/dist/src/models/index.d.ts.map +0 -1
- package/dist/src/models/index.js +0 -69
- package/dist/src/models/index.js.map +0 -1
- package/dist/src/structures/OrganizationServerMetaData.d.ts.map +0 -1
- package/dist/src/structures/OrganizationServerMetaData.js +0 -135
- package/dist/src/structures/OrganizationServerMetaData.js.map +0 -1
- package/dist/tests/jest.global.setup.d.ts +0 -3
- package/dist/tests/jest.global.setup.d.ts.map +0 -1
- package/dist/tests/jest.global.setup.js +0 -33
- package/dist/tests/jest.global.setup.js.map +0 -1
- package/dist/tests/jest.setup.d.ts +0 -2
- package/dist/tests/jest.setup.d.ts.map +0 -1
- package/dist/tests/jest.setup.js +0 -32
- package/dist/tests/jest.setup.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- /package/dist/{src/assets → assets}/Metropolis-Black.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-BlackItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-Bold.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-BoldItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-ExtraBold.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-ExtraBoldItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-ExtraLight.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-ExtraLightItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-Light.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-LightItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-Medium.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-MediumItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-Regular.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-RegularItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-SemiBold.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-SemiBoldItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-Thin.woff2 +0 -0
- /package/dist/{src/assets → assets}/Metropolis-ThinItalic.woff2 +0 -0
- /package/dist/{src/assets → assets}/logo.png +0 -0
- /package/dist/{src/factories → factories}/AddressFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/EmergencyContactFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/OrganizationTagFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/ParentFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/PlatformEventTypeFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/PlatformResponsibilityFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/RecordFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/RegisterCodeFactory.d.ts +0 -0
- /package/dist/{src/factories → factories}/index.d.ts +0 -0
- /package/dist/{src/helpers → helpers}/Handlebars.d.ts +0 -0
- /package/dist/{src/helpers → helpers}/MemberMerger.d.ts +0 -0
- /package/dist/{src/helpers → helpers}/RateLimiter.d.ts +0 -0
- /package/dist/{src/index.d.ts → index.d.ts} +0 -0
- /package/dist/{src/migrations → migrations}/1593773929-create-initial-tables.sql +0 -0
- /package/dist/{src/migrations → migrations}/1605261999-gemeenten-tmp.sql +0 -0
- /package/dist/{src/migrations → migrations}/1605262045-import-postcodes.d.ts +0 -0
- /package/dist/{src/migrations → migrations}/1605262046-import-postcodes-nl.d.ts +0 -0
- /package/dist/{src/migrations → migrations}/1605279038-drop-gemeenten-tmp.sql +0 -0
- /package/dist/{src/migrations → migrations}/1708607340-tickets-deleted-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1710459176-register-code-invoices.sql +0 -0
- /package/dist/{src/migrations → migrations}/1712158247-discount-codes.sql +0 -0
- /package/dist/{src/migrations → migrations}/1713178665-drop-invites.sql +0 -0
- /package/dist/{src/migrations → migrations}/1713178666-drop-keychain.sql +0 -0
- /package/dist/{src/migrations → migrations}/1713178667-drop-challenges.sql +0 -0
- /package/dist/{src/migrations → migrations}/1713178668-drop-user-keys.sql +0 -0
- /package/dist/{src/migrations → migrations}/1713178669-drop-organization-key.sql +0 -0
- /package/dist/{src/migrations → migrations}/1714985451-user-nullable-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1714985452-email-verification-code-nullable-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1714985453-user-organization-permissions.sql +0 -0
- /package/dist/{src/migrations → migrations}/1714985454-user-organization-permissions.sql +0 -0
- /package/dist/{src/migrations → migrations}/1715079362-platform.sql +0 -0
- /package/dist/{src/migrations → migrations}/1715181649-registrations-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1715181650-registrations-organization-id-fill.sql +0 -0
- /package/dist/{src/migrations → migrations}/1715181651-registrations-organization-id-drop-null.sql +0 -0
- /package/dist/{src/migrations → migrations}/1716117067-members-nullable-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719567581-registration-periods.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719567582-organization-registration-periods.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719567881-organization-periodId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719567882-groups-periodId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719567883-platform-periodId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719568079-default-period.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719568080-set-default-period-platform.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719568081-set-default-period-organizations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719568082-set-default-period-groups.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719580828-registrations-periodId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719580829-set-default-period-registrations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1719931362-groups-default-age-group-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1720080975-convert-charset.sql +0 -0
- /package/dist/{src/migrations → migrations}/1720080976-responsibilities.sql +0 -0
- /package/dist/{src/migrations → migrations}/1720088136-member-membership-types.sql +0 -0
- /package/dist/{src/migrations → migrations}/1720088137-member-membership-types-expire-date.sql +0 -0
- /package/dist/{src/migrations → migrations}/1720444931-organization-active.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721050380-email-table.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721050381-email-recipients-table.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721342679-responsibility-groupId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721342680-responsibility-groupId-foreign-key.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721400546-users-memberId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721639159-membership-deleted-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721639160-membership-generated.sql +0 -0
- /package/dist/{src/migrations → migrations}/1721841819-group-type.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722090482-events.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722269236-group-waitinglist-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722525785-balance-item-paying-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722525787-depending-balance-item.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722845608-registration-stock-reservations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722845609-group-stock-reservations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722852362-stripe-intents-account-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722852363-stripe-checkout-sessions-account-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722959111-allow-multiple-registrations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1722963554-registration-group-price-and-options.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723202125-member-number.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723202126-member-number-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723218160-balance-item-unit-price.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723218161-balance-item-amount.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723218162-balance-item-type.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723218163-balance-item-type-defaults.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723218164-balance-item-relations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723652795-payments-paying-user-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723652796-payments-paying-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723652797-payments-paying-organization-id-fk.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723652798-payments-customer.sql +0 -0
- /package/dist/{src/migrations → migrations}/1723736282-merged-members.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724076162-setup-steps.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724156666-member-indexes.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724156667-organization-tag-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724256125-membership-balance-item-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724256126-membership-balance-item-fk.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724258844-membershipOrganizationId.sql +0 -0
- /package/dist/{src/migrations → migrations}/1724258845-membershipOrganizationId-fk.sql +0 -0
- /package/dist/{src/migrations → migrations}/1726054851-balance-item-price-pending.sql +0 -0
- /package/dist/{src/migrations → migrations}/1726054852-cached-outstanding-balances.sql +0 -0
- /package/dist/{src/migrations → migrations}/1726668114-maximum-free-amount.sql +0 -0
- /package/dist/{src/migrations → migrations}/1726668115-free-amount.sql +0 -0
- /package/dist/{src/migrations → migrations}/1726668116-price-without-discount.sql +0 -0
- /package/dist/{src/migrations → migrations}/1727947041-registration-record-answers.sql +0 -0
- /package/dist/{src/migrations → migrations}/1729251385-order-extra-filter-columns.sql +0 -0
- /package/dist/{src/migrations → migrations}/1732285080-audit-logs.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733129611-clear-audit-logs.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733129612-audit-logs-source.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733317908-added-missing-organization-fk-on-registrations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733317909-paying-organization-id-registrations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733317910-paying-organization-id-fk.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733410641-audit-log-external-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733418667-desc-audit-log-primary-key.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733909398-balance-items-due-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733909399-recalculate-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1733994454-balance-item-price-open.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734084689-payment-type.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734084690-move-payment-column-order.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734084691-fill-payment-type-refunds.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734084692-fill-payment-type-reallocations.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734429094-registration-trial-until.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734429095-membership-trial-until.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734535120-registration-period-previous-period-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734535121-platform-previous-period-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734626607-cached-balance-amount-open.sql +0 -0
- /package/dist/{src/migrations → migrations}/1734698906-cached-balance-amount-paid.sql +0 -0
- /package/dist/{src/migrations → migrations}/1735573520-emails-email-type.sql +0 -0
- /package/dist/{src/migrations → migrations}/1735573521-email-recipients-email-type.sql +0 -0
- /package/dist/{src/migrations → migrations}/1735573522-emails-indexes.sql +0 -0
- /package/dist/{src/migrations → migrations}/1735982691-cached-balance-email-reminder-counts.sql +0 -0
- /package/dist/{src/migrations → migrations}/1736850097-audit-logs-meta.sql +0 -0
- /package/dist/{src/migrations → migrations}/1736947931-platform-server-config.sql +0 -0
- /package/dist/{src/migrations → migrations}/1738922428-membership-locked.sql +0 -0
- /package/dist/{src/migrations → migrations}/1739017508-event-notifications.sql +0 -0
- /package/dist/{src/migrations → migrations}/1739017509-event-notifications-link.sql +0 -0
- /package/dist/{src/migrations → migrations}/1739282590-event-notifications-submitted-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1741954610-event-notifications-accepted-record-answers.sql +0 -0
- /package/dist/{src/migrations → migrations}/1742579832-audit-log-longer-object-size.sql +0 -0
- /package/dist/{src/migrations → migrations}/1747913433-registration-discounts.sql +0 -0
- /package/dist/{src/migrations → migrations}/1747996262-balance-items-paid-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1747996263-balance-items-paid-at-fill.sql +0 -0
- /package/dist/{src/migrations → migrations}/1751633220-create-uitpas-client-credentials.sql +0 -0
- /package/dist/{src/migrations → migrations}/1751970372-create-webshop-uitpas-numbers.sql +0 -0
- /package/dist/{src/migrations → migrations}/1752655335-events-webshop-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1752678047-confirmation-email.sql +0 -0
- /package/dist/{src/migrations → migrations}/1753363434-service-fees.sql +0 -0
- /package/dist/{src/migrations → migrations}/1753430415-update-webshop-uitpasnumbers.sql +0 -0
- /package/dist/{src/migrations → migrations}/1755529026-email-sender-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1755789797-email-counts-errors.sql +0 -0
- /package/dist/{src/migrations → migrations}/1755789798-email-recipient-errors.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756115313-email-recipient-ids-and-errors.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756115314-email-recipient-email-optional.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756115315-email-recipients-count.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756115316-email-cached-counts.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756115317-email-deleted-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756293494-registration-period-next-period-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756293495-platform-next-period-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756387016-registration-period-custom-name.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756391212-email-recipients-duplicate.sql +0 -0
- /package/dist/{src/migrations → migrations}/1756821154-email-send-as-email.sql +0 -0
- /package/dist/{src/migrations → migrations}/1758034021-email-recipient-previous-error.sql +0 -0
- /package/dist/{src/migrations → migrations}/1760535508-update-cached-balances-object-id-unique-constraint.sql +0 -0
- /package/dist/{src/migrations → migrations}/1761750780-renamed-invoice-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1761750781-rename-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1761750782-invoices-add-organization-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1761750783-invoices-organization-id-fk.sql +0 -0
- /package/dist/{src/migrations → migrations}/1762521336-did-send-peppol.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216321-multiply-balance-item-payments.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216322-multiply-balance-items.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216323-bigint-cached-balances.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216324-multiply-cached-balances.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216325-multiply-member-platform-memberships.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216326-multiply-payments.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216327-multiply-register-codes.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216328-multiply-credits.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216329-multiply-orders.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216330-multiply-uitpas-numbers.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216331-balance-item-vat-percentages.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216332-balance-item-price-total.sql +0 -0
- /package/dist/{src/migrations → migrations}/1763216333-balance-item-price-total-fill.sql +0 -0
- /package/dist/{src/migrations → migrations}/1765895470-document-year.sql +0 -0
- /package/dist/{src/migrations → migrations}/1766150401-document-published-at.sql +0 -0
- /package/dist/{src/migrations → migrations}/1766410598-registration-end-date.sql +0 -0
- /package/dist/{src/migrations → migrations}/1769087807-invoices-table.sql +0 -0
- /package/dist/{src/migrations → migrations}/1769087808-invoiced-balance-items-table.sql +0 -0
- /package/dist/{src/migrations → migrations}/1769087809-payments-invoice-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1769621227-payments-rounding-amount.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917406-create-cached-balances-global-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917407-create-member-name-ordering-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917408-create-member-name-ordering-index-desc.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917409-create-member-age-ordering-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917410-create-member-age-ordering-index-desc.sql +0 -0
- /package/dist/{src/migrations → migrations}/1770917411-drop-duplicate-member-indexes.sql +0 -0
- /package/dist/{src/migrations → migrations}/1771510518-events-index-organization-id-start-date.sql +0 -0
- /package/dist/{src/migrations → migrations}/1771918307-membership-active-filter-index.sql +0 -0
- /package/dist/{src/migrations → migrations}/1772033555-balance-item-package-id.sql +0 -0
- /package/dist/{src/migrations → migrations}/1772033715-balance-item-start-end-date.sql +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Drenthe +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Flevoland +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Friesland +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Gelderland +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Groningen +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Limburg +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Noord-Brabant +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Noord-Holland +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Overrijsel +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Utrecht +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Zeeland +0 -0
- /package/dist/{src/migrations → migrations}/data/postcodes/nl/Zuid-Holland +0 -0
- /package/dist/{src/models → models}/AuditLog.d.ts +0 -0
- /package/dist/{src/models → models}/BuckarooPayment.d.ts +0 -0
- /package/dist/{src/models → models}/EmailRecipient.d.ts +0 -0
- /package/dist/{src/models → models}/Event.d.ts +0 -0
- /package/dist/{src/models → models}/Invoice.d.ts +0 -0
- /package/dist/{src/models → models}/MemberUser.d.ts +0 -0
- /package/dist/{src/models → models}/MolliePayment.d.ts +0 -0
- /package/dist/{src/models → models}/Platform.d.ts +0 -0
- /package/dist/{src/models → models}/RegisterCode.d.ts +0 -0
- /package/dist/{src/models → models}/RegistrationPeriod.d.ts +0 -0
- /package/dist/{src/models → models}/STCredit.d.ts +0 -0
- /package/dist/{src/models → models}/STPackage.d.ts +0 -0
- /package/dist/{src/models → models}/StripeAccount.d.ts +0 -0
- /package/dist/{src/models → models}/StripeCheckoutSession.d.ts +0 -0
- /package/dist/{src/models → models}/StripePaymentIntent.d.ts +0 -0
- /package/dist/{src/models → models}/UitpasClientCredential.d.ts +0 -0
- /package/dist/{src/models → models}/UsedRegisterCode.d.ts +0 -0
- /package/dist/{src/models → models}/WebshopDiscountCode.d.ts +0 -0
- /package/dist/{src/models → models}/WebshopUitpasNumber.d.ts +0 -0
- /package/dist/{src/models → models}/addresses/Street.d.ts +0 -0
- /package/dist/{src/structures → structures}/OrganizationServerMetaData.d.ts +0 -0
|
@@ -0,0 +1,331 @@
|
|
|
1
|
+
import { BalanceItemStatus } from '../../../../../shared/structures/dist/BalanceItem.js';
|
|
2
|
+
import { ReceivableBalanceType } from '../../../../../shared/structures/dist/ReceivableBalance.js';
|
|
3
|
+
import { MemberFactory } from '../factories/MemberFactory.js';
|
|
4
|
+
import { OrganizationFactory } from '../factories/OrganizationFactory.js';
|
|
5
|
+
import { UserFactory } from '../factories/UserFactory.js';
|
|
6
|
+
import { BalanceItem } from './BalanceItem.js';
|
|
7
|
+
import { CachedBalance } from './CachedBalance.js';
|
|
8
|
+
import { Member } from './Member.js';
|
|
9
|
+
|
|
10
|
+
describe('CachedBalance', () => {
|
|
11
|
+
const now = new Date('2024-05-01T00:00:00Z');
|
|
12
|
+
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
// Mock datetime
|
|
15
|
+
vitest.useFakeTimers({ toFake: ['Date'] }).setSystemTime(now);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
afterAll(() => {
|
|
19
|
+
vitest.useRealTimers();
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
test('Balances for members are summed', async () => {
|
|
23
|
+
const organization = await new OrganizationFactory({}).create();
|
|
24
|
+
const member = await new MemberFactory({organization}).create();
|
|
25
|
+
|
|
26
|
+
const balanceA = new BalanceItem();
|
|
27
|
+
balanceA.dueAt = null
|
|
28
|
+
balanceA.quantity = 2;
|
|
29
|
+
balanceA.unitPrice = 1_00;
|
|
30
|
+
balanceA.memberId = member.id;
|
|
31
|
+
balanceA.organizationId = organization.id;
|
|
32
|
+
balanceA.status = BalanceItemStatus.Due
|
|
33
|
+
await balanceA.save();
|
|
34
|
+
|
|
35
|
+
// Update cached balance for user.
|
|
36
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
37
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
38
|
+
expect(cached).toHaveLength(1);
|
|
39
|
+
expect(cached[0].amountOpen).toBe(2_00);
|
|
40
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
41
|
+
expect(cached[0].amountPending).toBe(0);
|
|
42
|
+
expect(cached[0].nextDueAt).toBe(null);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
test('Balances less than 7 days in the future are summed', async () => {
|
|
46
|
+
const organization = await new OrganizationFactory({}).create();
|
|
47
|
+
const member = await new MemberFactory({organization}).create();
|
|
48
|
+
|
|
49
|
+
const balanceA = new BalanceItem();
|
|
50
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 6); // 6 days later
|
|
51
|
+
balanceA.quantity = 1;
|
|
52
|
+
balanceA.unitPrice = 1_00;
|
|
53
|
+
balanceA.memberId = member.id;
|
|
54
|
+
balanceA.organizationId = organization.id;
|
|
55
|
+
balanceA.status = BalanceItemStatus.Due
|
|
56
|
+
await balanceA.save();
|
|
57
|
+
|
|
58
|
+
// Update cached balance for user.
|
|
59
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
60
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
61
|
+
expect(cached).toHaveLength(1);
|
|
62
|
+
expect(cached[0].amountOpen).toBe(1_00);
|
|
63
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
64
|
+
expect(cached[0].amountPending).toBe(0);
|
|
65
|
+
expect(cached[0].nextDueAt).toEqual(null);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
test('Balances more than 7 days in the future are not summed', async () => {
|
|
69
|
+
const organization = await new OrganizationFactory({}).create();
|
|
70
|
+
const member = await new MemberFactory({organization}).create();
|
|
71
|
+
|
|
72
|
+
const balanceA = new BalanceItem();
|
|
73
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 8); // 8 days later
|
|
74
|
+
balanceA.quantity = 1;
|
|
75
|
+
balanceA.unitPrice = 1_00;
|
|
76
|
+
balanceA.memberId = member.id;
|
|
77
|
+
balanceA.organizationId = organization.id;
|
|
78
|
+
balanceA.status = BalanceItemStatus.Due
|
|
79
|
+
await balanceA.save();
|
|
80
|
+
|
|
81
|
+
// Update cached balance for user.
|
|
82
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
83
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
84
|
+
expect(cached).toHaveLength(1);
|
|
85
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
86
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
87
|
+
expect(cached[0].amountPending).toBe(0);
|
|
88
|
+
expect(cached[0].nextDueAt).toEqual(balanceA.dueAt);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
test('Paid balances more than 7 days in the future are summed', async () => {
|
|
92
|
+
const organization = await new OrganizationFactory({}).create();
|
|
93
|
+
const member = await new MemberFactory({organization}).create();
|
|
94
|
+
|
|
95
|
+
const balanceA = new BalanceItem();
|
|
96
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 8); // 8 days later
|
|
97
|
+
balanceA.quantity = 2;
|
|
98
|
+
balanceA.unitPrice = 1_00;
|
|
99
|
+
balanceA.memberId = member.id;
|
|
100
|
+
balanceA.organizationId = organization.id;
|
|
101
|
+
balanceA.status = BalanceItemStatus.Due
|
|
102
|
+
balanceA.pricePaid = 2_00;
|
|
103
|
+
await balanceA.save();
|
|
104
|
+
|
|
105
|
+
// Update cached balance for user.
|
|
106
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
107
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
108
|
+
expect(cached).toHaveLength(1);
|
|
109
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
110
|
+
expect(cached[0].amountPaid).toBe(2_00);
|
|
111
|
+
expect(cached[0].amountPending).toBe(0);
|
|
112
|
+
expect(cached[0].nextDueAt).toEqual(null);
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
test('Paid balances more than 7 days in the future are summed and due at is still set if only partially paid', async () => {
|
|
116
|
+
const organization = await new OrganizationFactory({}).create();
|
|
117
|
+
const member = await new MemberFactory({organization}).create();
|
|
118
|
+
|
|
119
|
+
const balanceA = new BalanceItem();
|
|
120
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 8); // 8 days later
|
|
121
|
+
balanceA.quantity = 2;
|
|
122
|
+
balanceA.unitPrice = 1_00;
|
|
123
|
+
balanceA.memberId = member.id;
|
|
124
|
+
balanceA.organizationId = organization.id;
|
|
125
|
+
balanceA.status = BalanceItemStatus.Due
|
|
126
|
+
balanceA.pricePaid = 1_00;
|
|
127
|
+
await balanceA.save();
|
|
128
|
+
|
|
129
|
+
// Update cached balance for user.
|
|
130
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
131
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
132
|
+
expect(cached).toHaveLength(1);
|
|
133
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
134
|
+
expect(cached[0].amountPaid).toBe(1_00);
|
|
135
|
+
expect(cached[0].amountPending).toBe(0);
|
|
136
|
+
expect(cached[0].nextDueAt).toEqual(balanceA.dueAt);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
test('Canceled items are not summed', async () => {
|
|
140
|
+
const organization = await new OrganizationFactory({}).create();
|
|
141
|
+
const member = await new MemberFactory({organization}).create();
|
|
142
|
+
|
|
143
|
+
const balanceA = new BalanceItem();
|
|
144
|
+
balanceA.dueAt = null;
|
|
145
|
+
balanceA.quantity = 1;
|
|
146
|
+
balanceA.unitPrice = 1_00;
|
|
147
|
+
balanceA.memberId = member.id;
|
|
148
|
+
balanceA.organizationId = organization.id;
|
|
149
|
+
balanceA.status = BalanceItemStatus.Canceled
|
|
150
|
+
await balanceA.save();
|
|
151
|
+
|
|
152
|
+
// Update cached balance for user.
|
|
153
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
154
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
155
|
+
expect(cached).toHaveLength(1);
|
|
156
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
157
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
158
|
+
expect(cached[0].amountPending).toBe(0);
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
test('Hidden items are not summed', async () => {
|
|
162
|
+
const organization = await new OrganizationFactory({}).create();
|
|
163
|
+
const member = await new MemberFactory({organization}).create();
|
|
164
|
+
|
|
165
|
+
const balanceA = new BalanceItem();
|
|
166
|
+
balanceA.dueAt = null;
|
|
167
|
+
balanceA.quantity = 1;
|
|
168
|
+
balanceA.unitPrice = 1_00;
|
|
169
|
+
balanceA.memberId = member.id;
|
|
170
|
+
balanceA.organizationId = organization.id;
|
|
171
|
+
balanceA.status = BalanceItemStatus.Hidden
|
|
172
|
+
await balanceA.save();
|
|
173
|
+
|
|
174
|
+
// Update cached balance for user.
|
|
175
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
176
|
+
const cached = await CachedBalance.getForObjects([member.id], organization.id, ReceivableBalanceType.member);
|
|
177
|
+
expect(cached).toHaveLength(1);
|
|
178
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
179
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
180
|
+
expect(cached[0].amountPending).toBe(0);
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
describe('nextDueAt for users with members', () => {
|
|
184
|
+
test('Two balance items in the future are merged if less than 7 days in the future', async () => {
|
|
185
|
+
const organization = await new OrganizationFactory({}).create();
|
|
186
|
+
const member = await new MemberFactory({organization}).create();
|
|
187
|
+
const user = await new UserFactory({organization}).create();
|
|
188
|
+
|
|
189
|
+
// Link member with user
|
|
190
|
+
await Member.users.reverse('members').link(user, [member]);
|
|
191
|
+
|
|
192
|
+
const balanceA = new BalanceItem();
|
|
193
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60); // 1 hour later
|
|
194
|
+
balanceA.quantity = 1;
|
|
195
|
+
balanceA.unitPrice = 1_00;
|
|
196
|
+
balanceA.memberId = member.id;
|
|
197
|
+
balanceA.organizationId = organization.id;
|
|
198
|
+
balanceA.status = BalanceItemStatus.Due
|
|
199
|
+
await balanceA.save();
|
|
200
|
+
|
|
201
|
+
const balanceB = new BalanceItem();
|
|
202
|
+
balanceB.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 2); // 2 hours later
|
|
203
|
+
balanceB.quantity = 1;
|
|
204
|
+
balanceB.unitPrice = 1_00;
|
|
205
|
+
balanceB.userId = user.id;
|
|
206
|
+
balanceB.organizationId = organization.id;
|
|
207
|
+
balanceB.status = BalanceItemStatus.Due
|
|
208
|
+
await balanceB.save();
|
|
209
|
+
|
|
210
|
+
// Update cached balance for user.
|
|
211
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
212
|
+
await CachedBalance.updateForUsers(organization.id, [user.id])
|
|
213
|
+
{
|
|
214
|
+
const cached = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.user);
|
|
215
|
+
expect(cached).toHaveLength(1);
|
|
216
|
+
expect(cached[0].amountOpen).toBe(2_00);
|
|
217
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
218
|
+
expect(cached[0].amountPending).toBe(0);
|
|
219
|
+
expect(cached[0].nextDueAt).toBe(null);
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
{
|
|
223
|
+
const cached = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.userWithoutMembers);
|
|
224
|
+
expect(cached).toHaveLength(1);
|
|
225
|
+
expect(cached[0].amountOpen).toBe(1_00);
|
|
226
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
227
|
+
expect(cached[0].amountPending).toBe(0);
|
|
228
|
+
expect(cached[0].nextDueAt).toBe(null);
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
test('[Regression] Two balance items more than 7 days in the future set correct nextDueAt', async () => {
|
|
233
|
+
const organization = await new OrganizationFactory({}).create();
|
|
234
|
+
const member = await new MemberFactory({organization}).create();
|
|
235
|
+
const user = await new UserFactory({organization}).create();
|
|
236
|
+
|
|
237
|
+
// Link member with user
|
|
238
|
+
await Member.users.reverse('members').link(user, [member]);
|
|
239
|
+
|
|
240
|
+
const balanceA = new BalanceItem();
|
|
241
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 8); // 8 days later
|
|
242
|
+
balanceA.quantity = 1;
|
|
243
|
+
balanceA.unitPrice = 1_00;
|
|
244
|
+
balanceA.memberId = member.id;
|
|
245
|
+
balanceA.organizationId = organization.id;
|
|
246
|
+
balanceA.status = BalanceItemStatus.Due
|
|
247
|
+
await balanceA.save();
|
|
248
|
+
|
|
249
|
+
const balanceB = new BalanceItem();
|
|
250
|
+
balanceB.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 9); // 9 days later
|
|
251
|
+
balanceB.quantity = 1;
|
|
252
|
+
balanceB.unitPrice = 1_00;
|
|
253
|
+
balanceB.userId = user.id;
|
|
254
|
+
balanceB.organizationId = organization.id;
|
|
255
|
+
balanceB.status = BalanceItemStatus.Due
|
|
256
|
+
await balanceB.save();
|
|
257
|
+
|
|
258
|
+
// Update cached balance for user.
|
|
259
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
260
|
+
await CachedBalance.updateForUsers(organization.id, [user.id])
|
|
261
|
+
{
|
|
262
|
+
const cached = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.user);
|
|
263
|
+
expect(cached).toHaveLength(1);
|
|
264
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
265
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
266
|
+
expect(cached[0].amountPending).toBe(0);
|
|
267
|
+
expect(cached[0].nextDueAt).toEqual(balanceA.dueAt);
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
{
|
|
271
|
+
const cached = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.userWithoutMembers);
|
|
272
|
+
expect(cached).toHaveLength(1);
|
|
273
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
274
|
+
expect(cached[0].amountPaid).toBe(0);
|
|
275
|
+
expect(cached[0].amountPending).toBe(0);
|
|
276
|
+
expect(cached[0].nextDueAt).toEqual(balanceB.dueAt);
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Advance time with one day, balanceA is now less than 7 days in the future and should be included in the cached balance.
|
|
280
|
+
// nextDueAt should be different and set to balanceB.dueAt
|
|
281
|
+
vitest.setSystemTime(new Date(now.getTime() + 1000 * 60 * 60 * 24 * 1))
|
|
282
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
283
|
+
await CachedBalance.updateForUsers(organization.id, [user.id])
|
|
284
|
+
const cachedAfter = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.user);
|
|
285
|
+
expect(cachedAfter).toHaveLength(1);
|
|
286
|
+
expect(cachedAfter[0].amountOpen).toBe(1_00);
|
|
287
|
+
expect(cachedAfter[0].amountPaid).toBe(0);
|
|
288
|
+
expect(cachedAfter[0].amountPending).toBe(0);
|
|
289
|
+
expect(cachedAfter[0].nextDueAt).toEqual(balanceB.dueAt);
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
test('Two balance items more than 7 days in the future that are partially paid are summed correctly', async () => {
|
|
293
|
+
const organization = await new OrganizationFactory({}).create();
|
|
294
|
+
const member = await new MemberFactory({organization}).create();
|
|
295
|
+
const user = await new UserFactory({organization}).create();
|
|
296
|
+
|
|
297
|
+
// Link member with user
|
|
298
|
+
await Member.users.reverse('members').link(user, [member]);
|
|
299
|
+
|
|
300
|
+
const balanceA = new BalanceItem();
|
|
301
|
+
balanceA.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 8); // 8 days later
|
|
302
|
+
balanceA.quantity = 1;
|
|
303
|
+
balanceA.unitPrice = 1_00;
|
|
304
|
+
balanceA.memberId = member.id;
|
|
305
|
+
balanceA.organizationId = organization.id;
|
|
306
|
+
balanceA.pricePaid = 50;
|
|
307
|
+
balanceA.status = BalanceItemStatus.Due
|
|
308
|
+
await balanceA.save();
|
|
309
|
+
|
|
310
|
+
const balanceB = new BalanceItem();
|
|
311
|
+
balanceB.dueAt = new Date(now.getTime() + 1000 * 60 * 60 * 24 * 9); // 9 days later
|
|
312
|
+
balanceB.quantity = 1;
|
|
313
|
+
balanceB.unitPrice = 1_00;
|
|
314
|
+
balanceB.userId = user.id;
|
|
315
|
+
balanceB.organizationId = organization.id;
|
|
316
|
+
balanceB.pricePaid = 50;
|
|
317
|
+
balanceB.status = BalanceItemStatus.Due
|
|
318
|
+
await balanceB.save();
|
|
319
|
+
|
|
320
|
+
// Update cached balance for user.
|
|
321
|
+
await CachedBalance.updateForMembers(organization.id, [member.id])
|
|
322
|
+
await CachedBalance.updateForUsers(organization.id, [user.id])
|
|
323
|
+
const cached = await CachedBalance.getForObjects([user.id], organization.id, ReceivableBalanceType.user);
|
|
324
|
+
expect(cached).toHaveLength(1);
|
|
325
|
+
expect(cached[0].amountOpen).toBe(0);
|
|
326
|
+
expect(cached[0].amountPaid).toBe(1_00);
|
|
327
|
+
expect(cached[0].amountPending).toBe(0);
|
|
328
|
+
expect(cached[0].nextDueAt).toEqual(balanceA.dueAt);
|
|
329
|
+
});
|
|
330
|
+
});
|
|
331
|
+
});
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { column } from '@simonbackx/simple-database';
|
|
2
|
-
import {
|
|
2
|
+
import type { SQLWhere} from '@stamhoofd/sql';
|
|
3
|
+
import { QueryableModel, SQL, SQLAlias, SQLMin, SQLSelectAs, SQLSum, SQLWhereSign } from '@stamhoofd/sql';
|
|
3
4
|
import { BalanceItemStatus, BalanceItem as BalanceItemStruct, ReceivableBalanceType } from '@stamhoofd/structures';
|
|
4
5
|
import { v4 as uuidv4 } from 'uuid';
|
|
5
6
|
import { BalanceItem } from './BalanceItem.js';
|
|
@@ -458,7 +459,7 @@ export class CachedBalance extends QueryableModel {
|
|
|
458
459
|
result[1].amountPaid += memberCachedBalance.amountPaid;
|
|
459
460
|
result[1].amountOpen += memberCachedBalance.amountOpen;
|
|
460
461
|
result[1].amountPending += memberCachedBalance.amountPending;
|
|
461
|
-
if (memberCachedBalance.nextDueAt && (!result[1].nextDueAt || memberCachedBalance.nextDueAt
|
|
462
|
+
if (memberCachedBalance.nextDueAt && (!result[1].nextDueAt || memberCachedBalance.nextDueAt < result[1].nextDueAt)) {
|
|
462
463
|
result[1].nextDueAt = memberCachedBalance.nextDueAt;
|
|
463
464
|
}
|
|
464
465
|
}
|
package/src/models/Document.ts
CHANGED
|
@@ -5,8 +5,8 @@ import { v4 as uuidv4 } from 'uuid';
|
|
|
5
5
|
|
|
6
6
|
import { QueryableModel } from '@stamhoofd/sql';
|
|
7
7
|
import { render } from '../helpers/Handlebars.js';
|
|
8
|
-
import { Member, MemberWithRegistrations,
|
|
9
|
-
import { Organization } from './Organization.js';
|
|
8
|
+
import type { Member, MemberWithRegistrations, RegistrationWithMember } from './Member.js';
|
|
9
|
+
import type { Organization } from './Organization.js';
|
|
10
10
|
import { Registration } from './Registration.js';
|
|
11
11
|
|
|
12
12
|
export class Document extends QueryableModel {
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { column } from '@simonbackx/simple-database';
|
|
2
2
|
import { isSimpleError, isSimpleErrors, SimpleError } from '@simonbackx/simple-errors';
|
|
3
3
|
import { QueueHandler } from '@stamhoofd/queues';
|
|
4
|
-
import {
|
|
4
|
+
import type { Parent, RecordAnswer} from '@stamhoofd/structures';
|
|
5
|
+
import { BalanceItemStatus, DocumentData, DocumentPrivateSettings, DocumentSettings, DocumentStatus, DocumentTemplatePrivate, GroupType, NationalRegisterNumberOptOut, RecordAddressAnswer, RecordAnswerDecoder, RecordDateAnswer, RecordPriceAnswer, RecordSettings, RecordTextAnswer, RecordType } from '@stamhoofd/structures';
|
|
5
6
|
import { Formatter, Sorter } from '@stamhoofd/utility';
|
|
6
7
|
import { v4 as uuidv4 } from 'uuid';
|
|
7
8
|
|
|
@@ -10,8 +11,9 @@ import { render } from '../helpers/Handlebars.js';
|
|
|
10
11
|
import { BalanceItem } from './BalanceItem.js';
|
|
11
12
|
import { Document } from './Document.js';
|
|
12
13
|
import { Group } from './Group.js';
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
14
|
+
import type { RegistrationWithMember } from './Member.js';
|
|
15
|
+
import { Member } from './Member.js';
|
|
16
|
+
import type { Organization } from './Organization.js';
|
|
15
17
|
import { Registration } from './Registration.js';
|
|
16
18
|
import { User } from './User.js';
|
|
17
19
|
|
package/src/models/Email.test.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import type { LimitedFilteredRequest} from '@stamhoofd/structures';
|
|
2
|
+
import { BalanceItemType, EmailRecipientFilter, EmailRecipientFilterType, EmailRecipientsStatus, EmailRecipient as EmailRecipientStruct, EmailRecipientSubfilter, EmailStatus, OrganizationMetaData, PaginatedResponse } from '@stamhoofd/structures';
|
|
2
3
|
import { Email } from './Email.js';
|
|
3
4
|
import { EmailRecipient } from './EmailRecipient.js';
|
|
4
5
|
import { EmailMocker } from '@stamhoofd/email';
|
|
@@ -217,7 +218,7 @@ describe('Model.Email', () => {
|
|
|
217
218
|
],
|
|
218
219
|
});
|
|
219
220
|
|
|
220
|
-
await expect(model.queueForSending(true)).
|
|
221
|
+
await expect(model.queueForSending(true)).rejects.toThrow();
|
|
221
222
|
await model.refresh();
|
|
222
223
|
|
|
223
224
|
// Check if it was sent correctly
|
|
@@ -284,7 +285,7 @@ describe('Model.Email', () => {
|
|
|
284
285
|
sentAt: null,
|
|
285
286
|
failCount: 1,
|
|
286
287
|
failError: STExpect.simpleErrors([{
|
|
287
|
-
message: /This is a simulated network error (3
|
|
288
|
+
message: /This is a simulated network error ([3-6])/,
|
|
288
289
|
}]),
|
|
289
290
|
firstFailedAt: expect.any(Date),
|
|
290
291
|
lastFailedAt: expect.any(Date),
|
|
@@ -294,7 +295,7 @@ describe('Model.Email', () => {
|
|
|
294
295
|
sentAt: null,
|
|
295
296
|
failCount: 1,
|
|
296
297
|
failError: STExpect.simpleErrors([{
|
|
297
|
-
message: /This is a simulated network error (3
|
|
298
|
+
message: /This is a simulated network error ([3-6])/,
|
|
298
299
|
}]),
|
|
299
300
|
firstFailedAt: expect.any(Date),
|
|
300
301
|
lastFailedAt: expect.any(Date),
|
|
@@ -933,20 +934,20 @@ describe('Model.Email', () => {
|
|
|
933
934
|
subject: `${expectedAmount}`,
|
|
934
935
|
});
|
|
935
936
|
|
|
936
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
937
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
937
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('<p>' + expectedAmount + '</p>');
|
|
938
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(expectedAmount);
|
|
938
939
|
|
|
939
940
|
// Check if the table is correct
|
|
940
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
941
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
942
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
943
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
944
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
945
|
-
|
|
946
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
947
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
948
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
949
|
-
expect(EmailMocker.getSucceededEmail(0).text?.toLowerCase()).
|
|
941
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('<table');
|
|
942
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('2 x '); // amount
|
|
943
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch(Formatter.price(12_99)); // unit price
|
|
944
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('<td>' + expectedAmount); // total price in table
|
|
945
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('Test balance item'); // description
|
|
946
|
+
|
|
947
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch('2 x '); // amount
|
|
948
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(Formatter.price(12_99)); // unit price
|
|
949
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(expectedAmount); // total price in table
|
|
950
|
+
expect(EmailMocker.getSucceededEmail(0).text?.toLowerCase()).toMatch('test balance item'); // description
|
|
950
951
|
}, 15_000);
|
|
951
952
|
|
|
952
953
|
it('The balance is zero for unknown users', async () => {
|
|
@@ -994,16 +995,16 @@ describe('Model.Email', () => {
|
|
|
994
995
|
subject: `${expectedAmount}`,
|
|
995
996
|
});
|
|
996
997
|
|
|
997
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
998
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
998
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('<p>' + expectedAmount + '</p>');
|
|
999
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(expectedAmount);
|
|
999
1000
|
|
|
1000
1001
|
// Check if the table is correct
|
|
1001
|
-
expect(EmailMocker.getSucceededEmail(0).html).not.
|
|
1002
|
-
expect(EmailMocker.getSucceededEmail(0).html).not.
|
|
1003
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
1002
|
+
expect(EmailMocker.getSucceededEmail(0).html).not.toMatch('<table');
|
|
1003
|
+
expect(EmailMocker.getSucceededEmail(0).html).not.toMatch(' x '); // amount
|
|
1004
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch('<p class="description">' + $t('%hX') + '</p>');
|
|
1004
1005
|
|
|
1005
|
-
expect(EmailMocker.getSucceededEmail(0).text).not.
|
|
1006
|
-
expect(EmailMocker.getSucceededEmail(0).text?.toLowerCase()).
|
|
1006
|
+
expect(EmailMocker.getSucceededEmail(0).text).not.toMatch(' x '); // amount
|
|
1007
|
+
expect(EmailMocker.getSucceededEmail(0).text?.toLowerCase()).toMatch($t('%hX').toLowerCase());
|
|
1007
1008
|
}, 15_000);
|
|
1008
1009
|
|
|
1009
1010
|
it('loginDetails are added for existing users without password', async () => {
|
|
@@ -1048,10 +1049,10 @@ describe('Model.Email', () => {
|
|
|
1048
1049
|
expect(await EmailMocker.getSucceededCount()).toBe(1);
|
|
1049
1050
|
expect(await EmailMocker.getFailedCount()).toBe(0);
|
|
1050
1051
|
|
|
1051
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
1052
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch(
|
|
1052
1053
|
$t('%1EB', { email: existingUser.email }),
|
|
1053
1054
|
);
|
|
1054
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
1055
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(
|
|
1055
1056
|
$t('%1EB', { email: existingUser.email }),
|
|
1056
1057
|
);
|
|
1057
1058
|
}, 15_000);
|
|
@@ -1093,10 +1094,10 @@ describe('Model.Email', () => {
|
|
|
1093
1094
|
expect(await EmailMocker.getSucceededCount()).toBe(1);
|
|
1094
1095
|
expect(await EmailMocker.getFailedCount()).toBe(0);
|
|
1095
1096
|
|
|
1096
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
1097
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch(
|
|
1097
1098
|
$t('%1EB', { email: 'unknown@example.com' }),
|
|
1098
1099
|
);
|
|
1099
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
1100
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(
|
|
1100
1101
|
$t('%1EB', { email: 'unknown@example.com' }),
|
|
1101
1102
|
);
|
|
1102
1103
|
}, 15_000);
|
|
@@ -1143,10 +1144,10 @@ describe('Model.Email', () => {
|
|
|
1143
1144
|
expect(await EmailMocker.getSucceededCount()).toBe(1);
|
|
1144
1145
|
expect(await EmailMocker.getFailedCount()).toBe(0);
|
|
1145
1146
|
|
|
1146
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
1147
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch(
|
|
1147
1148
|
$t('%1EA', { email: existingUser.email }),
|
|
1148
1149
|
);
|
|
1149
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
1150
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(
|
|
1150
1151
|
$t('%1EA', { email: existingUser.email }),
|
|
1151
1152
|
);
|
|
1152
1153
|
}, 15_000);
|
|
@@ -1202,13 +1203,13 @@ describe('Model.Email', () => {
|
|
|
1202
1203
|
expect(await EmailMocker.getSucceededCount()).toBe(1);
|
|
1203
1204
|
expect(await EmailMocker.getFailedCount()).toBe(0);
|
|
1204
1205
|
|
|
1205
|
-
expect(EmailMocker.getSucceededEmail(0).html).
|
|
1206
|
+
expect(EmailMocker.getSucceededEmail(0).html).toMatch(
|
|
1206
1207
|
$t('%1EC', {
|
|
1207
1208
|
firstName: Formatter.escapeHtml(member.firstName),
|
|
1208
1209
|
securityCode: `<span class="style-inline-code">${Formatter.escapeHtml(Formatter.spaceString(member.details.securityCode ?? '', 4, '-'))}</span>`,
|
|
1209
1210
|
}),
|
|
1210
1211
|
);
|
|
1211
|
-
expect(EmailMocker.getSucceededEmail(0).text).
|
|
1212
|
+
expect(EmailMocker.getSucceededEmail(0).text).toMatch(
|
|
1212
1213
|
$t('%1EC', {
|
|
1213
1214
|
firstName: member.firstName,
|
|
1214
1215
|
securityCode: Formatter.spaceString(member.details.securityCode ?? '', 4, '-'),
|
package/src/models/Email.ts
CHANGED
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import { column } from '@simonbackx/simple-database';
|
|
2
|
-
import { BaseOrganization,
|
|
2
|
+
import type { BaseOrganization, EmailRecipientFilterType, EmailRecipient as EmailRecipientStruct, EmailTemplateType, PaginatedResponse, StamhoofdFilter, User as UserStruct } from '@stamhoofd/structures';
|
|
3
|
+
import { EmailAttachment, EmailPreview, EmailRecipientFilter, EmailRecipientsStatus, EmailStatus, Email as EmailStruct, EmailWithRecipients, getExampleRecipient, isSoftEmailRecipientError, LimitedFilteredRequest, SortItemDirection } from '@stamhoofd/structures';
|
|
3
4
|
import { v4 as uuidv4 } from 'uuid';
|
|
4
5
|
|
|
5
6
|
import { AnyDecoder, ArrayDecoder } from '@simonbackx/simple-encoding';
|
|
6
7
|
import { isSimpleError, isSimpleErrors, SimpleError, SimpleErrors } from '@simonbackx/simple-errors';
|
|
7
|
-
import { I18n } from '@stamhoofd/backend-i18n';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
8
|
+
import { I18n } from '@stamhoofd/backend-i18n/I18n';
|
|
9
|
+
import type { EmailInterfaceRecipient } from '@stamhoofd/email';
|
|
10
|
+
import { Email as EmailClass } from '@stamhoofd/email';
|
|
11
|
+
import type { QueueHandlerOptions } from '@stamhoofd/queues';
|
|
12
|
+
import { isAbortedError, QueueHandler } from '@stamhoofd/queues';
|
|
10
13
|
import { QueryableModel, readDynamicSQLExpression, SQL, SQLAlias, SQLCalculation, SQLCount, SQLPlusSign, SQLSelectAs, SQLWhereSign } from '@stamhoofd/sql';
|
|
11
14
|
import { canSendFromEmail, fillRecipientReplacements, getEmailBuilder, mergeReplacementsIfEqual, removeUnusedReplacements, stripRecipientReplacementsForWebDisplay, stripSensitiveRecipientReplacements } from '../helpers/EmailBuilder.js';
|
|
12
15
|
import { EmailRecipient } from './EmailRecipient.js';
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { column } from '@simonbackx/simple-database';
|
|
2
2
|
import { AnyDecoder } from '@simonbackx/simple-encoding';
|
|
3
3
|
import { QueryableModel } from '@stamhoofd/sql';
|
|
4
|
-
import {
|
|
4
|
+
import type { EmailTemplateType } from '@stamhoofd/structures';
|
|
5
|
+
import { EmailTemplate as EmailTemplateStruct } from '@stamhoofd/structures';
|
|
5
6
|
import { v4 as uuidv4 } from 'uuid';
|
|
6
7
|
|
|
7
8
|
/**
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { column } from '@simonbackx/simple-database';
|
|
2
2
|
import { SimpleError } from '@simonbackx/simple-errors';
|
|
3
|
-
import {
|
|
3
|
+
import type {I18n} from '@stamhoofd/backend-i18n';
|
|
4
4
|
import { QueryableModel } from '@stamhoofd/sql';
|
|
5
5
|
import { EmailTemplateType, Recipient, Replacement } from '@stamhoofd/structures';
|
|
6
6
|
import basex from 'base-x';
|
|
@@ -8,6 +8,8 @@ import crypto from 'crypto';
|
|
|
8
8
|
import { v4 as uuidv4 } from 'uuid';
|
|
9
9
|
import { sendEmailTemplate } from '../helpers/EmailBuilder.js';
|
|
10
10
|
import { Platform } from './Platform.js';
|
|
11
|
+
import type {User} from './User.js';
|
|
12
|
+
import type {Organization} from './Organization.js';
|
|
11
13
|
|
|
12
14
|
const ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';
|
|
13
15
|
const bs58 = basex(ALPHABET);
|
|
@@ -118,7 +120,7 @@ export class EmailVerificationCode extends QueryableModel {
|
|
|
118
120
|
this.expiresAt = new Date(new Date().getTime() + 1000 * 60 * 60 * 12);
|
|
119
121
|
}
|
|
120
122
|
|
|
121
|
-
getEmailVerificationUrl(user:
|
|
123
|
+
getEmailVerificationUrl(user: User, organization: Organization | null, i18n: I18n) {
|
|
122
124
|
let host: string;
|
|
123
125
|
if (user.permissions || !organization || STAMHOOFD.userMode === 'platform') {
|
|
124
126
|
host = 'https://' + (STAMHOOFD.domains.dashboard ?? 'stamhoofd.app') + '/' + i18n.locale;
|
|
@@ -244,7 +246,7 @@ export class EmailVerificationCode extends QueryableModel {
|
|
|
244
246
|
}
|
|
245
247
|
}
|
|
246
248
|
|
|
247
|
-
async send(user:
|
|
249
|
+
async send(user: User, organization: Organization | null, i18n: I18n, withCode = true) {
|
|
248
250
|
const url = this.getEmailVerificationUrl(user, organization, i18n);
|
|
249
251
|
|
|
250
252
|
const name = organization?.name ?? (await Platform.getSharedPrivateStruct()).config.name;
|
|
@@ -298,7 +300,7 @@ export class EmailVerificationCode extends QueryableModel {
|
|
|
298
300
|
}
|
|
299
301
|
}
|
|
300
302
|
|
|
301
|
-
static async resend(organization:
|
|
303
|
+
static async resend(organization: Organization | null, token: string, i18n: I18n) {
|
|
302
304
|
const verificationCodes = await this.where({
|
|
303
305
|
token,
|
|
304
306
|
organizationId: organization
|
|
@@ -336,7 +338,7 @@ export class EmailVerificationCode extends QueryableModel {
|
|
|
336
338
|
* If needed, it will update the code.
|
|
337
339
|
* Use this method for sending only, not for verification!
|
|
338
340
|
*/
|
|
339
|
-
static async createFor(user:
|
|
341
|
+
static async createFor(user: User, email: string): Promise<EmailVerificationCode> {
|
|
340
342
|
// TODO: make this constant time to avoid complex timing attacks (especially when under load)
|
|
341
343
|
// Do we already have a verificationCode for this email?
|
|
342
344
|
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { column, ManyToManyRelation } from '@simonbackx/simple-database';
|
|
2
2
|
import { MapDecoder, StringDecoder } from '@simonbackx/simple-encoding';
|
|
3
3
|
import { QueryableModel } from '@stamhoofd/sql';
|
|
4
|
-
import {
|
|
4
|
+
import type { RecordAnswer} from '@stamhoofd/structures';
|
|
5
|
+
import { EventNotificationStatus, RecordAnswerDecoder } from '@stamhoofd/structures';
|
|
5
6
|
import { v4 as uuidv4 } from 'uuid';
|
|
6
7
|
import { Event } from './Event.js';
|
|
7
8
|
|
|
@@ -79,5 +80,5 @@ export class EventNotification extends QueryableModel {
|
|
|
79
80
|
updatedAt: Date;
|
|
80
81
|
|
|
81
82
|
// Note: all relations should point to their parents, not the other way around to avoid reference cycles
|
|
82
|
-
static events = new ManyToManyRelation(EventNotification, Event, 'events');
|
|
83
|
+
static events = new ManyToManyRelation<'events', EventNotification, Event>(EventNotification, Event, 'events');
|
|
83
84
|
}
|