@stamhoofd/models 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/assets/Metropolis-Black.woff2 +0 -0
- package/dist/src/assets/Metropolis-BlackItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-Bold.woff2 +0 -0
- package/dist/src/assets/Metropolis-BoldItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-ExtraBold.woff2 +0 -0
- package/dist/src/assets/Metropolis-ExtraBoldItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-ExtraLight.woff2 +0 -0
- package/dist/src/assets/Metropolis-ExtraLightItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-Light.woff2 +0 -0
- package/dist/src/assets/Metropolis-LightItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-Medium.woff2 +0 -0
- package/dist/src/assets/Metropolis-MediumItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-Regular.woff2 +0 -0
- package/dist/src/assets/Metropolis-RegularItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-SemiBold.woff2 +0 -0
- package/dist/src/assets/Metropolis-SemiBoldItalic.woff2 +0 -0
- package/dist/src/assets/Metropolis-Thin.woff2 +0 -0
- package/dist/src/assets/Metropolis-ThinItalic.woff2 +0 -0
- 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/assets/logo.png +0 -0
- package/dist/src/factories/AddressFactory.d.ts +10 -0
- package/dist/src/factories/AddressFactory.d.ts.map +1 -0
- package/dist/src/factories/AddressFactory.js +42 -0
- package/dist/src/factories/AddressFactory.js.map +1 -0
- package/dist/src/factories/EmergencyContactFactory.d.ts +9 -0
- package/dist/src/factories/EmergencyContactFactory.d.ts.map +1 -0
- package/dist/src/factories/EmergencyContactFactory.js +42 -0
- package/dist/src/factories/EmergencyContactFactory.js.map +1 -0
- package/dist/src/factories/GroupFactory.d.ts +19 -0
- package/dist/src/factories/GroupFactory.d.ts.map +1 -0
- package/dist/src/factories/GroupFactory.js +52 -0
- package/dist/src/factories/GroupFactory.js.map +1 -0
- package/dist/src/factories/MemberFactory.d.ts +16 -0
- package/dist/src/factories/MemberFactory.d.ts.map +1 -0
- package/dist/src/factories/MemberFactory.js +98 -0
- package/dist/src/factories/MemberFactory.js.map +1 -0
- package/dist/src/factories/OrganizationFactory.d.ts +16 -0
- package/dist/src/factories/OrganizationFactory.d.ts.map +1 -0
- package/dist/src/factories/OrganizationFactory.js +40 -0
- package/dist/src/factories/OrganizationFactory.js.map +1 -0
- package/dist/src/factories/ParentFactory.d.ts +10 -0
- package/dist/src/factories/ParentFactory.d.ts.map +1 -0
- package/dist/src/factories/ParentFactory.js +44 -0
- package/dist/src/factories/ParentFactory.js.map +1 -0
- package/dist/src/factories/RecordFactory.d.ts +10 -0
- package/dist/src/factories/RecordFactory.d.ts.map +1 -0
- package/dist/src/factories/RecordFactory.js +14 -0
- package/dist/src/factories/RecordFactory.js.map +1 -0
- package/dist/src/factories/RegisterCodeFactory.d.ts +18 -0
- package/dist/src/factories/RegisterCodeFactory.d.ts.map +1 -0
- package/dist/src/factories/RegisterCodeFactory.js +19 -0
- package/dist/src/factories/RegisterCodeFactory.js.map +1 -0
- package/dist/src/factories/RegistrationFactory.d.ts +14 -0
- package/dist/src/factories/RegistrationFactory.d.ts.map +1 -0
- package/dist/src/factories/RegistrationFactory.js +26 -0
- package/dist/src/factories/RegistrationFactory.js.map +1 -0
- package/dist/src/factories/UserFactory.d.ts +21 -0
- package/dist/src/factories/UserFactory.d.ts.map +1 -0
- package/dist/src/factories/UserFactory.js +41 -0
- package/dist/src/factories/UserFactory.js.map +1 -0
- package/dist/src/factories/WebshopFactory.d.ts +16 -0
- package/dist/src/factories/WebshopFactory.d.ts.map +1 -0
- package/dist/src/factories/WebshopFactory.js +35 -0
- package/dist/src/factories/WebshopFactory.js.map +1 -0
- package/dist/src/helpers/DNSValidator.d.ts +6 -0
- package/dist/src/helpers/DNSValidator.d.ts.map +1 -0
- package/dist/src/helpers/DNSValidator.js +144 -0
- package/dist/src/helpers/DNSValidator.js.map +1 -0
- package/dist/src/helpers/EmailBuilder.d.ts +22 -0
- package/dist/src/helpers/EmailBuilder.d.ts.map +1 -0
- package/dist/src/helpers/EmailBuilder.js +100 -0
- package/dist/src/helpers/EmailBuilder.js.map +1 -0
- package/dist/src/helpers/GroupBuilder.d.ts +9 -0
- package/dist/src/helpers/GroupBuilder.d.ts.map +1 -0
- package/dist/src/helpers/GroupBuilder.js +382 -0
- package/dist/src/helpers/GroupBuilder.js.map +1 -0
- package/dist/src/helpers/Handlebars.d.ts +2 -0
- package/dist/src/helpers/Handlebars.d.ts.map +1 -0
- package/dist/src/helpers/Handlebars.js +192 -0
- package/dist/src/helpers/Handlebars.js.map +1 -0
- package/dist/src/helpers/InvoiceBuilder.d.ts +29 -0
- package/dist/src/helpers/InvoiceBuilder.d.ts.map +1 -0
- package/dist/src/helpers/InvoiceBuilder.js +406 -0
- package/dist/src/helpers/InvoiceBuilder.js.map +1 -0
- package/dist/src/helpers/InvoiceBuilder.test.d.ts +2 -0
- package/dist/src/helpers/InvoiceBuilder.test.d.ts.map +1 -0
- package/dist/src/helpers/InvoiceBuilder.test.js +52 -0
- package/dist/src/helpers/InvoiceBuilder.test.js.map +1 -0
- package/dist/src/helpers/RateLimiter.d.ts +27 -0
- package/dist/src/helpers/RateLimiter.d.ts.map +1 -0
- package/dist/src/helpers/RateLimiter.js +57 -0
- package/dist/src/helpers/RateLimiter.js.map +1 -0
- package/dist/src/helpers/WebshopCounter.d.ts +6 -0
- package/dist/src/helpers/WebshopCounter.d.ts.map +1 -0
- package/dist/src/helpers/WebshopCounter.js +36 -0
- package/dist/src/helpers/WebshopCounter.js.map +1 -0
- package/dist/src/helpers/WebshopCounter.test.d.ts +2 -0
- package/dist/src/helpers/WebshopCounter.test.d.ts.map +1 -0
- package/dist/src/helpers/WebshopCounter.test.js +17 -0
- package/dist/src/helpers/WebshopCounter.test.js.map +1 -0
- package/dist/src/index.d.ts +18 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +23 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/migrations/1593773929-create-initial-tables.sql +634 -0
- package/dist/src/migrations/1605261999-gemeenten-tmp.sql +2820 -0
- package/dist/src/migrations/1605262045-import-postcodes.d.ts +16 -0
- package/dist/src/migrations/1605262045-import-postcodes.d.ts.map +1 -0
- package/dist/src/migrations/1605262045-import-postcodes.js +116 -0
- package/dist/src/migrations/1605262045-import-postcodes.js.map +1 -0
- package/dist/src/migrations/1605262046-import-postcodes-nl.d.ts +4 -0
- package/dist/src/migrations/1605262046-import-postcodes-nl.d.ts.map +1 -0
- package/dist/src/migrations/1605262046-import-postcodes-nl.js +83 -0
- package/dist/src/migrations/1605262046-import-postcodes-nl.js.map +1 -0
- package/dist/src/migrations/1605279038-drop-gemeenten-tmp.sql +1 -0
- package/dist/src/migrations/1648392491-default-templates.sql +9 -0
- package/dist/src/migrations/1651245707-default-templates-reminders.sql +6 -0
- package/dist/src/migrations/1708607340-tickets-deleted-at.sql +1 -0
- package/dist/src/migrations/1710459176-register-code-invoices.sql +3 -0
- package/dist/src/migrations/1712158247-discount-codes.sql +17 -0
- package/dist/src/migrations/1713178665-drop-invites.sql +1 -0
- package/dist/src/migrations/1713178666-drop-keychain.sql +1 -0
- package/dist/src/migrations/1713178667-drop-challenges.sql +1 -0
- package/dist/src/migrations/1713178668-drop-user-keys.sql +7 -0
- package/dist/src/migrations/1713178669-drop-organization-key.sql +2 -0
- package/dist/src/migrations/data/postcodes/nl/Drenthe +291 -0
- package/dist/src/migrations/data/postcodes/nl/Flevoland +107 -0
- package/dist/src/migrations/data/postcodes/nl/Friesland +518 -0
- package/dist/src/migrations/data/postcodes/nl/Gelderland +601 -0
- package/dist/src/migrations/data/postcodes/nl/Groningen +279 -0
- package/dist/src/migrations/data/postcodes/nl/Limburg +324 -0
- package/dist/src/migrations/data/postcodes/nl/Noord-Brabant +620 -0
- package/dist/src/migrations/data/postcodes/nl/Noord-Holland +566 -0
- package/dist/src/migrations/data/postcodes/nl/Overrijsel +344 -0
- package/dist/src/migrations/data/postcodes/nl/Utrecht +278 -0
- package/dist/src/migrations/data/postcodes/nl/Zeeland +179 -0
- package/dist/src/migrations/data/postcodes/nl/Zuid-Holland +662 -0
- package/dist/src/models/BalanceItem.d.ts +57 -0
- package/dist/src/models/BalanceItem.d.ts.map +1 -0
- package/dist/src/models/BalanceItem.js +346 -0
- package/dist/src/models/BalanceItem.js.map +1 -0
- package/dist/src/models/BalanceItemPayment.d.ts +31 -0
- package/dist/src/models/BalanceItemPayment.d.ts.map +1 -0
- package/dist/src/models/BalanceItemPayment.js +101 -0
- package/dist/src/models/BalanceItemPayment.js.map +1 -0
- package/dist/src/models/BuckarooPayment.d.ts +8 -0
- package/dist/src/models/BuckarooPayment.d.ts.map +1 -0
- package/dist/src/models/BuckarooPayment.js +24 -0
- package/dist/src/models/BuckarooPayment.js.map +1 -0
- package/dist/src/models/Document.d.ts +44 -0
- package/dist/src/models/Document.d.ts.map +1 -0
- package/dist/src/models/Document.js +194 -0
- package/dist/src/models/Document.js.map +1 -0
- package/dist/src/models/DocumentTemplate.d.ts +45 -0
- package/dist/src/models/DocumentTemplate.d.ts.map +1 -0
- package/dist/src/models/DocumentTemplate.js +533 -0
- package/dist/src/models/DocumentTemplate.js.map +1 -0
- package/dist/src/models/EmailTemplate.d.ts +22 -0
- package/dist/src/models/EmailTemplate.d.ts.map +1 -0
- package/dist/src/models/EmailTemplate.js +70 -0
- package/dist/src/models/EmailTemplate.js.map +1 -0
- package/dist/src/models/EmailVerificationCode.d.ts +60 -0
- package/dist/src/models/EmailVerificationCode.d.ts.map +1 -0
- package/dist/src/models/EmailVerificationCode.js +307 -0
- package/dist/src/models/EmailVerificationCode.js.map +1 -0
- package/dist/src/models/Group.d.ts +36 -0
- package/dist/src/models/Group.d.ts.map +1 -0
- package/dist/src/models/Group.js +231 -0
- package/dist/src/models/Group.js.map +1 -0
- package/dist/src/models/Image.d.ts +12 -0
- package/dist/src/models/Image.d.ts.map +1 -0
- package/dist/src/models/Image.js +137 -0
- package/dist/src/models/Image.js.map +1 -0
- package/dist/src/models/Member.d.ts +66 -0
- package/dist/src/models/Member.d.ts.map +1 -0
- package/dist/src/models/Member.js +309 -0
- package/dist/src/models/Member.js.map +1 -0
- package/dist/src/models/MemberResponsibilityRecord.d.ts +11 -0
- package/dist/src/models/MemberResponsibilityRecord.d.ts.map +1 -0
- package/dist/src/models/MemberResponsibilityRecord.js +47 -0
- package/dist/src/models/MemberResponsibilityRecord.js.map +1 -0
- package/dist/src/models/MolliePayment.d.ts +8 -0
- package/dist/src/models/MolliePayment.d.ts.map +1 -0
- package/dist/src/models/MolliePayment.js +24 -0
- package/dist/src/models/MolliePayment.js.map +1 -0
- package/dist/src/models/MollieToken.d.ts +45 -0
- package/dist/src/models/MollieToken.d.ts.map +1 -0
- package/dist/src/models/MollieToken.js +333 -0
- package/dist/src/models/MollieToken.js.map +1 -0
- package/dist/src/models/OneTimeToken.d.ts +38 -0
- package/dist/src/models/OneTimeToken.d.ts.map +1 -0
- package/dist/src/models/OneTimeToken.js +126 -0
- package/dist/src/models/OneTimeToken.js.map +1 -0
- package/dist/src/models/Order.d.ts +99 -0
- package/dist/src/models/Order.d.ts.map +1 -0
- package/dist/src/models/Order.js +912 -0
- package/dist/src/models/Order.js.map +1 -0
- package/dist/src/models/Organization.d.ts +119 -0
- package/dist/src/models/Organization.d.ts.map +1 -0
- package/dist/src/models/Organization.js +900 -0
- package/dist/src/models/Organization.js.map +1 -0
- package/dist/src/models/OrganizationRegistrationPeriod.d.ts +14 -0
- package/dist/src/models/OrganizationRegistrationPeriod.d.ts.map +1 -0
- package/dist/src/models/OrganizationRegistrationPeriod.js +62 -0
- package/dist/src/models/OrganizationRegistrationPeriod.js.map +1 -0
- package/dist/src/models/PasswordToken.d.ts +29 -0
- package/dist/src/models/PasswordToken.d.ts.map +1 -0
- package/dist/src/models/PasswordToken.js +118 -0
- package/dist/src/models/PasswordToken.js.map +1 -0
- package/dist/src/models/PayconiqPayment.d.ts +18 -0
- package/dist/src/models/PayconiqPayment.d.ts.map +1 -0
- package/dist/src/models/PayconiqPayment.js +216 -0
- package/dist/src/models/PayconiqPayment.js.map +1 -0
- package/dist/src/models/Payment.d.ts +62 -0
- package/dist/src/models/Payment.d.ts.map +1 -0
- package/dist/src/models/Payment.js +199 -0
- package/dist/src/models/Payment.js.map +1 -0
- package/dist/src/models/Platform.d.ts +15 -0
- package/dist/src/models/Platform.d.ts.map +1 -0
- package/dist/src/models/Platform.js +77 -0
- package/dist/src/models/Platform.js.map +1 -0
- package/dist/src/models/RegisterCode.d.ts +27 -0
- package/dist/src/models/RegisterCode.d.ts.map +1 -0
- package/dist/src/models/RegisterCode.js +162 -0
- package/dist/src/models/RegisterCode.js.map +1 -0
- package/dist/src/models/Registration.d.ts +47 -0
- package/dist/src/models/Registration.d.ts.map +1 -0
- package/dist/src/models/Registration.js +369 -0
- package/dist/src/models/Registration.js.map +1 -0
- package/dist/src/models/RegistrationPeriod.d.ts +15 -0
- package/dist/src/models/RegistrationPeriod.d.ts.map +1 -0
- package/dist/src/models/RegistrationPeriod.js +64 -0
- package/dist/src/models/RegistrationPeriod.js.map +1 -0
- package/dist/src/models/STCredit.d.ts +20 -0
- package/dist/src/models/STCredit.d.ts.map +1 -0
- package/dist/src/models/STCredit.js +129 -0
- package/dist/src/models/STCredit.js.map +1 -0
- package/dist/src/models/STInvoice.d.ts +51 -0
- package/dist/src/models/STInvoice.d.ts.map +1 -0
- package/dist/src/models/STInvoice.js +453 -0
- package/dist/src/models/STInvoice.js.map +1 -0
- package/dist/src/models/STPackage.d.ts +36 -0
- package/dist/src/models/STPackage.d.ts.map +1 -0
- package/dist/src/models/STPackage.js +300 -0
- package/dist/src/models/STPackage.js.map +1 -0
- package/dist/src/models/STPendingInvoice.d.ts +45 -0
- package/dist/src/models/STPendingInvoice.d.ts.map +1 -0
- package/dist/src/models/STPendingInvoice.js +284 -0
- package/dist/src/models/STPendingInvoice.js.map +1 -0
- package/dist/src/models/StripeAccount.d.ts +17 -0
- package/dist/src/models/StripeAccount.d.ts.map +1 -0
- package/dist/src/models/StripeAccount.js +81 -0
- package/dist/src/models/StripeAccount.js.map +1 -0
- package/dist/src/models/StripeCheckoutSession.d.ts +9 -0
- package/dist/src/models/StripeCheckoutSession.d.ts.map +1 -0
- package/dist/src/models/StripeCheckoutSession.js +31 -0
- package/dist/src/models/StripeCheckoutSession.js.map +1 -0
- package/dist/src/models/StripePaymentIntent.d.ts +9 -0
- package/dist/src/models/StripePaymentIntent.d.ts.map +1 -0
- package/dist/src/models/StripePaymentIntent.js +31 -0
- package/dist/src/models/StripePaymentIntent.js.map +1 -0
- package/dist/src/models/Ticket.d.ts +61 -0
- package/dist/src/models/Ticket.d.ts.map +1 -0
- package/dist/src/models/Ticket.js +143 -0
- package/dist/src/models/Ticket.js.map +1 -0
- package/dist/src/models/Token.d.ts +49 -0
- package/dist/src/models/Token.d.ts.map +1 -0
- package/dist/src/models/Token.js +218 -0
- package/dist/src/models/Token.js.map +1 -0
- package/dist/src/models/Token.test.d.ts +2 -0
- package/dist/src/models/Token.test.d.ts.map +1 -0
- package/dist/src/models/Token.test.js +60 -0
- package/dist/src/models/Token.test.js.map +1 -0
- package/dist/src/models/UsedRegisterCode.d.ts +22 -0
- package/dist/src/models/UsedRegisterCode.d.ts.map +1 -0
- package/dist/src/models/UsedRegisterCode.js +158 -0
- package/dist/src/models/UsedRegisterCode.js.map +1 -0
- package/dist/src/models/User.d.ts +55 -0
- package/dist/src/models/User.d.ts.map +1 -0
- package/dist/src/models/User.js +314 -0
- package/dist/src/models/User.js.map +1 -0
- package/dist/src/models/UserPermissions.d.ts +15 -0
- package/dist/src/models/UserPermissions.d.ts.map +1 -0
- package/dist/src/models/UserPermissions.js +57 -0
- package/dist/src/models/UserPermissions.js.map +1 -0
- package/dist/src/models/Webshop.d.ts +44 -0
- package/dist/src/models/Webshop.d.ts.map +1 -0
- package/dist/src/models/Webshop.js +184 -0
- package/dist/src/models/Webshop.js.map +1 -0
- package/dist/src/models/WebshopDiscountCode.d.ts +18 -0
- package/dist/src/models/WebshopDiscountCode.d.ts.map +1 -0
- package/dist/src/models/WebshopDiscountCode.js +88 -0
- package/dist/src/models/WebshopDiscountCode.js.map +1 -0
- package/dist/src/models/addresses/City.d.ts +14 -0
- package/dist/src/models/addresses/City.d.ts.map +1 -0
- package/dist/src/models/addresses/City.js +37 -0
- package/dist/src/models/addresses/City.js.map +1 -0
- package/dist/src/models/addresses/PostalCode.d.ts +20 -0
- package/dist/src/models/addresses/PostalCode.d.ts.map +1 -0
- package/dist/src/models/addresses/PostalCode.js +138 -0
- package/dist/src/models/addresses/PostalCode.js.map +1 -0
- package/dist/src/models/addresses/PostalCode.test.d.ts +2 -0
- package/dist/src/models/addresses/PostalCode.test.d.ts.map +1 -0
- package/dist/src/models/addresses/PostalCode.test.js +98 -0
- package/dist/src/models/addresses/PostalCode.test.js.map +1 -0
- package/dist/src/models/addresses/Province.d.ts +9 -0
- package/dist/src/models/addresses/Province.d.ts.map +1 -0
- package/dist/src/models/addresses/Province.js +24 -0
- package/dist/src/models/addresses/Province.js.map +1 -0
- package/dist/src/models/addresses/Street.d.ts +10 -0
- package/dist/src/models/addresses/Street.d.ts.map +1 -0
- package/dist/src/models/addresses/Street.js +26 -0
- package/dist/src/models/addresses/Street.js.map +1 -0
- package/dist/src/models/index.d.ts +37 -0
- package/dist/src/models/index.d.ts.map +1 -0
- package/dist/src/models/index.js +53 -0
- package/dist/src/models/index.js.map +1 -0
- package/dist/src/structures/OrganizationServerMetaData.d.ts +43 -0
- package/dist/src/structures/OrganizationServerMetaData.d.ts.map +1 -0
- package/dist/src/structures/OrganizationServerMetaData.js +128 -0
- package/dist/src/structures/OrganizationServerMetaData.js.map +1 -0
- package/dist/tests/jest.global.setup.d.ts +3 -0
- package/dist/tests/jest.global.setup.d.ts.map +1 -0
- package/dist/tests/jest.global.setup.js +20 -0
- package/dist/tests/jest.global.setup.js.map +1 -0
- package/dist/tests/jest.setup.d.ts +2 -0
- package/dist/tests/jest.setup.d.ts.map +1 -0
- package/dist/tests/jest.setup.js +15 -0
- package/dist/tests/jest.setup.js.map +1 -0
- package/package.json +30 -0
- package/src/assets/Metropolis-Black.woff2 +0 -0
- package/src/assets/Metropolis-BlackItalic.woff2 +0 -0
- package/src/assets/Metropolis-Bold.woff2 +0 -0
- package/src/assets/Metropolis-BoldItalic.woff2 +0 -0
- package/src/assets/Metropolis-ExtraBold.woff2 +0 -0
- package/src/assets/Metropolis-ExtraBoldItalic.woff2 +0 -0
- package/src/assets/Metropolis-ExtraLight.woff2 +0 -0
- package/src/assets/Metropolis-ExtraLightItalic.woff2 +0 -0
- package/src/assets/Metropolis-Light.woff2 +0 -0
- package/src/assets/Metropolis-LightItalic.woff2 +0 -0
- package/src/assets/Metropolis-Medium.woff2 +0 -0
- package/src/assets/Metropolis-MediumItalic.woff2 +0 -0
- package/src/assets/Metropolis-Regular.woff2 +0 -0
- package/src/assets/Metropolis-RegularItalic.woff2 +0 -0
- package/src/assets/Metropolis-SemiBold.woff2 +0 -0
- package/src/assets/Metropolis-SemiBoldItalic.woff2 +0 -0
- package/src/assets/Metropolis-Thin.woff2 +0 -0
- package/src/assets/Metropolis-ThinItalic.woff2 +0 -0
- package/src/assets/logo.png +0 -0
- package/src/factories/AddressFactory.ts +42 -0
- package/src/factories/EmergencyContactFactory.ts +43 -0
- package/src/factories/GroupFactory.ts +66 -0
- package/src/factories/MemberFactory.ts +122 -0
- package/src/factories/OrganizationFactory.ts +45 -0
- package/src/factories/ParentFactory.ts +49 -0
- package/src/factories/RecordFactory.ts +12 -0
- package/src/factories/RegisterCodeFactory.ts +25 -0
- package/src/factories/RegistrationFactory.ts +32 -0
- package/src/factories/UserFactory.ts +66 -0
- package/src/factories/WebshopFactory.ts +43 -0
- package/src/helpers/DNSValidator.ts +153 -0
- package/src/helpers/EmailBuilder.ts +127 -0
- package/src/helpers/GroupBuilder.ts +438 -0
- package/src/helpers/Handlebars.ts +203 -0
- package/src/helpers/InvoiceBuilder.test.ts +57 -0
- package/src/helpers/InvoiceBuilder.ts +501 -0
- package/src/helpers/RateLimiter.ts +75 -0
- package/src/helpers/WebshopCounter.test.ts +16 -0
- package/src/helpers/WebshopCounter.ts +36 -0
- package/src/index.ts +21 -0
- package/src/migrations/1593773929-create-initial-tables.sql +634 -0
- package/src/migrations/1605261999-gemeenten-tmp.sql +2820 -0
- package/src/migrations/1605262045-import-postcodes.ts +132 -0
- package/src/migrations/1605262046-import-postcodes-nl.ts +97 -0
- package/src/migrations/1605279038-drop-gemeenten-tmp.sql +1 -0
- package/src/migrations/1648392491-default-templates.sql +9 -0
- package/src/migrations/1651245707-default-templates-reminders.sql +6 -0
- package/src/migrations/1708607340-tickets-deleted-at.sql +1 -0
- package/src/migrations/1710459176-register-code-invoices.sql +3 -0
- package/src/migrations/1712158247-discount-codes.sql +17 -0
- package/src/migrations/1713178665-drop-invites.sql +1 -0
- package/src/migrations/1713178666-drop-keychain.sql +1 -0
- package/src/migrations/1713178667-drop-challenges.sql +1 -0
- package/src/migrations/1713178668-drop-user-keys.sql +7 -0
- package/src/migrations/1713178669-drop-organization-key.sql +2 -0
- package/src/migrations/1714985451-user-nullable-organization-id.sql +2 -0
- package/src/migrations/1714985452-email-verification-code-nullable-organization-id.sql +2 -0
- package/src/migrations/1714985453-user-organization-permissions.sql +2 -0
- package/src/migrations/1714985454-user-organization-permissions.sql +2 -0
- package/src/migrations/1715079362-platform.sql +6 -0
- package/src/migrations/1715181649-registrations-organization-id.sql +2 -0
- package/src/migrations/1715181650-registrations-organization-id-fill.sql +1 -0
- package/src/migrations/1715181651-registrations-organization-id-drop-null.sql +2 -0
- package/src/migrations/1716117067-members-nullable-organization-id.sql +2 -0
- package/src/migrations/1719567581-registration-periods.sql +13 -0
- package/src/migrations/1719567582-organization-registration-periods.sql +13 -0
- package/src/migrations/1719567881-organization-periodId.sql +2 -0
- package/src/migrations/1719567882-groups-periodId.sql +2 -0
- package/src/migrations/1719567883-platform-periodId.sql +2 -0
- package/src/migrations/1719568079-default-period.sql +2 -0
- package/src/migrations/1719568080-set-default-period-platform.sql +1 -0
- package/src/migrations/1719568081-set-default-period-organizations.sql +1 -0
- package/src/migrations/1719568082-set-default-period-groups.sql +1 -0
- package/src/migrations/1719580828-registrations-periodId.sql +2 -0
- package/src/migrations/1719580829-set-default-period-registrations.sql +1 -0
- package/src/migrations/data/postcodes/nl/Drenthe +291 -0
- package/src/migrations/data/postcodes/nl/Flevoland +107 -0
- package/src/migrations/data/postcodes/nl/Friesland +518 -0
- package/src/migrations/data/postcodes/nl/Gelderland +601 -0
- package/src/migrations/data/postcodes/nl/Groningen +279 -0
- package/src/migrations/data/postcodes/nl/Limburg +324 -0
- package/src/migrations/data/postcodes/nl/Noord-Brabant +620 -0
- package/src/migrations/data/postcodes/nl/Noord-Holland +566 -0
- package/src/migrations/data/postcodes/nl/Overrijsel +344 -0
- package/src/migrations/data/postcodes/nl/Utrecht +278 -0
- package/src/migrations/data/postcodes/nl/Zeeland +179 -0
- package/src/migrations/data/postcodes/nl/Zuid-Holland +662 -0
- package/src/models/BalanceItem.ts +392 -0
- package/src/models/BalanceItemPayment.ts +106 -0
- package/src/models/BuckarooPayment.ts +19 -0
- package/src/models/Document.ts +203 -0
- package/src/models/DocumentTemplate.ts +583 -0
- package/src/models/EmailTemplate.ts +64 -0
- package/src/models/EmailVerificationCode.ts +352 -0
- package/src/models/Group.ts +293 -0
- package/src/models/Image.ts +147 -0
- package/src/models/Member.ts +386 -0
- package/src/models/MemberResponsibilityRecord.ts +39 -0
- package/src/models/MolliePayment.ts +19 -0
- package/src/models/MollieToken.ts +369 -0
- package/src/models/OneTimeToken.ts +131 -0
- package/src/models/Order.ts +1030 -0
- package/src/models/Organization.ts +1085 -0
- package/src/models/OrganizationRegistrationPeriod.ts +54 -0
- package/src/models/PasswordToken.ts +139 -0
- package/src/models/PayconiqPayment.ts +241 -0
- package/src/models/Payment.ts +216 -0
- package/src/models/Platform.ts +76 -0
- package/src/models/RegisterCode.ts +164 -0
- package/src/models/Registration.ts +405 -0
- package/src/models/RegistrationPeriod.ts +55 -0
- package/src/models/STCredit.ts +134 -0
- package/src/models/STInvoice.ts +507 -0
- package/src/models/STPackage.ts +324 -0
- package/src/models/STPendingInvoice.ts +308 -0
- package/src/models/StripeAccount.ts +71 -0
- package/src/models/StripeCheckoutSession.ts +22 -0
- package/src/models/StripePaymentIntent.ts +22 -0
- package/src/models/Ticket.ts +145 -0
- package/src/models/Token.test.ts +69 -0
- package/src/models/Token.ts +269 -0
- package/src/models/UsedRegisterCode.ts +166 -0
- package/src/models/User.ts +445 -0
- package/src/models/UserPermissions.ts +54 -0
- package/src/models/Webshop.ts +206 -0
- package/src/models/WebshopDiscountCode.ts +81 -0
- package/src/models/addresses/City.ts +31 -0
- package/src/models/addresses/PostalCode.test.ts +117 -0
- package/src/models/addresses/PostalCode.ts +164 -0
- package/src/models/addresses/Province.ts +20 -0
- package/src/models/addresses/Street.ts +25 -0
- package/src/models/index.ts +49 -0
- package/src/structures/OrganizationServerMetaData.ts +117 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { Gender, MemberDetails, ParentType } from '@stamhoofd/structures';
|
|
3
|
+
import { Formatter } from "@stamhoofd/utility";
|
|
4
|
+
|
|
5
|
+
import { Member, MemberWithRegistrations } from "../models/Member";
|
|
6
|
+
import { Organization } from "../models/Organization";
|
|
7
|
+
import { User } from "../models/User";
|
|
8
|
+
import { EmergencyContactFactory } from './EmergencyContactFactory';
|
|
9
|
+
import { OrganizationFactory } from './OrganizationFactory';
|
|
10
|
+
import { ParentFactory } from './ParentFactory';
|
|
11
|
+
|
|
12
|
+
class Options {
|
|
13
|
+
organization?: Organization;
|
|
14
|
+
user?: User;
|
|
15
|
+
|
|
16
|
+
/// In order to add something to the keychain, we need the private key of the user (since everything needs to be signed)
|
|
17
|
+
userPrivateKey?: string;
|
|
18
|
+
|
|
19
|
+
minAge?: number
|
|
20
|
+
maxAge?: number
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export class MemberFactory extends Factory<Options, MemberWithRegistrations> {
|
|
24
|
+
async create(): Promise<MemberWithRegistrations> {
|
|
25
|
+
const organization = this.options.organization
|
|
26
|
+
?? await new OrganizationFactory({}).create()
|
|
27
|
+
|
|
28
|
+
const memberDetails = new MemberDetails()
|
|
29
|
+
const minAge = (this.options.minAge ?? 6)
|
|
30
|
+
const maxAge = this.options.maxAge ?? 18
|
|
31
|
+
|
|
32
|
+
memberDetails.gender = Math.random() >= 0.05 ? (Math.random() >= 0.5 ? Gender.Male : Gender.Female) : Gender.Other;
|
|
33
|
+
memberDetails.firstName = this.randomFirstName(memberDetails.gender);
|
|
34
|
+
memberDetails.birthDay = new Date(
|
|
35
|
+
new Date().getFullYear() -
|
|
36
|
+
(minAge + Math.floor(Math.random() * (maxAge - minAge + 1))),
|
|
37
|
+
Math.floor(Math.random() * 12), // 11 = 12
|
|
38
|
+
Math.floor(Math.random() * 31)
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
// For now only generate -18
|
|
42
|
+
memberDetails.address = null;
|
|
43
|
+
|
|
44
|
+
if (memberDetails.age! >= 14) {
|
|
45
|
+
memberDetails.phone =
|
|
46
|
+
"+32 47" +
|
|
47
|
+
Math.floor(Math.random() * 10) +
|
|
48
|
+
" " +
|
|
49
|
+
Math.floor(Math.random() * 10) +
|
|
50
|
+
Math.floor(Math.random() * 10) +
|
|
51
|
+
" " +
|
|
52
|
+
Math.floor(Math.random() * 10) +
|
|
53
|
+
Math.floor(Math.random() * 10) +
|
|
54
|
+
" " +
|
|
55
|
+
Math.floor(Math.random() * 10) +
|
|
56
|
+
Math.floor(Math.random() * 10);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
let parentFactory = new ParentFactory({});
|
|
60
|
+
|
|
61
|
+
memberDetails.parents.push(await parentFactory.create());
|
|
62
|
+
|
|
63
|
+
// 80% chance to have 2 parents if not guardian
|
|
64
|
+
if (Math.random() >= 0.2 && memberDetails.parents[0].type != ParentType.Other) {
|
|
65
|
+
// 90% chance to have parents of different gender
|
|
66
|
+
parentFactory = new ParentFactory({
|
|
67
|
+
type:
|
|
68
|
+
Math.random() >= 0.2
|
|
69
|
+
? memberDetails.parents[0].type == ParentType.Mother
|
|
70
|
+
? ParentType.Father
|
|
71
|
+
: ParentType.Mother
|
|
72
|
+
: undefined,
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
memberDetails.parents.push(await parentFactory.create());
|
|
76
|
+
|
|
77
|
+
if (Math.random() >= 0.1) {
|
|
78
|
+
// 10% chance to have divorced parents
|
|
79
|
+
memberDetails.parents[1].address = memberDetails.parents[0].address;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Sort
|
|
84
|
+
|
|
85
|
+
if (memberDetails.parents.length == 2 && Math.random() >= 0.9) {
|
|
86
|
+
memberDetails.lastName = memberDetails.parents[0].lastName + "-" + memberDetails.parents[1].lastName;
|
|
87
|
+
} else {
|
|
88
|
+
if (memberDetails.parents[0].type == ParentType.Father) {
|
|
89
|
+
memberDetails.lastName = memberDetails.parents[0].lastName;
|
|
90
|
+
} else if (memberDetails.parents[1] && memberDetails.parents[1].type == ParentType.Father) {
|
|
91
|
+
memberDetails.lastName = memberDetails.parents[1].lastName;
|
|
92
|
+
} else {
|
|
93
|
+
memberDetails.lastName = memberDetails.parents[0].lastName;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
if (memberDetails.age! >= 16) {
|
|
98
|
+
memberDetails.email = Formatter.slugEmail(memberDetails.firstName + "-" + memberDetails.lastName) + "@geen-email.com";
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const emergencyContactFactory = new EmergencyContactFactory({});
|
|
102
|
+
memberDetails.emergencyContacts.push(await emergencyContactFactory.create());
|
|
103
|
+
if (Math.random() >= 0.9) {
|
|
104
|
+
memberDetails.emergencyContacts.push(await emergencyContactFactory.create());
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
const member = new Member()
|
|
108
|
+
.setManyRelation(Member.registrations, [])
|
|
109
|
+
.setManyRelation(Member.users, this.options.user ? [this.options.user] : [])
|
|
110
|
+
|
|
111
|
+
member.organizationId = organization.id
|
|
112
|
+
member.details = memberDetails
|
|
113
|
+
await member.save()
|
|
114
|
+
|
|
115
|
+
// Give user access to the encrypted data
|
|
116
|
+
if (this.options.user) {
|
|
117
|
+
await Member.users.link(member, [this.options.user])
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return member as any;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { Address,Country,OrganizationMetaData, OrganizationType, PermissionRoleDetailed } from "@stamhoofd/structures";
|
|
3
|
+
import { Formatter } from "@stamhoofd/utility";
|
|
4
|
+
|
|
5
|
+
import { Organization } from "../models/Organization";
|
|
6
|
+
|
|
7
|
+
class Options {
|
|
8
|
+
uri?: string;
|
|
9
|
+
domain?: string;
|
|
10
|
+
meta?: OrganizationMetaData;
|
|
11
|
+
name?: string;
|
|
12
|
+
city?: string;
|
|
13
|
+
roles?: PermissionRoleDetailed[];
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export class OrganizationFactory extends Factory<Options, Organization> {
|
|
17
|
+
async create(): Promise<Organization> {
|
|
18
|
+
const organization = new Organization();
|
|
19
|
+
organization.name = this.options.name ?? "Organization " + (new Date().getTime() + Math.floor(Math.random() * 999999));
|
|
20
|
+
organization.website = "https://domain.com";
|
|
21
|
+
organization.registerDomain = this.options.domain ?? null;
|
|
22
|
+
organization.uri = this.options.uri ?? Formatter.slug(organization.name);
|
|
23
|
+
organization.meta = this.options.meta ?? OrganizationMetaData.create({
|
|
24
|
+
type: this.randomEnum(OrganizationType),
|
|
25
|
+
umbrellaOrganization: null,
|
|
26
|
+
defaultEndDate: new Date(),
|
|
27
|
+
defaultStartDate: new Date(),
|
|
28
|
+
defaultPrices: []
|
|
29
|
+
});
|
|
30
|
+
organization.address = Address.create({
|
|
31
|
+
street: "Demostraat",
|
|
32
|
+
number: "12",
|
|
33
|
+
city: this.options.city ?? "Gent",
|
|
34
|
+
postalCode: "9000",
|
|
35
|
+
country: Country.Belgium
|
|
36
|
+
})
|
|
37
|
+
|
|
38
|
+
if (this.options.roles) {
|
|
39
|
+
organization.privateMeta.roles = this.options.roles;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
await organization.save();
|
|
43
|
+
return organization;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { Gender, Parent, ParentType } from '@stamhoofd/structures';
|
|
3
|
+
import { Formatter } from "@stamhoofd/utility";
|
|
4
|
+
|
|
5
|
+
import { AddressFactory } from "./AddressFactory";
|
|
6
|
+
|
|
7
|
+
interface Options {
|
|
8
|
+
type?: ParentType;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export class ParentFactory extends Factory<Options, Parent> {
|
|
12
|
+
async create(): Promise<Parent> {
|
|
13
|
+
const parent = new Parent();
|
|
14
|
+
parent.type = this.options.type ?? this.randomArray([ParentType.Mother, ParentType.Father, ParentType.Stepfather, ParentType.Stepmother, ParentType.Other]);
|
|
15
|
+
if (parent.type == ParentType.Other) {
|
|
16
|
+
// Second spin
|
|
17
|
+
parent.type = this.options.type ?? this.randomArray([ParentType.Mother, ParentType.Father, ParentType.Stepfather, ParentType.Stepmother, ParentType.Other]);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
parent.firstName = this.randomFirstName(parent.type == ParentType.Mother ? Gender.Female : Gender.Male);
|
|
21
|
+
parent.lastName = this.randomLastName();
|
|
22
|
+
|
|
23
|
+
parent.address = await new AddressFactory({}).create();
|
|
24
|
+
parent.phone =
|
|
25
|
+
"+32 47" +
|
|
26
|
+
Math.floor(Math.random() * 10) +
|
|
27
|
+
" " +
|
|
28
|
+
Math.floor(Math.random() * 10) +
|
|
29
|
+
Math.floor(Math.random() * 10) +
|
|
30
|
+
" " +
|
|
31
|
+
Math.floor(Math.random() * 10) +
|
|
32
|
+
Math.floor(Math.random() * 10) +
|
|
33
|
+
" " +
|
|
34
|
+
Math.floor(Math.random() * 10) +
|
|
35
|
+
Math.floor(Math.random() * 10);
|
|
36
|
+
|
|
37
|
+
parent.email =
|
|
38
|
+
Formatter.slugEmail(
|
|
39
|
+
(Math.random() >= 0.5 ? parent.firstName.toLowerCase() : parent.firstName.toLowerCase()[0]) +
|
|
40
|
+
(Math.random() >= 0.5 ? "." : Math.random() >= 0.5 ? "_" : "") +
|
|
41
|
+
parent.lastName.toLowerCase().replace(" ", "")
|
|
42
|
+
) +
|
|
43
|
+
"@" +
|
|
44
|
+
this.randomArray([
|
|
45
|
+
"geen-email.com"
|
|
46
|
+
]);
|
|
47
|
+
return parent;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { LegacyRecord, LegacyRecordType } from '@stamhoofd/structures';
|
|
3
|
+
|
|
4
|
+
interface Options {}
|
|
5
|
+
|
|
6
|
+
export class RecordFactory extends Factory<Options, LegacyRecord> {LegacyRecordLegacyRecord
|
|
7
|
+
create(): Promise<LegacyRecord> {
|
|
8
|
+
return Promise.resolve(LegacyRecord.create({
|
|
9
|
+
type: this.randomArray(Object.values(LegacyRecordType))
|
|
10
|
+
}));
|
|
11
|
+
}
|
|
12
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
|
|
3
|
+
import { RegisterCode } from "../models";
|
|
4
|
+
|
|
5
|
+
type OrganizationOptions = {
|
|
6
|
+
organizationId: string
|
|
7
|
+
} | {organization: {id: string}}
|
|
8
|
+
|
|
9
|
+
type Options = OrganizationOptions & {
|
|
10
|
+
value?: number;
|
|
11
|
+
description?: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export class RegisterCodeFactory extends Factory<Options, RegisterCode> {
|
|
15
|
+
async create(): Promise<RegisterCode> {
|
|
16
|
+
const code = new RegisterCode();
|
|
17
|
+
code.organizationId = "organizationId" in this.options ? this.options.organizationId : this.options.organization.id;
|
|
18
|
+
code.value = this.options.value ?? (25 * 100);
|
|
19
|
+
code.description = this.options.description ?? "Test code";
|
|
20
|
+
|
|
21
|
+
await code.generateCode();
|
|
22
|
+
await code.save();
|
|
23
|
+
return code;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
|
|
3
|
+
import { Group } from "../models/Group";
|
|
4
|
+
import { Member } from '../models/Member';
|
|
5
|
+
import { Registration } from '../models/Registration';
|
|
6
|
+
|
|
7
|
+
class Options {
|
|
8
|
+
member: Member;
|
|
9
|
+
group: Group;
|
|
10
|
+
waitingList?: boolean
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export class RegistrationFactory extends Factory<Options, Registration> {
|
|
14
|
+
async create(): Promise<Registration> {
|
|
15
|
+
const registration = new Registration()
|
|
16
|
+
registration.memberId = this.options.member.id
|
|
17
|
+
registration.groupId = this.options.group.id
|
|
18
|
+
registration.periodId = this.options.group.periodId
|
|
19
|
+
registration.organizationId = this.options.group.organizationId
|
|
20
|
+
registration.cycle = this.options.group.cycle
|
|
21
|
+
|
|
22
|
+
if (this.options.waitingList !== true) {
|
|
23
|
+
registration.registeredAt = new Date()
|
|
24
|
+
registration.registeredAt.setMilliseconds(0)
|
|
25
|
+
} else {
|
|
26
|
+
registration.waitingList = true
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
await registration.save()
|
|
30
|
+
return registration;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { NewUser, Permissions, UserPermissions } from '@stamhoofd/structures';
|
|
3
|
+
|
|
4
|
+
import { Organization } from "../models/Organization";
|
|
5
|
+
import { User } from "../models/User";
|
|
6
|
+
import { OrganizationFactory } from './OrganizationFactory';
|
|
7
|
+
|
|
8
|
+
class Options {
|
|
9
|
+
organization?: Organization;
|
|
10
|
+
email?: string;
|
|
11
|
+
password?: string;
|
|
12
|
+
firstName?: string;
|
|
13
|
+
lastName?: string;
|
|
14
|
+
/**
|
|
15
|
+
* Default is true
|
|
16
|
+
*/
|
|
17
|
+
verified?: boolean;
|
|
18
|
+
permissions?: Permissions | null
|
|
19
|
+
globalPermissions?: Permissions | null
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export class UserFactory extends Factory<Options, User> {
|
|
23
|
+
async create(): Promise<User> {
|
|
24
|
+
let organization: Organization
|
|
25
|
+
|
|
26
|
+
if (!this.options.organization) {
|
|
27
|
+
const organizationFactory = new OrganizationFactory({})
|
|
28
|
+
organization = await organizationFactory.create()
|
|
29
|
+
} else {
|
|
30
|
+
organization = this.options.organization
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const email = this.options.email ?? "generated-email-" + this.randomString(20) + "@domain.com";
|
|
34
|
+
const password = this.options.password ?? this.randomString(20);
|
|
35
|
+
|
|
36
|
+
const user = await User.register(organization, NewUser.create({
|
|
37
|
+
email,
|
|
38
|
+
organizationId: organization.id,
|
|
39
|
+
password
|
|
40
|
+
}));
|
|
41
|
+
if (!user) {
|
|
42
|
+
throw new Error("Unexpected failure when creating user in factory");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (this.options.permissions) {
|
|
46
|
+
user.permissions = UserPermissions.create({})
|
|
47
|
+
user.permissions.organizationPermissions.set(organization.id, this.options.permissions)
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
if (this.options.globalPermissions) {
|
|
51
|
+
if (!user.permissions) {
|
|
52
|
+
user.permissions = UserPermissions.create({})
|
|
53
|
+
}
|
|
54
|
+
user.permissions.globalPermissions = this.options.globalPermissions
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
user.firstName = this.options.firstName ?? null;
|
|
58
|
+
user.lastName = this.options.lastName ?? null;
|
|
59
|
+
|
|
60
|
+
if (this.options.verified === undefined || this.options.verified === true) {
|
|
61
|
+
user.verified = true;
|
|
62
|
+
}
|
|
63
|
+
await user.save();
|
|
64
|
+
return user;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Factory } from "@simonbackx/simple-database";
|
|
2
|
+
import { AutoEncoderPatchType } from "@simonbackx/simple-encoding";
|
|
3
|
+
import { Product, WebshopMetaData, WebshopPrivateMetaData } from "@stamhoofd/structures";
|
|
4
|
+
import { Formatter } from "@stamhoofd/utility";
|
|
5
|
+
|
|
6
|
+
import { Webshop } from "../models";
|
|
7
|
+
import { OrganizationFactory } from "./OrganizationFactory";
|
|
8
|
+
|
|
9
|
+
class Options {
|
|
10
|
+
organizationId?: string
|
|
11
|
+
name?: string
|
|
12
|
+
meta?: WebshopMetaData|AutoEncoderPatchType<WebshopMetaData>
|
|
13
|
+
privateMeta?: WebshopPrivateMetaData|AutoEncoderPatchType<WebshopPrivateMetaData>
|
|
14
|
+
products?: Product[]
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export class WebshopFactory extends Factory<Options, Webshop> {
|
|
18
|
+
async create(): Promise<Webshop> {
|
|
19
|
+
const organizationId = this.options.organizationId ?? (await new OrganizationFactory({}).create()).id;
|
|
20
|
+
|
|
21
|
+
const webshop = new Webshop();
|
|
22
|
+
webshop.organizationId = organizationId;
|
|
23
|
+
webshop.meta = WebshopMetaData.create({
|
|
24
|
+
name: this.options?.name ?? ("Webshop " + (new Date().getTime() + Math.floor(Math.random() * 999999)))
|
|
25
|
+
});
|
|
26
|
+
webshop.uri = Formatter.slug(this.randomString(20));
|
|
27
|
+
|
|
28
|
+
if (this.options.meta) {
|
|
29
|
+
webshop.meta.patchOrPut(this.options.meta);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (this.options.privateMeta) {
|
|
33
|
+
webshop.privateMeta.patchOrPut(this.options.privateMeta);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
if (this.options.products) {
|
|
37
|
+
webshop.products = this.options.products;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
await webshop.save();
|
|
41
|
+
return webshop;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { SimpleErrors, SimpleError } from "@simonbackx/simple-errors";
|
|
2
|
+
import { DNSRecord, DNSRecordStatus, DNSRecordType } from "@stamhoofd/structures";
|
|
3
|
+
import { sleep } from "@stamhoofd/utility";
|
|
4
|
+
|
|
5
|
+
const { Resolver } = require('dns').promises;
|
|
6
|
+
|
|
7
|
+
export async function validateDNSRecords(dnsRecords: DNSRecord[], didRetry = false) {
|
|
8
|
+
// Revalidate all
|
|
9
|
+
const resolver = new Resolver();
|
|
10
|
+
resolver.setServers(['1.1.1.1', '8.8.8.8', '8.8.4.4']);
|
|
11
|
+
|
|
12
|
+
let allValid = true
|
|
13
|
+
|
|
14
|
+
// If all non-TXT records are valid, we can already setup the register domain
|
|
15
|
+
let hasAllNonTXT = true
|
|
16
|
+
|
|
17
|
+
for (const record of dnsRecords) {
|
|
18
|
+
try {
|
|
19
|
+
switch (record.type) {
|
|
20
|
+
case DNSRecordType.CNAME: {
|
|
21
|
+
|
|
22
|
+
const addresses: string[] = await resolver.resolveCname(record.name.substr(0, record.name.length - 1))
|
|
23
|
+
record.errors = null;
|
|
24
|
+
|
|
25
|
+
if (addresses.length == 0) {
|
|
26
|
+
record.status = DNSRecordStatus.Pending
|
|
27
|
+
allValid = false
|
|
28
|
+
hasAllNonTXT = false
|
|
29
|
+
|
|
30
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
31
|
+
code: "not_found",
|
|
32
|
+
message: "",
|
|
33
|
+
human: "We konden de CNAME-record " + record.name + " nog niet vinden. Hou er rekening mee dat het even (tot 24u) kan duren voor we deze kunnen zien."
|
|
34
|
+
}))
|
|
35
|
+
} else if (addresses.length > 1) {
|
|
36
|
+
record.status = DNSRecordStatus.Failed
|
|
37
|
+
allValid = false
|
|
38
|
+
hasAllNonTXT = false
|
|
39
|
+
|
|
40
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
41
|
+
code: "too_many_fields",
|
|
42
|
+
message: "",
|
|
43
|
+
human: "Er zijn meerdere CNAME records ingesteld voor " + record.name + ", kijk na of je er geen moet verwijderen of per ongeluk meerder hebt aangemaakt"
|
|
44
|
+
}))
|
|
45
|
+
} else {
|
|
46
|
+
if (addresses[0] + "." === record.value) {
|
|
47
|
+
record.status = DNSRecordStatus.Valid
|
|
48
|
+
} else {
|
|
49
|
+
record.status = DNSRecordStatus.Failed
|
|
50
|
+
allValid = false
|
|
51
|
+
hasAllNonTXT = false
|
|
52
|
+
|
|
53
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
54
|
+
code: "wrong_value",
|
|
55
|
+
message: "",
|
|
56
|
+
human: "Er is een andere waarde ingesteld voor de CNAME-record " + record.name + ", kijk na of je geen typfout hebt gemaakt. Gevonden: " + addresses[0] + "."
|
|
57
|
+
}))
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
case DNSRecordType.TXT: {
|
|
65
|
+
const records: string[][] = await resolver.resolveTxt(record.name.substr(0, record.name.length - 1))
|
|
66
|
+
|
|
67
|
+
record.errors = null;
|
|
68
|
+
|
|
69
|
+
if (records.length == 0) {
|
|
70
|
+
record.status = DNSRecordStatus.Pending
|
|
71
|
+
allValid = false
|
|
72
|
+
|
|
73
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
74
|
+
code: "not_found",
|
|
75
|
+
message: "",
|
|
76
|
+
human: "We konden de TXT-record " + record.name + " nog niet vinden. Hou er rekening mee dat het even (tot 24u) kan duren voor we deze kunnen zien."
|
|
77
|
+
}))
|
|
78
|
+
} else if (records.length > 1) {
|
|
79
|
+
record.status = DNSRecordStatus.Failed
|
|
80
|
+
allValid = false
|
|
81
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
82
|
+
code: "too_many_fields",
|
|
83
|
+
message: "",
|
|
84
|
+
human: "Er zijn meerdere TXT-records ingesteld voor " + record.name + ", kijk na of je er geen moet verwijderen of per ongeluk meerdere hebt aangemaakt"
|
|
85
|
+
}))
|
|
86
|
+
} else {
|
|
87
|
+
const val = records[0].join("").trim()
|
|
88
|
+
if (val === record.value.trim()) {
|
|
89
|
+
/*if (records[0].length > 1 && val.length <= 255) {
|
|
90
|
+
// Split was not needed and is not supported by SES
|
|
91
|
+
record.status = DNSRecordStatus.Failed
|
|
92
|
+
allValid = false
|
|
93
|
+
|
|
94
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
95
|
+
code: "wrong_value",
|
|
96
|
+
message: "",
|
|
97
|
+
human: "De waarde komt overeen maar is op één of andere manier opgesplitst in meerdere stukken, terwijl dat niet nodig is. Dit wordt niet ondersteund door onze e-mailprovider. Contacteer ons als je de oorzaak niet kan achterhalen."
|
|
98
|
+
}))
|
|
99
|
+
} else {*/
|
|
100
|
+
record.status = DNSRecordStatus.Valid
|
|
101
|
+
//}
|
|
102
|
+
} else {
|
|
103
|
+
record.status = DNSRecordStatus.Failed
|
|
104
|
+
allValid = false
|
|
105
|
+
|
|
106
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
107
|
+
code: "wrong_value",
|
|
108
|
+
message: "",
|
|
109
|
+
human: "Er is een andere waarde ingesteld voor de TXT-record " + record.name + ", kijk na of je geen typfout hebt gemaakt. Gevonden: " + records[0].join("")
|
|
110
|
+
}))
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
break;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
}
|
|
117
|
+
} catch (e) {
|
|
118
|
+
record.status = DNSRecordStatus.Pending
|
|
119
|
+
|
|
120
|
+
if (e.code && (e.code == "ENOTFOUND" || e.code == "ENODATA")) {
|
|
121
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
122
|
+
code: "not_found",
|
|
123
|
+
message: "",
|
|
124
|
+
human: "We konden de record " + record.name + " nog niet vinden. Hou er rekening mee dat het even (tot 24u) kan duren voor we deze kunnen zien."
|
|
125
|
+
}))
|
|
126
|
+
} else {
|
|
127
|
+
console.error(e)
|
|
128
|
+
|
|
129
|
+
record.errors = new SimpleErrors(new SimpleError({
|
|
130
|
+
code: "not_found",
|
|
131
|
+
message: "",
|
|
132
|
+
human: "Er ging iets mis. Deze record lijkt niet goed ingesteld te zijn."
|
|
133
|
+
}))
|
|
134
|
+
}
|
|
135
|
+
allValid = false
|
|
136
|
+
|
|
137
|
+
if (record.type !== DNSRecordType.TXT) {
|
|
138
|
+
hasAllNonTXT = false
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
if (!allValid && !didRetry) {
|
|
144
|
+
// Do a retry once
|
|
145
|
+
await sleep(100)
|
|
146
|
+
return validateDNSRecords(dnsRecords, true)
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
return {
|
|
150
|
+
hasAllNonTXT,
|
|
151
|
+
allValid
|
|
152
|
+
}
|
|
153
|
+
}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { EmailAddress, EmailBuilder } from "@stamhoofd/email";
|
|
2
|
+
import { Recipient, Replacement } from "@stamhoofd/structures";
|
|
3
|
+
import { Formatter } from "@stamhoofd/utility";
|
|
4
|
+
|
|
5
|
+
import { Organization, PasswordToken, User } from "../models";
|
|
6
|
+
|
|
7
|
+
export async function getEmailBuilder(organization: Organization, email: {
|
|
8
|
+
defaultReplacements?: Replacement[],
|
|
9
|
+
recipients: Recipient[],
|
|
10
|
+
from: string,
|
|
11
|
+
replyTo?: string,
|
|
12
|
+
subject: string,
|
|
13
|
+
//text: string | null,
|
|
14
|
+
html: string | null,
|
|
15
|
+
attachments?: {
|
|
16
|
+
filename: string;
|
|
17
|
+
content: string;
|
|
18
|
+
contentType: string | undefined;
|
|
19
|
+
encoding: string;
|
|
20
|
+
}[],
|
|
21
|
+
type?: "transactional" | "broadcast",
|
|
22
|
+
unsubscribeType?: 'all'|'marketing',
|
|
23
|
+
fromStamhoofd?: boolean,
|
|
24
|
+
singleBcc?: string
|
|
25
|
+
}) {
|
|
26
|
+
// Update recipients
|
|
27
|
+
const cleaned: Recipient[] = []
|
|
28
|
+
for (const recipient of email.recipients) {
|
|
29
|
+
try {
|
|
30
|
+
const unsubscribe = await EmailAddress.getOrCreate(recipient.email, email.fromStamhoofd ? null : organization.id)
|
|
31
|
+
|
|
32
|
+
if (unsubscribe.unsubscribedAll || unsubscribe.hardBounce || unsubscribe.markedAsSpam || !unsubscribe.token || (unsubscribe.unsubscribedMarketing && email.unsubscribeType === 'marketing')) {
|
|
33
|
+
// Ignore
|
|
34
|
+
continue
|
|
35
|
+
}
|
|
36
|
+
recipient.replacements.push(Replacement.create({
|
|
37
|
+
token: "unsubscribeUrl",
|
|
38
|
+
value: "https://"+STAMHOOFD.domains.dashboard+"/"+organization.i18n.locale+"/unsubscribe?id="+encodeURIComponent(unsubscribe.id)+"&token="+encodeURIComponent(unsubscribe.token)+"&type="+encodeURIComponent(email.unsubscribeType ?? 'all')
|
|
39
|
+
}))
|
|
40
|
+
|
|
41
|
+
// Override headers
|
|
42
|
+
recipient.headers = {
|
|
43
|
+
'List-Unsubscribe': "<mailto:unsubscribe+"+unsubscribe.id+"@stamhoofd.email>",
|
|
44
|
+
'List-Unsubscribe-Post': 'List-Unsubscribe=One-Click'
|
|
45
|
+
}
|
|
46
|
+
cleaned.push(recipient)
|
|
47
|
+
} catch (e) {
|
|
48
|
+
console.error(e)
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
email.recipients = cleaned
|
|
52
|
+
|
|
53
|
+
// Update recipients
|
|
54
|
+
for (const recipient of email.recipients) {
|
|
55
|
+
recipient.replacements = recipient.replacements.slice()
|
|
56
|
+
|
|
57
|
+
// Default signInUrl
|
|
58
|
+
let signInUrl = "https://"+organization.getHost()+"/login?email="+encodeURIComponent(recipient.email)
|
|
59
|
+
|
|
60
|
+
if (recipient.userId) {
|
|
61
|
+
const recipientUser = await User.getByID(recipient.userId)
|
|
62
|
+
if (recipientUser && recipientUser.organizationId === organization.id && recipientUser.email === recipient.email) {
|
|
63
|
+
// We can create a special token
|
|
64
|
+
signInUrl = await PasswordToken.getMagicSignInUrl(recipientUser, organization)
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
recipient.replacements.push(Replacement.create({
|
|
69
|
+
token: "signInUrl",
|
|
70
|
+
value: signInUrl
|
|
71
|
+
}))
|
|
72
|
+
|
|
73
|
+
if (email.defaultReplacements) {
|
|
74
|
+
recipient.replacements.push(...email.defaultReplacements)
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const extra = organization.meta.getEmailReplacements()
|
|
78
|
+
recipient.replacements.push(...extra)
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const queue = email.recipients.slice()
|
|
82
|
+
|
|
83
|
+
let emailIndex = 0;
|
|
84
|
+
|
|
85
|
+
// Create e-mail builder
|
|
86
|
+
const builder: EmailBuilder = () => {
|
|
87
|
+
const recipient = queue.shift()
|
|
88
|
+
if (!recipient) {
|
|
89
|
+
return undefined
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
let replacedHtml = email.html
|
|
93
|
+
let replacedSubject = email.subject
|
|
94
|
+
//let replacedText = email.text
|
|
95
|
+
|
|
96
|
+
for (const replacement of recipient.replacements) {
|
|
97
|
+
if (replacedHtml) {
|
|
98
|
+
replacedHtml = replacedHtml.replaceAll("{{"+replacement.token+"}}", replacement.html ?? Formatter.escapeHtml(replacement.value))
|
|
99
|
+
}
|
|
100
|
+
//if (replacedText) {
|
|
101
|
+
// replacedText = replacedText.replaceAll("{{"+replacement.token+"}}", replacement.value)
|
|
102
|
+
//}
|
|
103
|
+
replacedSubject = replacedSubject.replaceAll("{{"+replacement.token+"}}", replacement.value)
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
emailIndex += 1;
|
|
107
|
+
|
|
108
|
+
return {
|
|
109
|
+
from: email.from,
|
|
110
|
+
replyTo: email.replyTo,
|
|
111
|
+
bcc: emailIndex === 1 ? email.singleBcc : undefined,
|
|
112
|
+
to: [
|
|
113
|
+
{
|
|
114
|
+
// Name will get cleaned by email service
|
|
115
|
+
name: (recipient.firstName??'')+" "+(recipient.lastName??''),
|
|
116
|
+
email: recipient.email
|
|
117
|
+
}
|
|
118
|
+
],
|
|
119
|
+
subject: replacedSubject,
|
|
120
|
+
html: replacedHtml ?? undefined,
|
|
121
|
+
attachments: email.attachments,
|
|
122
|
+
headers: recipient.headers,
|
|
123
|
+
type: email.type
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
return builder;
|
|
127
|
+
}
|