@nlabs/reaktor 0.10.1 → 0.10.2
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/coverage/actions/index.html +21 -36
- package/coverage/actions/notifications.ts.html +223 -0
- package/coverage/actions/posts.ts.html +2356 -0
- package/coverage/adapters/arangoAdapter.ts.html +170 -20
- package/coverage/adapters/fileAdapter.ts.html +445 -0
- package/coverage/adapters/index.html +72 -42
- package/coverage/adapters/postAdapter.ts.html +436 -0
- package/coverage/adapters/reaktorAdapter.ts.html +201 -18
- package/coverage/adapters/tagAdapter.ts.html +274 -25
- package/coverage/adapters/userAdapter.ts.html +829 -0
- package/coverage/analyticsUtils.ts.html +286 -0
- package/coverage/config.ts.html +766 -0
- package/coverage/index.html +81 -51
- package/coverage/mocks/group.ts.html +5 -5
- package/coverage/mocks/image.ts.html +18 -12
- package/coverage/mocks/index.html +37 -7
- package/coverage/mocks/post.ts.html +8 -8
- package/coverage/mocks/tag.ts.html +2 -2
- package/coverage/mocks/user.ts.html +18 -15
- package/coverage/testUtils.ts.html +1309 -0
- package/coverage/translationQueue.ts.html +592 -0
- package/coverage/types/error.types.ts.html +148 -0
- package/coverage/types/index.html +2 -2
- package/coverage/utils/adapterUtils.ts.html +39 -27
- package/coverage/utils/analyticsUtils.ts.html +35 -41
- package/coverage/utils/authUtils.ts.html +328 -0
- package/coverage/utils/dbI18n.ts.html +280 -0
- package/coverage/utils/googleTranslate.ts.html +385 -0
- package/coverage/utils/index.html +29 -44
- package/coverage/utils/localeUtils.ts.html +193 -0
- package/coverage/utils/sessionUtils.ts.html +211 -0
- package/coverage/utils/testUtils.ts.html +1309 -0
- package/lex.config.mjs +34 -0
- package/lib/actions/apps.d.ts +25 -0
- package/lib/actions/apps.js +11 -11
- package/lib/actions/connections.d.ts +5 -0
- package/lib/actions/connections.js +6 -6
- package/lib/actions/content.d.ts +13 -0
- package/lib/actions/content.js +9 -9
- package/lib/actions/conversations.d.ts +16 -0
- package/lib/actions/conversations.js +17 -17
- package/lib/actions/dynamodb.d.ts +12 -0
- package/lib/actions/dynamodb.js +2 -2
- package/lib/actions/email.d.ts +8 -0
- package/lib/actions/email.js +2 -2
- package/lib/actions/files.d.ts +19 -0
- package/lib/actions/files.js +3 -3
- package/lib/actions/groups.d.ts +13 -0
- package/lib/actions/groups.js +15 -15
- package/lib/actions/images.d.ts +33 -0
- package/lib/actions/images.js +22 -22
- package/lib/actions/index.d.ts +27 -0
- package/lib/actions/index.js +2 -2
- package/lib/actions/ios.d.ts +7 -0
- package/lib/actions/ios.js +4 -4
- package/lib/actions/locations.d.ts +6 -0
- package/lib/actions/locations.js +3 -3
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +3 -3
- package/lib/actions/notifications.d.ts +9 -0
- package/lib/actions/notifications.js +2 -2
- package/lib/actions/payments.d.ts +12 -0
- package/lib/actions/payments.js +6 -6
- package/lib/actions/posts.d.ts +25 -0
- package/lib/actions/posts.js +30 -30
- package/lib/actions/profiles.d.ts +4 -0
- package/lib/actions/profiles.js +4 -4
- package/lib/actions/reactions.d.ts +32 -0
- package/lib/actions/reactions.js +16 -16
- package/lib/actions/s3.d.ts +11 -0
- package/lib/actions/s3.js +2 -2
- package/lib/actions/search.d.ts +3 -0
- package/lib/actions/search.js +3 -3
- package/lib/actions/sms.d.ts +2 -0
- package/lib/actions/sms.js +2 -2
- package/lib/actions/statistics.d.ts +4 -0
- package/lib/actions/statistics.js +4 -4
- package/lib/actions/subscriptions.d.ts +7 -0
- package/lib/actions/subscriptions.js +6 -6
- package/lib/actions/tags.d.ts +34 -0
- package/lib/actions/tags.js +6 -6
- package/lib/actions/users.d.ts +73 -0
- package/lib/actions/users.js +45 -42
- package/lib/actions/websockets.d.ts +20 -0
- package/lib/actions/websockets.js +8 -8
- package/lib/adapters/arangoAdapter.d.ts +8 -0
- package/lib/adapters/arangoAdapter.js +2 -2
- package/lib/adapters/contentAdapter.d.ts +8 -0
- package/lib/adapters/contentAdapter.js +2 -2
- package/lib/adapters/fileAdapter.d.ts +9 -0
- package/lib/adapters/fileAdapter.js +2 -2
- package/lib/adapters/imageAdapter.d.ts +8 -0
- package/lib/adapters/imageAdapter.js +2 -2
- package/lib/adapters/index.d.ts +9 -0
- package/lib/adapters/index.js +2 -0
- package/lib/adapters/messageAdapter.d.ts +8 -0
- package/lib/adapters/messageAdapter.js +2 -2
- package/lib/adapters/postAdapter.d.ts +8 -0
- package/lib/adapters/postAdapter.js +2 -2
- package/lib/adapters/reaktorAdapter.d.ts +16 -0
- package/lib/adapters/reaktorAdapter.js +2 -2
- package/lib/adapters/tagAdapter.d.ts +9 -0
- package/lib/adapters/tagAdapter.js +2 -2
- package/lib/adapters/userAdapter.d.ts +13 -0
- package/lib/adapters/userAdapter.js +2 -2
- package/lib/config.d.ts +57 -0
- package/lib/config.js +2 -2
- package/lib/handlers/graphqlHandler.d.ts +4 -0
- package/lib/handlers/graphqlHandler.js +2 -2
- package/lib/index.d.ts +19 -0
- package/lib/index.js +2 -2
- package/lib/lambdas/actions/websockets.d.ts +7 -0
- package/lib/lambdas/actions/websockets.js +6 -6
- package/lib/lambdas/authorizer.d.ts +20 -0
- package/lib/lambdas/authorizer.js +2 -2
- package/lib/lambdas/connection.d.ts +12 -0
- package/lib/lambdas/connection.js +2 -2
- package/lib/lambdas/utils/message.d.ts +1 -0
- package/lib/lambdas/utils/websocket.d.ts +7 -0
- package/lib/lambdas/utils/websocket.js +2 -2
- package/lib/mocks/conversation.d.ts +8 -0
- package/lib/mocks/file.d.ts +11 -0
- package/lib/mocks/group.d.ts +17 -0
- package/lib/mocks/group.js +2 -2
- package/lib/mocks/image.d.ts +3 -0
- package/lib/mocks/image.js +2 -2
- package/lib/mocks/post.d.ts +38 -0
- package/lib/mocks/post.js +2 -2
- package/lib/mocks/tag.d.ts +2 -0
- package/lib/mocks/tag.js +1 -1
- package/lib/mocks/user.d.ts +4 -0
- package/lib/mocks/user.js +2 -2
- package/lib/mutations/content.d.ts +2 -0
- package/lib/mutations/content.js +2 -0
- package/lib/mutations/index.d.ts +11 -0
- package/lib/mutations/index.js +2 -2
- package/lib/mutations/locations.d.ts +2 -0
- package/lib/mutations/locations.js +2 -2
- package/lib/mutations/messages.d.ts +2 -0
- package/lib/mutations/messages.js +2 -2
- package/lib/mutations/posts.d.ts +2 -0
- package/lib/mutations/posts.js +2 -2
- package/lib/mutations/profiles.d.ts +2 -0
- package/lib/mutations/profiles.js +2 -2
- package/lib/mutations/reactions.d.ts +2 -0
- package/lib/mutations/reactions.js +2 -2
- package/lib/mutations/statistics.d.ts +2 -0
- package/lib/mutations/statistics.js +2 -2
- package/lib/mutations/subscriptions.d.ts +2 -0
- package/lib/mutations/subscriptions.js +2 -2
- package/lib/mutations/tags.d.ts +2 -0
- package/lib/mutations/tags.js +2 -2
- package/lib/mutations/users.d.ts +1 -0
- package/lib/mutations/users.js +2 -2
- package/lib/objectTypes/app.d.ts +3 -0
- package/lib/objectTypes/app.js +2 -2
- package/lib/objectTypes/bankAccount.d.ts +1 -0
- package/lib/objectTypes/connection.d.ts +1 -0
- package/lib/objectTypes/connection.js +2 -2
- package/lib/objectTypes/content.d.ts +2 -0
- package/lib/objectTypes/content.js +2 -0
- package/lib/objectTypes/conversation.d.ts +2 -0
- package/lib/objectTypes/conversation.js +2 -2
- package/lib/objectTypes/creditCard.d.ts +1 -0
- package/lib/objectTypes/document.d.ts +1 -0
- package/lib/objectTypes/error.d.ts +1 -0
- package/lib/objectTypes/external.d.ts +1 -0
- package/lib/objectTypes/external.js +2 -2
- package/lib/objectTypes/file.d.ts +2 -0
- package/lib/objectTypes/file.js +2 -2
- package/lib/objectTypes/filter.d.ts +1 -0
- package/lib/objectTypes/group.d.ts +3 -0
- package/lib/objectTypes/group.js +2 -2
- package/lib/objectTypes/iapSubscription.d.ts +1 -0
- package/lib/objectTypes/image.d.ts +6 -0
- package/lib/objectTypes/image.js +2 -2
- package/lib/objectTypes/index.d.ts +26 -0
- package/lib/objectTypes/index.js +2 -2
- package/lib/objectTypes/location.d.ts +2 -0
- package/lib/objectTypes/location.js +2 -2
- package/lib/objectTypes/message.d.ts +2 -0
- package/lib/objectTypes/message.js +2 -2
- package/lib/objectTypes/passcode.d.ts +1 -0
- package/lib/objectTypes/passcode.js +2 -2
- package/lib/objectTypes/plan.d.ts +2 -0
- package/lib/objectTypes/plan.js +2 -2
- package/lib/objectTypes/post.d.ts +2 -0
- package/lib/objectTypes/post.js +2 -2
- package/lib/objectTypes/profile.d.ts +3 -0
- package/lib/objectTypes/profile.js +2 -2
- package/lib/objectTypes/reaction.d.ts +2 -0
- package/lib/objectTypes/reaction.js +2 -2
- package/lib/objectTypes/relation.d.ts +1 -0
- package/lib/objectTypes/relation.js +2 -2
- package/lib/objectTypes/search.d.ts +1 -0
- package/lib/objectTypes/search.js +2 -2
- package/lib/objectTypes/statistics.d.ts +1 -0
- package/lib/objectTypes/statistics.js +2 -2
- package/lib/objectTypes/subscription.d.ts +2 -0
- package/lib/objectTypes/subscription.js +2 -2
- package/lib/objectTypes/tag.d.ts +2 -0
- package/lib/objectTypes/tag.js +2 -2
- package/lib/objectTypes/user.d.ts +4 -0
- package/lib/objectTypes/user.js +2 -2
- package/lib/queries/content.d.ts +2 -0
- package/lib/queries/content.js +2 -0
- package/lib/queries/index.d.ts +10 -0
- package/lib/queries/index.js +2 -2
- package/lib/queries/locations.d.ts +2 -0
- package/lib/queries/locations.js +2 -2
- package/lib/queries/messages.d.ts +2 -0
- package/lib/queries/messages.js +2 -2
- package/lib/queries/posts.d.ts +2 -0
- package/lib/queries/posts.js +2 -2
- package/lib/queries/reactions.d.ts +2 -0
- package/lib/queries/reactions.js +2 -2
- package/lib/queries/statistics.d.ts +2 -0
- package/lib/queries/statistics.js +2 -2
- package/lib/queries/subscriptions.d.ts +2 -0
- package/lib/queries/subscriptions.js +2 -2
- package/lib/queries/tags.d.ts +2 -0
- package/lib/queries/tags.js +2 -2
- package/lib/queries/users.d.ts +1 -0
- package/lib/queries/users.js +2 -2
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/types/apps.types.d.ts +50 -0
- package/lib/types/apps.types.js +1 -1
- package/lib/types/arangodb.types.d.ts +38 -0
- package/lib/types/auth.types.d.ts +15 -0
- package/lib/types/connections.types.d.ts +9 -0
- package/lib/types/content.types.d.ts +31 -0
- package/lib/types/conversations.types.d.ts +31 -0
- package/lib/types/email.types.d.ts +17 -0
- package/lib/types/error.types.d.ts +21 -0
- package/lib/types/files.types.d.ts +27 -0
- package/lib/types/google.types.d.ts +33 -0
- package/lib/types/groups.types.d.ts +22 -0
- package/lib/types/images.types.d.ts +56 -0
- package/lib/types/index.d.ts +26 -0
- package/lib/types/index.js +2 -2
- package/lib/types/locations.types.d.ts +22 -0
- package/lib/types/messages.types.d.ts +20 -0
- package/lib/types/notifications.types.d.ts +23 -0
- package/lib/types/payments.types.d.ts +113 -0
- package/lib/types/posts.types.d.ts +32 -0
- package/lib/types/profiles.types.d.ts +20 -0
- package/lib/types/statistics.types.d.ts +3 -0
- package/lib/types/tags.types.d.ts +19 -0
- package/lib/types/users.types.d.ts +110 -0
- package/lib/types/websockets.types.d.ts +22 -0
- package/lib/utils/adapterUtils.d.ts +5 -0
- package/lib/utils/analyticsUtils.d.ts +25 -0
- package/lib/utils/analyticsUtils.js +2 -2
- package/lib/utils/arangodbUtils.d.ts +70 -0
- package/lib/utils/arangodbUtils.js +3 -3
- package/lib/utils/authUtils.d.ts +23 -0
- package/lib/utils/authUtils.js +2 -2
- package/lib/utils/contextUtils.d.ts +3 -0
- package/lib/utils/contextUtils.js +1 -1
- package/lib/utils/dbI18n.d.ts +10 -0
- package/lib/utils/dbI18n.example.d.ts +20 -0
- package/lib/utils/dbI18n.example.js +3 -3
- package/lib/utils/dbI18n.js +2 -2
- package/lib/utils/googleTranslate.d.ts +6 -0
- package/lib/utils/googleTranslate.js +2 -2
- package/lib/utils/graphqlUtils.d.ts +10 -0
- package/lib/utils/graphqlUtils.js +2 -2
- package/lib/utils/index.d.ts +18 -0
- package/lib/utils/index.js +2 -2
- package/lib/utils/languageDetection.d.ts +8 -0
- package/lib/utils/languageDetection.js +1 -1
- package/lib/utils/localeUtils.d.ts +11 -0
- package/lib/utils/localeUtils.example.d.ts +5 -0
- package/lib/utils/localeUtils.example.js +2 -2
- package/lib/utils/localeUtils.js +1 -1
- package/lib/utils/middlewareUtils.d.ts +2 -0
- package/lib/utils/middlewareUtils.js +2 -2
- package/lib/utils/sessionUtils.d.ts +18 -0
- package/lib/utils/sessionUtils.js +2 -2
- package/lib/utils/stripeUtils.d.ts +7 -0
- package/lib/utils/stripeUtils.js +2 -2
- package/lib/utils/templateUtils.d.ts +3 -0
- package/lib/utils/testUtils.d.ts +95 -0
- package/lib/utils/testUtils.js +2 -2
- package/lib/utils/translationQueue.d.ts +29 -0
- package/lib/utils/translationQueue.example.d.ts +33 -0
- package/lib/utils/translationQueue.example.js +2 -2
- package/lib/utils/translationQueue.js +2 -2
- package/package.json +22 -21
- package/tsconfig.build.json +21 -0
- package/tsconfig.lint.json +33 -0
- package/tsconfig.test.json +31 -0
- package/dist/actions/apps.js +0 -242
- package/dist/actions/connections.js +0 -90
- package/dist/actions/conversations.js +0 -350
- package/dist/actions/dynamodb.js +0 -150
- package/dist/actions/email.js +0 -152
- package/dist/actions/files.js +0 -283
- package/dist/actions/groups.js +0 -292
- package/dist/actions/images.js +0 -735
- package/dist/actions/index.js +0 -66
- package/dist/actions/ios.js +0 -164
- package/dist/actions/locations.js +0 -122
- package/dist/actions/messages.js +0 -208
- package/dist/actions/notifications.js +0 -59
- package/dist/actions/payments.js +0 -497
- package/dist/actions/personas.js +0 -110
- package/dist/actions/posts.js +0 -595
- package/dist/actions/reactions.js +0 -322
- package/dist/actions/s3.js +0 -133
- package/dist/actions/search.js +0 -90
- package/dist/actions/sms.js +0 -108
- package/dist/actions/statistics.js +0 -62
- package/dist/actions/subscription.js +0 -220
- package/dist/actions/tags.js +0 -292
- package/dist/actions/users.js +0 -784
- package/dist/actions/websockets.js +0 -174
- package/dist/adapters/arangoAdapter.js +0 -46
- package/dist/adapters/fileAdapter.js +0 -76
- package/dist/adapters/imageAdapter.js +0 -40
- package/dist/adapters/messageAdapter.js +0 -49
- package/dist/adapters/postAdapter.js +0 -70
- package/dist/adapters/reaktorAdapter.js +0 -44
- package/dist/adapters/tagAdapter.js +0 -50
- package/dist/adapters/userAdapter.js +0 -115
- package/dist/config.js +0 -125
- package/dist/index.js +0 -66
- package/dist/lambdas/actions/websockets.js +0 -132
- package/dist/lambdas/authorizer.js +0 -67
- package/dist/lambdas/connection.js +0 -91
- package/dist/lambdas/utils/message.js +0 -42
- package/dist/lambdas/utils/websocket.js +0 -105
- package/dist/mocks/conversation.js +0 -35
- package/dist/mocks/file.js +0 -38
- package/dist/mocks/group.js +0 -47
- package/dist/mocks/image.js +0 -44
- package/dist/mocks/nlabs.png +0 -0
- package/dist/mocks/post.js +0 -55
- package/dist/mocks/tag.js +0 -37
- package/dist/mocks/user.js +0 -88
- package/dist/mutations/index.js +0 -26
- package/dist/mutations/locations.js +0 -44
- package/dist/mutations/messages.js +0 -86
- package/dist/mutations/personas.js +0 -100
- package/dist/mutations/posts.js +0 -53
- package/dist/mutations/reactions.js +0 -51
- package/dist/mutations/statistics.js +0 -39
- package/dist/mutations/subscriptions.js +0 -56
- package/dist/mutations/tags.js +0 -120
- package/dist/mutations/users.js +0 -116
- package/dist/objectTypes/app.js +0 -173
- package/dist/objectTypes/bankAccount.js +0 -76
- package/dist/objectTypes/connection.js +0 -48
- package/dist/objectTypes/conversation.js +0 -77
- package/dist/objectTypes/creditCard.js +0 -86
- package/dist/objectTypes/document.js +0 -46
- package/dist/objectTypes/error.js +0 -46
- package/dist/objectTypes/external.js +0 -74
- package/dist/objectTypes/file.js +0 -100
- package/dist/objectTypes/filter.js +0 -43
- package/dist/objectTypes/group.js +0 -123
- package/dist/objectTypes/iapSubscription.js +0 -40
- package/dist/objectTypes/image.js +0 -129
- package/dist/objectTypes/index.js +0 -68
- package/dist/objectTypes/location.js +0 -109
- package/dist/objectTypes/message.js +0 -96
- package/dist/objectTypes/passcode.js +0 -42
- package/dist/objectTypes/persona.js +0 -87
- package/dist/objectTypes/plan.js +0 -95
- package/dist/objectTypes/post.js +0 -125
- package/dist/objectTypes/reaction.js +0 -61
- package/dist/objectTypes/relation.js +0 -49
- package/dist/objectTypes/search.js +0 -72
- package/dist/objectTypes/statistics.js +0 -39
- package/dist/objectTypes/subscription.js +0 -117
- package/dist/objectTypes/tag.js +0 -65
- package/dist/objectTypes/user.js +0 -144
- package/dist/queries/index.js +0 -33
- package/dist/queries/locations.js +0 -45
- package/dist/queries/messages.js +0 -52
- package/dist/queries/posts.js +0 -154
- package/dist/queries/reactions.js +0 -56
- package/dist/queries/statistics.js +0 -39
- package/dist/queries/subscriptions.js +0 -44
- package/dist/queries/tags.js +0 -75
- package/dist/queries/users.js +0 -64
- package/dist/templates/email/layout.js +0 -302
- package/dist/templates/email/passwordForgot.js +0 -38
- package/dist/templates/email/passwordRecovery.js +0 -35
- package/dist/templates/email/verifyEmail.js +0 -38
- package/dist/templates/email/welcome.js +0 -38
- package/dist/templates/sms/passwordForgot.js +0 -24
- package/dist/templates/sms/passwordRecovery.js +0 -24
- package/dist/templates/sms/verifyEmail.js +0 -24
- package/dist/templates/sms/verifyPhone.js +0 -24
- package/dist/templates/sms/welcome.js +0 -24
- package/dist/types/apps.js +0 -32
- package/dist/types/arangodb.js +0 -16
- package/dist/types/auth.js +0 -16
- package/dist/types/connections.js +0 -16
- package/dist/types/conversations.js +0 -16
- package/dist/types/email.js +0 -16
- package/dist/types/error.js +0 -44
- package/dist/types/files.js +0 -16
- package/dist/types/google.js +0 -16
- package/dist/types/groups.js +0 -16
- package/dist/types/images.js +0 -16
- package/dist/types/index.js +0 -60
- package/dist/types/locations.js +0 -16
- package/dist/types/messages.js +0 -16
- package/dist/types/notifications.js +0 -16
- package/dist/types/payments.js +0 -16
- package/dist/types/personas.js +0 -16
- package/dist/types/posts.js +0 -16
- package/dist/types/statistics.js +0 -16
- package/dist/types/tags.js +0 -16
- package/dist/types/users.js +0 -16
- package/dist/types/websockets.js +0 -16
- package/dist/utils/adapterUtils.js +0 -45
- package/dist/utils/analyticsUtils.js +0 -72
- package/dist/utils/arangodbUtils.js +0 -165
- package/dist/utils/auth.js +0 -57
- package/dist/utils/index.js +0 -30
- package/dist/utils/session.js +0 -60
- package/jest.config.js +0 -17
- package/jest.setup.js +0 -36
- package/lex.config.cjs +0 -13
- package/lib/mutations/locations.integration.js +0 -2
- package/lib/mutations/messages.integration.js +0 -2
- package/lib/mutations/posts.integration.js +0 -2
- package/lib/mutations/profiles.integration.js +0 -2
- package/lib/mutations/reactions.integration.js +0 -2
- package/lib/mutations/statistics.integration.js +0 -2
- package/lib/mutations/subscriptions.integration.js +0 -2
- package/lib/mutations/tags.integration.js +0 -2
- package/lib/mutations/users.integration.js +0 -2
- package/lib/queries/locations.integration.js +0 -2
- package/lib/queries/messages.integration.js +0 -2
- package/lib/queries/posts.integration.js +0 -2
- package/lib/queries/reactions.integration.js +0 -2
- package/lib/queries/tags.integration.js +0 -2
- package/lib/queries/users.integration.js +0 -2
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __export = (target, all) => {
|
|
6
|
-
for (var name in all)
|
|
7
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
-
};
|
|
9
|
-
var __copyProps = (to, from, except, desc) => {
|
|
10
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
-
for (let key of __getOwnPropNames(from))
|
|
12
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
-
}
|
|
15
|
-
return to;
|
|
16
|
-
};
|
|
17
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
-
var notifications_exports = {};
|
|
19
|
-
__export(notifications_exports, {
|
|
20
|
-
clearBadges: () => clearBadges,
|
|
21
|
-
getApnProvider: () => getApnProvider,
|
|
22
|
-
pushNotification: () => pushNotification
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(notifications_exports);
|
|
25
|
-
var import_apn = require("apn");
|
|
26
|
-
var import_config = require("../config");
|
|
27
|
-
const getApnProvider = () => new import_apn.Provider({
|
|
28
|
-
ca: import_config.Config.get("app.apn.ca"),
|
|
29
|
-
cert: import_config.Config.get("app.apn.cert"),
|
|
30
|
-
key: import_config.Config.get("app.apn.key"),
|
|
31
|
-
production: import_config.Config.get("environment") === "prod"
|
|
32
|
-
});
|
|
33
|
-
const pushNotification = (deviceTokens, note) => {
|
|
34
|
-
const provider = getApnProvider();
|
|
35
|
-
const notification = new import_apn.Notification();
|
|
36
|
-
notification.topic = import_config.Config.get("app.apn.id");
|
|
37
|
-
notification.alert = note.message;
|
|
38
|
-
if (note.data) {
|
|
39
|
-
notification.mutableContent = true;
|
|
40
|
-
notification.payload = note.data;
|
|
41
|
-
}
|
|
42
|
-
if (note.badge !== void 0) {
|
|
43
|
-
notification.badge = note.badge;
|
|
44
|
-
}
|
|
45
|
-
return provider.send(notification, deviceTokens);
|
|
46
|
-
};
|
|
47
|
-
const clearBadges = (deviceTokens) => {
|
|
48
|
-
const provider = getApnProvider();
|
|
49
|
-
const notification = new import_apn.Notification();
|
|
50
|
-
notification.badge = 0;
|
|
51
|
-
return provider.send(notification, deviceTokens);
|
|
52
|
-
};
|
|
53
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
54
|
-
0 && (module.exports = {
|
|
55
|
-
clearBadges,
|
|
56
|
-
getApnProvider,
|
|
57
|
-
pushNotification
|
|
58
|
-
});
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcblxuaW1wb3J0IHR5cGUge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG5leHBvcnQgY29uc3QgZ2V0QXBuUHJvdmlkZXIgPSAoKSA9PiBuZXcgUHJvdmlkZXIoe1xuICBjYTogQ29uZmlnLmdldCgnYXBwLmFwbi5jYScpLFxuICBjZXJ0OiBDb25maWcuZ2V0KCdhcHAuYXBuLmNlcnQnKSxcbiAga2V5OiBDb25maWcuZ2V0KCdhcHAuYXBuLmtleScpLFxuICBwcm9kdWN0aW9uOiBDb25maWcuZ2V0KCdlbnZpcm9ubWVudCcpID09PSAncHJvZCdcbn0pO1xuXG5leHBvcnQgY29uc3QgcHVzaE5vdGlmaWNhdGlvbiA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdLCBub3RlOiBOb3RpZmljYXRpb25UeXBlKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyOiBQcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbjogQVBOTm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24udG9waWMgPSBDb25maWcuZ2V0KCdhcHAuYXBuLmlkJyk7XG4gIG5vdGlmaWNhdGlvbi5hbGVydCA9IG5vdGUubWVzc2FnZTtcblxuICBpZihub3RlLmRhdGEpIHtcbiAgICBub3RpZmljYXRpb24ubXV0YWJsZUNvbnRlbnQgPSB0cnVlO1xuICAgIG5vdGlmaWNhdGlvbi5wYXlsb2FkID0gbm90ZS5kYXRhO1xuICB9XG5cbiAgaWYobm90ZS5iYWRnZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgbm90aWZpY2F0aW9uLmJhZGdlID0gbm90ZS5iYWRnZTtcbiAgfVxuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhckJhZGdlcyA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24uYmFkZ2UgPSAwO1xuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBTUEsaUJBQW1FO0FBRW5FLG9CQUFxQjtBQUlkLE1BQU0saUJBQWlCLE1BQU0sSUFBSSxvQkFBUztBQUFBLEVBQy9DLElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==
|
package/dist/actions/payments.js
DELETED
|
@@ -1,497 +0,0 @@
|
|
|
1
|
-
var __create = Object.create;
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
-
mod
|
|
26
|
-
));
|
|
27
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
-
var payments_exports = {};
|
|
29
|
-
__export(payments_exports, {
|
|
30
|
-
addBankAccount: () => addBankAccount,
|
|
31
|
-
addCreditCard: () => addCreditCard,
|
|
32
|
-
addCustomerAccount: () => addCustomerAccount,
|
|
33
|
-
createPaymentHold: () => createPaymentHold,
|
|
34
|
-
createPaymentTransfer: () => createPaymentTransfer,
|
|
35
|
-
deleteBankAccount: () => deleteBankAccount,
|
|
36
|
-
deleteCreditCard: () => deleteCreditCard,
|
|
37
|
-
getCreditCards: () => getCreditCards,
|
|
38
|
-
updateCreditCard: () => updateCreditCard
|
|
39
|
-
});
|
|
40
|
-
module.exports = __toCommonJS(payments_exports);
|
|
41
|
-
var import_utils = require("@nlabs/utils");
|
|
42
|
-
var import_arangojs = require("arangojs");
|
|
43
|
-
var import_stripe = __toESM(require("stripe"), 1);
|
|
44
|
-
var import_config = require("../config");
|
|
45
|
-
var import_users = require("./users");
|
|
46
|
-
var import_error = require("../types/error");
|
|
47
|
-
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
48
|
-
const eventCategory = "payments";
|
|
49
|
-
const apiVersion = "2025-02-24.acacia";
|
|
50
|
-
const addCustomerAccount = (context) => {
|
|
51
|
-
const action = "addCustomerAccount";
|
|
52
|
-
const { database, session: { userId: sessionId, username } } = context;
|
|
53
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
54
|
-
return stripeClient.customers.create({
|
|
55
|
-
metadata: {
|
|
56
|
-
userId: sessionId,
|
|
57
|
-
username
|
|
58
|
-
}
|
|
59
|
-
}).then((customer) => {
|
|
60
|
-
const now = Date.now();
|
|
61
|
-
const update = {
|
|
62
|
-
modified: now,
|
|
63
|
-
stripeCustomerId: customer.id
|
|
64
|
-
};
|
|
65
|
-
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
66
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser) => !!updatedUser).catch((error) => (0, import_analyticsUtils.logError)({
|
|
67
|
-
action,
|
|
68
|
-
category: eventCategory,
|
|
69
|
-
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
70
|
-
}, error, context).then(() => null));
|
|
71
|
-
});
|
|
72
|
-
};
|
|
73
|
-
const addBankAccount = (context, bankAccount) => {
|
|
74
|
-
const action = "addPaymentAccountBank";
|
|
75
|
-
const { database, session: { userId: sessionId } } = context;
|
|
76
|
-
const {
|
|
77
|
-
accountNumber,
|
|
78
|
-
fullName,
|
|
79
|
-
routing
|
|
80
|
-
} = bankAccount;
|
|
81
|
-
const formatAccount = (0, import_utils.parseString)(accountNumber, 32);
|
|
82
|
-
if (formatAccount === "") {
|
|
83
|
-
throw new import_analyticsUtils.UserError("required_account_number");
|
|
84
|
-
}
|
|
85
|
-
const formatFullName = (0, import_utils.parseVarChar)(fullName, 128);
|
|
86
|
-
if (formatFullName === "") {
|
|
87
|
-
throw new import_analyticsUtils.UserError("required_full_name");
|
|
88
|
-
}
|
|
89
|
-
const formatRouting = (0, import_utils.parseString)(routing, 32);
|
|
90
|
-
if (formatRouting === "") {
|
|
91
|
-
throw new import_analyticsUtils.UserError("required_routing_number");
|
|
92
|
-
}
|
|
93
|
-
return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
|
|
94
|
-
const { stripeAccountId } = user;
|
|
95
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
96
|
-
return stripeClient.tokens.create({
|
|
97
|
-
bank_account: {
|
|
98
|
-
account_holder_name: formatFullName,
|
|
99
|
-
account_holder_type: "individual",
|
|
100
|
-
account_number: formatAccount,
|
|
101
|
-
country: "US",
|
|
102
|
-
currency: "USD",
|
|
103
|
-
routing_number: formatRouting
|
|
104
|
-
}
|
|
105
|
-
}).then((token) => stripeClient.customers.createSource(
|
|
106
|
-
stripeAccountId,
|
|
107
|
-
{ source: token.id }
|
|
108
|
-
)).then((account) => {
|
|
109
|
-
const cardSource = account;
|
|
110
|
-
const brand = cardSource.brand || "";
|
|
111
|
-
const cvcCheck = cardSource.cvc_check || "";
|
|
112
|
-
const last4 = cardSource.last4 || "";
|
|
113
|
-
const now = Date.now();
|
|
114
|
-
const update = {
|
|
115
|
-
bankAccount,
|
|
116
|
-
bankFullName: formatFullName,
|
|
117
|
-
bankId: account.id,
|
|
118
|
-
bankRouting: formatRouting,
|
|
119
|
-
modified: now
|
|
120
|
-
};
|
|
121
|
-
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
122
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser) => updatedUser);
|
|
123
|
-
}).catch((error) => {
|
|
124
|
-
const msg = error.message;
|
|
125
|
-
if (msg === "A bank account with that routing number and account number already exists for this customer.") {
|
|
126
|
-
return (0, import_analyticsUtils.logError)({
|
|
127
|
-
action,
|
|
128
|
-
category: eventCategory,
|
|
129
|
-
label: "bank_account_exists"
|
|
130
|
-
}, error, context).then(() => null);
|
|
131
|
-
}
|
|
132
|
-
return (0, import_analyticsUtils.logError)({
|
|
133
|
-
action,
|
|
134
|
-
category: eventCategory,
|
|
135
|
-
label: "payment_error"
|
|
136
|
-
}, error, context).then(() => null);
|
|
137
|
-
});
|
|
138
|
-
});
|
|
139
|
-
};
|
|
140
|
-
const addCreditCard = (context, card) => {
|
|
141
|
-
const action = "addCreditCard";
|
|
142
|
-
const { database, session: { userId: sessionId } } = context;
|
|
143
|
-
return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
|
|
144
|
-
const { stripeAccountId } = user;
|
|
145
|
-
const {
|
|
146
|
-
accountNumber,
|
|
147
|
-
city,
|
|
148
|
-
country,
|
|
149
|
-
cvc,
|
|
150
|
-
expMonth,
|
|
151
|
-
expYear,
|
|
152
|
-
fullName,
|
|
153
|
-
street1,
|
|
154
|
-
street2,
|
|
155
|
-
state,
|
|
156
|
-
zip
|
|
157
|
-
} = card;
|
|
158
|
-
const formatNumber = (0, import_utils.parseNum)(accountNumber, 16);
|
|
159
|
-
if (!formatNumber) {
|
|
160
|
-
throw new import_analyticsUtils.UserError("required_credit_card_number");
|
|
161
|
-
}
|
|
162
|
-
const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
|
|
163
|
-
if (!formatExpMonth) {
|
|
164
|
-
throw new import_analyticsUtils.UserError("required_credit_card_exp_month");
|
|
165
|
-
}
|
|
166
|
-
const formatExpYear = (0, import_utils.parseNum)(expYear, 2);
|
|
167
|
-
if (!formatExpYear) {
|
|
168
|
-
throw new import_analyticsUtils.UserError("required_credit_card_exp_year");
|
|
169
|
-
}
|
|
170
|
-
const formatCvc = (0, import_utils.parseNum)(cvc, 3);
|
|
171
|
-
const paymentCard = {};
|
|
172
|
-
const formatCity = (0, import_utils.parseVarChar)(city, 32);
|
|
173
|
-
if (formatCity) {
|
|
174
|
-
paymentCard.city = formatCity;
|
|
175
|
-
}
|
|
176
|
-
const formatCountry = (0, import_utils.parseChar)(country, 2);
|
|
177
|
-
if (formatCountry) {
|
|
178
|
-
paymentCard.country = formatCountry;
|
|
179
|
-
}
|
|
180
|
-
const formatFullName = (0, import_utils.parseVarChar)(fullName, 32);
|
|
181
|
-
if (formatFullName) {
|
|
182
|
-
paymentCard.fullName = formatFullName;
|
|
183
|
-
}
|
|
184
|
-
const formatStreet1 = (0, import_utils.parseVarChar)(street1, 32);
|
|
185
|
-
if (formatStreet1) {
|
|
186
|
-
paymentCard.street1 = formatStreet1;
|
|
187
|
-
}
|
|
188
|
-
const formatStreet2 = (0, import_utils.parseVarChar)(street2, 32);
|
|
189
|
-
if (formatStreet2) {
|
|
190
|
-
paymentCard.street2 = formatStreet2;
|
|
191
|
-
}
|
|
192
|
-
const formatState = (0, import_utils.parseChar)(state, 2);
|
|
193
|
-
if (formatState) {
|
|
194
|
-
paymentCard.state = formatState;
|
|
195
|
-
}
|
|
196
|
-
const formatZip = (0, import_utils.parseVarChar)(zip, 10);
|
|
197
|
-
if (formatZip) {
|
|
198
|
-
paymentCard.zip = formatZip;
|
|
199
|
-
}
|
|
200
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
201
|
-
return stripeClient.tokens.create({
|
|
202
|
-
card: {
|
|
203
|
-
address_city: formatCity,
|
|
204
|
-
address_country: formatCountry,
|
|
205
|
-
address_line1: formatStreet1,
|
|
206
|
-
address_line2: formatStreet2,
|
|
207
|
-
address_state: formatState,
|
|
208
|
-
address_zip: formatZip,
|
|
209
|
-
cvc: formatCvc.toString(),
|
|
210
|
-
exp_month: formatExpMonth.toString(),
|
|
211
|
-
exp_year: formatExpYear.toString(),
|
|
212
|
-
name: fullName,
|
|
213
|
-
number: formatNumber.toString()
|
|
214
|
-
}
|
|
215
|
-
}).then((token) => stripeClient.customers.createSource(
|
|
216
|
-
stripeAccountId,
|
|
217
|
-
{ source: token.id }
|
|
218
|
-
)).then((newSource) => {
|
|
219
|
-
const cardSource = newSource;
|
|
220
|
-
const brand = cardSource.brand || "";
|
|
221
|
-
const cvcCheck = cardSource.cvc_check || "";
|
|
222
|
-
const last4 = cardSource.last4 || "";
|
|
223
|
-
const now = Date.now();
|
|
224
|
-
const insert = {
|
|
225
|
-
...paymentCard,
|
|
226
|
-
_key: (0, import_utils.createHash)(`user-payment-${sessionId}`),
|
|
227
|
-
accountNumber: last4,
|
|
228
|
-
added: now,
|
|
229
|
-
brand,
|
|
230
|
-
cvcCheck,
|
|
231
|
-
expMonth,
|
|
232
|
-
expYear,
|
|
233
|
-
modified: now,
|
|
234
|
-
userId: sessionId
|
|
235
|
-
};
|
|
236
|
-
const insertAqlQry = import_arangojs.aql`INSERT ${insert} IN creditCards RETURN NEW`;
|
|
237
|
-
return database.query(insertAqlQry).then((cursor) => cursor.next()).then((newCard) => {
|
|
238
|
-
if (newCard) {
|
|
239
|
-
const { _id: cardId, _key: cardKey } = card;
|
|
240
|
-
const edgeCollection = database.collection("hasPayment");
|
|
241
|
-
const edgeId = (0, import_utils.createHash)(`payment-${cardKey}`);
|
|
242
|
-
const edge = {
|
|
243
|
-
_from: `users/${sessionId}`,
|
|
244
|
-
_key: edgeId,
|
|
245
|
-
_to: cardId
|
|
246
|
-
};
|
|
247
|
-
return edgeCollection.save(edge, { returnNew: true }).then(() => card);
|
|
248
|
-
}
|
|
249
|
-
return newCard;
|
|
250
|
-
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
251
|
-
action,
|
|
252
|
-
category: eventCategory,
|
|
253
|
-
label: "payment_error"
|
|
254
|
-
}, error, context).then(() => null));
|
|
255
|
-
});
|
|
256
|
-
});
|
|
257
|
-
};
|
|
258
|
-
const updateCreditCard = (context, card) => {
|
|
259
|
-
const { database, session: { userId: sessionId } } = context;
|
|
260
|
-
const {
|
|
261
|
-
city,
|
|
262
|
-
country,
|
|
263
|
-
expMonth,
|
|
264
|
-
expYear,
|
|
265
|
-
fullName,
|
|
266
|
-
id,
|
|
267
|
-
street1,
|
|
268
|
-
state,
|
|
269
|
-
zip
|
|
270
|
-
} = card;
|
|
271
|
-
const formatId = (0, import_utils.parseId)(id);
|
|
272
|
-
if (formatId) {
|
|
273
|
-
throw new import_analyticsUtils.UserError("required_credit_card_id");
|
|
274
|
-
}
|
|
275
|
-
const paymentCard = {};
|
|
276
|
-
const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
|
|
277
|
-
const formatExpYear = (0, import_utils.parseNum)(expYear, 2);
|
|
278
|
-
const formatCity = (0, import_utils.parseVarChar)(city, 32);
|
|
279
|
-
const formatCountry = (0, import_utils.parseChar)(country, 2);
|
|
280
|
-
const formatFullName = (0, import_utils.parseVarChar)(fullName, 32);
|
|
281
|
-
const formatStreet1 = (0, import_utils.parseString)(street1, 32);
|
|
282
|
-
const formatState = (0, import_utils.parseChar)(state, 2);
|
|
283
|
-
const formatZip = (0, import_utils.parseVarChar)(zip, 10);
|
|
284
|
-
if (formatExpMonth) {
|
|
285
|
-
paymentCard.expMonth = formatExpMonth;
|
|
286
|
-
}
|
|
287
|
-
if (formatExpYear) {
|
|
288
|
-
paymentCard.expYear = formatExpYear;
|
|
289
|
-
}
|
|
290
|
-
if (formatCity) {
|
|
291
|
-
paymentCard.city = formatCity;
|
|
292
|
-
}
|
|
293
|
-
if (formatCountry) {
|
|
294
|
-
paymentCard.country = formatCountry;
|
|
295
|
-
}
|
|
296
|
-
if (formatFullName) {
|
|
297
|
-
paymentCard.fullName = formatFullName;
|
|
298
|
-
}
|
|
299
|
-
if (formatStreet1) {
|
|
300
|
-
paymentCard.street1 = formatStreet1;
|
|
301
|
-
}
|
|
302
|
-
if (formatState) {
|
|
303
|
-
paymentCard.state = formatState;
|
|
304
|
-
}
|
|
305
|
-
if (formatZip) {
|
|
306
|
-
paymentCard.zip = formatZip;
|
|
307
|
-
}
|
|
308
|
-
const update = paymentCard;
|
|
309
|
-
const aqlQry = import_arangojs.aql`
|
|
310
|
-
LET updatedCard = FIRST(
|
|
311
|
-
FOR c IN creditCards
|
|
312
|
-
FILTER c._key == ${formatId} && c.userId == ${sessionId}
|
|
313
|
-
UPDATE c WITH ${update} IN creditCards
|
|
314
|
-
LIMIT 1
|
|
315
|
-
RETURN NEW
|
|
316
|
-
)
|
|
317
|
-
LET user = FIRST(
|
|
318
|
-
FOR u IN users
|
|
319
|
-
FILTER u._key == ${sessionId}
|
|
320
|
-
LIMIT 1
|
|
321
|
-
RETURN u
|
|
322
|
-
)
|
|
323
|
-
RETURN {user: user, card: updatedCard}`;
|
|
324
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((results = { card: {}, user: {} }) => {
|
|
325
|
-
const updatedCard = results.card;
|
|
326
|
-
const { user } = results;
|
|
327
|
-
if (!updatedCard) {
|
|
328
|
-
throw new import_analyticsUtils.UserError("not_found");
|
|
329
|
-
}
|
|
330
|
-
const { stripeCustomerId } = user;
|
|
331
|
-
const { stripeId } = card;
|
|
332
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
333
|
-
const update2 = {
|
|
334
|
-
address_city: formatCity,
|
|
335
|
-
address_country: formatCountry,
|
|
336
|
-
address_line1: formatStreet1,
|
|
337
|
-
address_state: formatState,
|
|
338
|
-
address_zip: formatZip,
|
|
339
|
-
exp_month: formatExpMonth.toString(),
|
|
340
|
-
exp_year: formatExpYear.toString(),
|
|
341
|
-
name: formatFullName
|
|
342
|
-
};
|
|
343
|
-
return stripeClient.customers.updateSource(stripeCustomerId, stripeId, update2).then(() => card).catch((error) => {
|
|
344
|
-
console.log("payments::updateCard::error", error);
|
|
345
|
-
throw new import_analyticsUtils.UserError("payment_error");
|
|
346
|
-
});
|
|
347
|
-
});
|
|
348
|
-
};
|
|
349
|
-
const getCreditCards = (context) => {
|
|
350
|
-
const action = "getCreditCards";
|
|
351
|
-
const { database, session: { userId: sessionId } } = context;
|
|
352
|
-
const aqlQry = import_arangojs.aql`FOR c IN creditCards
|
|
353
|
-
FILTER c.userId == ${sessionId}
|
|
354
|
-
RETURN c`;
|
|
355
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analyticsUtils.logError)({
|
|
356
|
-
action,
|
|
357
|
-
category: eventCategory,
|
|
358
|
-
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
359
|
-
}, error, context).then(() => null));
|
|
360
|
-
};
|
|
361
|
-
const deleteCreditCard = (context, cardId) => {
|
|
362
|
-
const { database, session: { userId: sessionId } } = context;
|
|
363
|
-
const formatCardId = (0, import_utils.parseId)(cardId);
|
|
364
|
-
const aqlQry = import_arangojs.aql`
|
|
365
|
-
LET card = FIRST(
|
|
366
|
-
FOR c IN creditCards
|
|
367
|
-
FILTER c._key == ${formatCardId} && c.userId == ${sessionId}
|
|
368
|
-
LIMIT 1
|
|
369
|
-
REMOVE c IN creditCards
|
|
370
|
-
RETURN OLD
|
|
371
|
-
)
|
|
372
|
-
LET user = FIRST(
|
|
373
|
-
FOR u IN users
|
|
374
|
-
FILTER u._key == ${sessionId}
|
|
375
|
-
LIMIT 1
|
|
376
|
-
RETURN u
|
|
377
|
-
)
|
|
378
|
-
RETURN {user: user, card: card}`;
|
|
379
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((result = { card: {}, user: {} }) => {
|
|
380
|
-
if (!result) {
|
|
381
|
-
return false;
|
|
382
|
-
}
|
|
383
|
-
const { card, user } = result;
|
|
384
|
-
const { _key: cardKey } = card;
|
|
385
|
-
const edgeCollection = database.collection("hasPayment");
|
|
386
|
-
return edgeCollection.outEdges(cardKey, {}).then(async (response) => {
|
|
387
|
-
const edges = Array.isArray(response) ? response : [];
|
|
388
|
-
if (edges.length) {
|
|
389
|
-
await Promise.all(
|
|
390
|
-
edges.map((edge) => {
|
|
391
|
-
const { _key: edgeKey } = edge;
|
|
392
|
-
const removeAqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN hasPayment`;
|
|
393
|
-
return database.query(removeAqlQry);
|
|
394
|
-
})
|
|
395
|
-
).then(() => {
|
|
396
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
397
|
-
return stripeClient.customers.deleteSource(user.stripeCustomerId, card.stripeId).then(() => true).catch((error) => {
|
|
398
|
-
console.log("payments::deleteCard::error", error);
|
|
399
|
-
throw new import_analyticsUtils.UserError("payment_error");
|
|
400
|
-
});
|
|
401
|
-
});
|
|
402
|
-
return true;
|
|
403
|
-
}
|
|
404
|
-
return false;
|
|
405
|
-
});
|
|
406
|
-
});
|
|
407
|
-
};
|
|
408
|
-
const deleteBankAccount = (context, bankId) => {
|
|
409
|
-
const { database, session: { userId: sessionId } } = context;
|
|
410
|
-
const update = {
|
|
411
|
-
bankAccount: "",
|
|
412
|
-
bankFullName: "",
|
|
413
|
-
bankId: "",
|
|
414
|
-
bankRouting: "",
|
|
415
|
-
modified: Date.now()
|
|
416
|
-
};
|
|
417
|
-
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
418
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((user) => {
|
|
419
|
-
const { stripeAccountId } = user;
|
|
420
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
421
|
-
return stripeClient.customers.deleteSource(stripeAccountId, bankId).then(() => true).catch(() => Promise.resolve(false));
|
|
422
|
-
});
|
|
423
|
-
};
|
|
424
|
-
const createPaymentTransfer = (context, transfer) => {
|
|
425
|
-
const { database, session: { userId: sessionId } } = context;
|
|
426
|
-
const { amount, currency } = transfer;
|
|
427
|
-
const formatAmount = (0, import_utils.parseNum)(amount);
|
|
428
|
-
const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
|
|
429
|
-
return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
|
|
430
|
-
const { stripeAccountId } = user;
|
|
431
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
432
|
-
return stripeClient.transfers.create({
|
|
433
|
-
amount: formatAmount,
|
|
434
|
-
currency: formatCurrency,
|
|
435
|
-
destination: stripeAccountId
|
|
436
|
-
}).then((stripeTransfer) => {
|
|
437
|
-
console.log(stripeTransfer);
|
|
438
|
-
const now = Date.now();
|
|
439
|
-
const insert = {
|
|
440
|
-
added: now,
|
|
441
|
-
amount: formatAmount,
|
|
442
|
-
currency: formatCurrency,
|
|
443
|
-
modified: now,
|
|
444
|
-
userId: sessionId
|
|
445
|
-
};
|
|
446
|
-
const aqlQry = import_arangojs.aql`INSERT ${insert} IN transfers RETURN NEW`;
|
|
447
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((newTransfer) => newTransfer);
|
|
448
|
-
});
|
|
449
|
-
});
|
|
450
|
-
};
|
|
451
|
-
const createPaymentHold = (context, payment) => {
|
|
452
|
-
const { database, session: { userId: sessionId } } = context;
|
|
453
|
-
const { amount, capture, cardId, currency, description } = payment;
|
|
454
|
-
const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
|
|
455
|
-
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
456
|
-
return stripeClient.charges.create({
|
|
457
|
-
amount,
|
|
458
|
-
capture,
|
|
459
|
-
currency: formatCurrency,
|
|
460
|
-
description,
|
|
461
|
-
source: cardId
|
|
462
|
-
}).then((stripeCharge) => {
|
|
463
|
-
const now = Date.now();
|
|
464
|
-
const insert = {
|
|
465
|
-
added: now,
|
|
466
|
-
amount,
|
|
467
|
-
capture,
|
|
468
|
-
cardId,
|
|
469
|
-
chargeFailCode: stripeCharge.failure_code,
|
|
470
|
-
chargeFailMsg: stripeCharge.failure_message,
|
|
471
|
-
chargeId: stripeCharge.id,
|
|
472
|
-
chargeStatus: stripeCharge.status,
|
|
473
|
-
currency: formatCurrency,
|
|
474
|
-
description,
|
|
475
|
-
modified: now,
|
|
476
|
-
userId: sessionId
|
|
477
|
-
};
|
|
478
|
-
const aqlQry = import_arangojs.aql`INSERT ${insert} IN payments RETURN NEW`;
|
|
479
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((newPayment) => newPayment);
|
|
480
|
-
}).catch((error) => {
|
|
481
|
-
console.log("payments::createHold::error", error);
|
|
482
|
-
throw new import_analyticsUtils.UserError("payment_error");
|
|
483
|
-
});
|
|
484
|
-
};
|
|
485
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
486
|
-
0 && (module.exports = {
|
|
487
|
-
addBankAccount,
|
|
488
|
-
addCreditCard,
|
|
489
|
-
addCustomerAccount,
|
|
490
|
-
createPaymentHold,
|
|
491
|
-
createPaymentTransfer,
|
|
492
|
-
deleteBankAccount,
|
|
493
|
-
deleteCreditCard,
|
|
494
|
-
getCreditCards,
|
|
495
|
-
updateCreditCard
|
|
496
|
-
});
|
|
497
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvcGF5bWVudHMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2NyZWF0ZUhhc2gsIHBhcnNlQ2hhciwgcGFyc2VJZCwgcGFyc2VOdW0sIHBhcnNlU3RyaW5nLCBwYXJzZVZhckNoYXJ9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCBTdHJpcGUgZnJvbSAnc3RyaXBlJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge0FwaUNvbnRleHQsIFBheW1lbnRCYW5rQWNjb3VudCwgUGF5bWVudENhcmRUeXBlLCBQYXltZW50Q2hhcmdlLCBQYXltZW50VHJhbnNmZXIsIFVzZXJUeXBlLCB0eXBlIEVkZ2VUeXBlfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge2dldFVzZXJ9IGZyb20gJy4vdXNlcnMnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5pbXBvcnQge2xvZ0Vycm9yLCBVc2VyRXJyb3J9IGZyb20gJy4uL3V0aWxzL2FuYWx5dGljc1V0aWxzJztcblxuaW1wb3J0IHR5cGUge0VkZ2VDb2xsZWN0aW9ufSBmcm9tICdhcmFuZ29qcy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnkgPSAncGF5bWVudHMnO1xuY29uc3QgYXBpVmVyc2lvbiA9ICcyMDI1LTAyLTI0LmFjYWNpYSc7XG5cbmV4cG9ydCBjb25zdCBhZGRDdXN0b21lckFjY291bnQgPSAoY29udGV4dDogQXBpQ29udGV4dCk6IFByb21pc2U8Ym9vbGVhbj4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnYWRkQ3VzdG9tZXJBY2NvdW50JztcbiAgY29uc3Qge2RhdGFiYXNlLCBzZXNzaW9uOiB7dXNlcklkOiBzZXNzaW9uSWQsIHVzZXJuYW1lfX0gPSBjb250ZXh0O1xuXG4gIC8vIFN0cmlwZVxuICBjb25zdCBzdHJpcGVDbGllbnQgPSBuZXcgU3RyaXBlKENvbmZpZy5nZXQoJ3N0cmlwZS50b2tlbicpLCB7YXBpVmVyc2lvbiwgdHlwZXNjcmlwdDogdHJ1ZX0pO1xuXG4gIHJldHVybiBzdHJpcGVDbGllbnQuY3VzdG9tZXJzXG4gICAgLmNyZWF0ZSh7XG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICB1c2VySWQ6IHNlc3Npb25JZCxcbiAgICAgICAgdXNlcm5hbWVcbiAgICAgIH1cbiAgICB9KVxuICAgIC50aGVuKChjdXN0b21lcikgPT4ge1xuICAgICAgLy8gQ3JlYXRlIHNlc3Npb25cbiAgICAgIGNvbnN0IG5vdzogbnVtYmVyID0gRGF0ZS5ub3coKTtcbiAgICAgIGNvbnN0IHVwZGF0ZTogVXNlclR5cGUgPSB7XG4gICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgIHN0cmlwZUN1c3RvbWVySWQ6IGN1c3RvbWVyLmlkXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQREFURSAke3Nlc3Npb25JZH0gV0lUSCAke3VwZGF0ZX0gSU4gdXNlcnMgTElNSVQgMSBSRVRVUk4gTkVXYDtcblxuICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAgICAgLnRoZW4oKGN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAgICAgLnRoZW4oKHVwZGF0ZWRVc2VyOiBVc2VyVHlwZSkgPT4gISF1cGRhdGVkVXNlcilcbiAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICAgICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gbnVsbCkpO1xuICAgIH0pO1xufTtcblxuaW50ZXJmYWNlIEJhbmtBY2NvdW50IHtcbiAgaWQ6IHN0cmluZztcbiAgbGFzdDQ/OiBzdHJpbmc7XG4gIHJvdXRpbmdfbnVtYmVyPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgQ2FyZCB7XG4gIGlkOiBzdHJpbmc7XG4gIGJyYW5kPzogc3RyaW5nO1xuICBjdmNfY2hlY2s/OiBzdHJpbmc7XG4gIGxhc3Q0Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgYWRkQmFua0FjY291bnQgPSAoY29udGV4dDogQXBpQ29udGV4dCwgYmFua0FjY291bnQ6IFBheW1lbnRCYW5rQWNjb3VudCk6IFByb21pc2U8Ym9vbGVhbj4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnYWRkUGF5bWVudEFjY291bnRCYW5rJztcbiAgY29uc3Qge2RhdGFiYXNlLCBzZXNzaW9uOiB7dXNlcklkOiBzZXNzaW9uSWR9fSA9IGNvbnRleHQ7XG5cbiAgLy8gUGFyYW1zXG4gIGNvbnN0IHtcbiAgICBhY2NvdW50TnVtYmVyLFxuICAgIGZ1bGxOYW1lLFxuICAgIHJvdXRpbmdcbiAgfSA9IGJhbmtBY2NvdW50O1xuXG4gIGNvbnN0IGZvcm1hdEFjY291bnQ6IHN0cmluZyA9IHBhcnNlU3RyaW5nKGFjY291bnROdW1iZXIsIDMyKTtcblxuICBpZihmb3JtYXRBY2NvdW50ID09PSAnJykge1xuICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ3JlcXVpcmVkX2FjY291bnRfbnVtYmVyJyk7XG4gIH1cblxuICBjb25zdCBmb3JtYXRGdWxsTmFtZTogc3RyaW5nID0gcGFyc2VWYXJDaGFyKGZ1bGxOYW1lLCAxMjgpO1xuXG4gIGlmKGZvcm1hdEZ1bGxOYW1lID09PSAnJykge1xuICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ3JlcXVpcmVkX2Z1bGxfbmFtZScpO1xuICB9XG5cbiAgY29uc3QgZm9ybWF0Um91dGluZzogc3RyaW5nID0gcGFyc2VTdHJpbmcocm91dGluZywgMzIpO1xuXG4gIGlmKGZvcm1hdFJvdXRpbmcgPT09ICcnKSB7XG4gICAgdGhyb3cgbmV3IFVzZXJFcnJvcigncmVxdWlyZWRfcm91dGluZ19udW1iZXInKTtcbiAgfVxuXG4gIHJldHVybiBnZXRVc2VyKGNvbnRleHQsIHt1c2VySWQ6IHNlc3Npb25JZH0pXG4gICAgLnRoZW4oKHVzZXI6IFVzZXJUeXBlKSA9PiB7XG4gICAgICBjb25zdCB7c3RyaXBlQWNjb3VudElkfSA9IHVzZXI7XG5cbiAgICAgIC8vIFN0cmlwZVxuICAgICAgY29uc3Qgc3RyaXBlQ2xpZW50ID0gbmV3IFN0cmlwZShDb25maWcuZ2V0KCdzdHJpcGUudG9rZW4nKSwge2FwaVZlcnNpb24sIHR5cGVzY3JpcHQ6IHRydWV9KTtcblxuICAgICAgLy8gQ3JlYXRlIGEgdG9rZW4gZmlyc3QsIHRoZW4gdXNlIHRoZSB0b2tlbiBhcyB0aGUgc291cmNlXG4gICAgICByZXR1cm4gc3RyaXBlQ2xpZW50LnRva2Vucy5jcmVhdGUoe1xuICAgICAgICBiYW5rX2FjY291bnQ6IHtcbiAgICAgICAgICBhY2NvdW50X2hvbGRlcl9uYW1lOiBmb3JtYXRGdWxsTmFtZSxcbiAgICAgICAgICBhY2NvdW50X2hvbGRlcl90eXBlOiAnaW5kaXZpZHVhbCcsXG4gICAgICAgICAgYWNjb3VudF9udW1iZXI6IGZvcm1hdEFjY291bnQsXG4gICAgICAgICAgY291bnRyeTogJ1VTJyxcbiAgICAgICAgICBjdXJyZW5jeTogJ1VTRCcsXG4gICAgICAgICAgcm91dGluZ19udW1iZXI6IGZvcm1hdFJvdXRpbmdcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICAgICAgLnRoZW4oKHRva2VuKSA9PiBzdHJpcGVDbGllbnQuY3VzdG9tZXJzLmNyZWF0ZVNvdXJjZShcbiAgICAgICAgICBzdHJpcGVBY2NvdW50SWQsXG4gICAgICAgICAge3NvdXJjZTogdG9rZW4uaWR9XG4gICAgICAgICkpXG4gICAgICAgIC50aGVuKChhY2NvdW50KSA9PiB7XG4gICAgICAgICAgLy8gVXNlIHR5cGUgYXNzZXJ0aW9uIGZvciBjYXJkIHByb3BlcnRpZXNcbiAgICAgICAgICBjb25zdCBjYXJkU291cmNlID0gYWNjb3VudCBhcyB1bmtub3duIGFzIENhcmQ7XG4gICAgICAgICAgY29uc3QgYnJhbmQgPSBjYXJkU291cmNlLmJyYW5kIHx8ICcnO1xuICAgICAgICAgIGNvbnN0IGN2Y0NoZWNrID0gY2FyZFNvdXJjZS5jdmNfY2hlY2sgfHwgJyc7XG4gICAgICAgICAgY29uc3QgbGFzdDQgPSBjYXJkU291cmNlLmxhc3Q0IHx8ICcnO1xuXG4gICAgICAgICAgLy8gQ3JlYXRlIHNlc3Npb25cbiAgICAgICAgICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gICAgICAgICAgY29uc3QgdXBkYXRlID0ge1xuICAgICAgICAgICAgYmFua0FjY291bnQsXG4gICAgICAgICAgICBiYW5rRnVsbE5hbWU6IGZvcm1hdEZ1bGxOYW1lLFxuICAgICAgICAgICAgYmFua0lkOiBhY2NvdW50LmlkLFxuICAgICAgICAgICAgYmFua1JvdXRpbmc6IGZvcm1hdFJvdXRpbmcsXG4gICAgICAgICAgICBtb2RpZmllZDogbm93XG4gICAgICAgICAgfTtcblxuICAgICAgICAgIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgVVBEQVRFICR7c2Vzc2lvbklkfSBXSVRIICR7dXBkYXRlfSBJTiB1c2VycyBMSU1JVCAxIFJFVFVSTiBORVdgO1xuXG4gICAgICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAgICAgICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgICAgICAgICAudGhlbigodXBkYXRlZFVzZXI6IFVzZXJUeXBlKSA9PiB1cGRhdGVkVXNlcik7XG4gICAgICAgIH0pXG4gICAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgY29uc3QgbXNnID0gZXJyb3IubWVzc2FnZTtcblxuICAgICAgICAgIGlmKG1zZyA9PT0gJ0EgYmFuayBhY2NvdW50IHdpdGggdGhhdCByb3V0aW5nIG51bWJlciBhbmQgYWNjb3VudCBudW1iZXIgJyArXG4gICAgICAgICAgJ2FscmVhZHkgZXhpc3RzIGZvciB0aGlzIGN1c3RvbWVyLicpIHtcbiAgICAgICAgICAgIHJldHVybiBsb2dFcnJvcih7XG4gICAgICAgICAgICAgIGFjdGlvbixcbiAgICAgICAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgICAgICAgIGxhYmVsOiAnYmFua19hY2NvdW50X2V4aXN0cydcbiAgICAgICAgICAgIH0sIGVycm9yLCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gbG9nRXJyb3Ioe1xuICAgICAgICAgICAgYWN0aW9uLFxuICAgICAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgICAgICBsYWJlbDogJ3BheW1lbnRfZXJyb3InXG4gICAgICAgICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gbnVsbCk7XG4gICAgICAgIH0pO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZENyZWRpdENhcmQgPSAoY29udGV4dDogQXBpQ29udGV4dCwgY2FyZDogUGF5bWVudENhcmRUeXBlKTogUHJvbWlzZTxVc2VyVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnYWRkQ3JlZGl0Q2FyZCc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuXG4gIHJldHVybiBnZXRVc2VyKGNvbnRleHQsIHt1c2VySWQ6IHNlc3Npb25JZH0pXG4gICAgLnRoZW4oKHVzZXI6IFVzZXJUeXBlKSA9PiB7XG4gICAgICAvLyBVc2VyXG4gICAgICBjb25zdCB7c3RyaXBlQWNjb3VudElkfSA9IHVzZXI7XG5cbiAgICAgIC8vIENhcmRcbiAgICAgIGNvbnN0IHtcbiAgICAgICAgYWNjb3VudE51bWJlcixcbiAgICAgICAgY2l0eSxcbiAgICAgICAgY291bnRyeSxcbiAgICAgICAgY3ZjLFxuICAgICAgICBleHBNb250aCxcbiAgICAgICAgZXhwWWVhcixcbiAgICAgICAgZnVsbE5hbWUsXG4gICAgICAgIHN0cmVldDEsXG4gICAgICAgIHN0cmVldDIsXG4gICAgICAgIHN0YXRlLFxuICAgICAgICB6aXBcbiAgICAgIH06IFBheW1lbnRDYXJkVHlwZSA9IGNhcmQ7XG5cbiAgICAgIGNvbnN0IGZvcm1hdE51bWJlcjogbnVtYmVyID0gcGFyc2VOdW0oYWNjb3VudE51bWJlciwgMTYpO1xuXG4gICAgICBpZighZm9ybWF0TnVtYmVyKSB7XG4gICAgICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ3JlcXVpcmVkX2NyZWRpdF9jYXJkX251bWJlcicpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBmb3JtYXRFeHBNb250aDogbnVtYmVyID0gcGFyc2VOdW0oZXhwTW9udGgsIDIpO1xuXG4gICAgICBpZighZm9ybWF0RXhwTW9udGgpIHtcbiAgICAgICAgdGhyb3cgbmV3IFVzZXJFcnJvcigncmVxdWlyZWRfY3JlZGl0X2NhcmRfZXhwX21vbnRoJyk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGZvcm1hdEV4cFllYXI6IG51bWJlciA9IHBhcnNlTnVtKGV4cFllYXIsIDIpO1xuXG4gICAgICBpZighZm9ybWF0RXhwWWVhcikge1xuICAgICAgICB0aHJvdyBuZXcgVXNlckVycm9yKCdyZXF1aXJlZF9jcmVkaXRfY2FyZF9leHBfeWVhcicpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBmb3JtYXRDdmM6IG51bWJlciA9IHBhcnNlTnVtKGN2YywgMyk7XG5cbiAgICAgIC8vIEFkZHJlc3NcbiAgICAgIGNvbnN0IHBheW1lbnRDYXJkOiBQYXltZW50Q2FyZFR5cGUgPSB7fTtcbiAgICAgIGNvbnN0IGZvcm1hdENpdHk6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcihjaXR5LCAzMik7XG5cbiAgICAgIGlmKGZvcm1hdENpdHkpIHtcbiAgICAgICAgcGF5bWVudENhcmQuY2l0eSA9IGZvcm1hdENpdHk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGZvcm1hdENvdW50cnk6IHN0cmluZyA9IHBhcnNlQ2hhcihjb3VudHJ5LCAyKTtcblxuICAgICAgaWYoZm9ybWF0Q291bnRyeSkge1xuICAgICAgICBwYXltZW50Q2FyZC5jb3VudHJ5ID0gZm9ybWF0Q291bnRyeTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgZm9ybWF0RnVsbE5hbWU6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcihmdWxsTmFtZSwgMzIpO1xuXG4gICAgICBpZihmb3JtYXRGdWxsTmFtZSkge1xuICAgICAgICBwYXltZW50Q2FyZC5mdWxsTmFtZSA9IGZvcm1hdEZ1bGxOYW1lO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBmb3JtYXRTdHJlZXQxOiBzdHJpbmcgPSBwYXJzZVZhckNoYXIoc3RyZWV0MSwgMzIpO1xuXG4gICAgICBpZihmb3JtYXRTdHJlZXQxKSB7XG4gICAgICAgIHBheW1lbnRDYXJkLnN0cmVldDEgPSBmb3JtYXRTdHJlZXQxO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBmb3JtYXRTdHJlZXQyOiBzdHJpbmcgPSBwYXJzZVZhckNoYXIoc3RyZWV0MiwgMzIpO1xuXG4gICAgICBpZihmb3JtYXRTdHJlZXQyKSB7XG4gICAgICAgIHBheW1lbnRDYXJkLnN0cmVldDIgPSBmb3JtYXRTdHJlZXQyO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBmb3JtYXRTdGF0ZTogc3RyaW5nID0gcGFyc2VDaGFyKHN0YXRlLCAyKTtcblxuICAgICAgaWYoZm9ybWF0U3RhdGUpIHtcbiAgICAgICAgcGF5bWVudENhcmQuc3RhdGUgPSBmb3JtYXRTdGF0ZTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgZm9ybWF0WmlwOiBzdHJpbmcgPSBwYXJzZVZhckNoYXIoemlwLCAxMCk7XG5cbiAgICAgIGlmKGZvcm1hdFppcCkge1xuICAgICAgICBwYXltZW50Q2FyZC56aXAgPSBmb3JtYXRaaXA7XG4gICAgICB9XG5cbiAgICAgIC8vIFN0cmlwZVxuICAgICAgY29uc3Qgc3RyaXBlQ2xpZW50ID0gbmV3IFN0cmlwZShDb25maWcuZ2V0KCdzdHJpcGUudG9rZW4nKSwge2FwaVZlcnNpb24sIHR5cGVzY3JpcHQ6IHRydWV9KTtcblxuICAgICAgLy8gQ3JlYXRlIGEgdG9rZW4gZmlyc3QsIHRoZW4gdXNlIHRoZSB0b2tlbiBhcyB0aGUgc291cmNlXG4gICAgICByZXR1cm4gc3RyaXBlQ2xpZW50LnRva2Vucy5jcmVhdGUoe1xuICAgICAgICBjYXJkOiB7XG4gICAgICAgICAgYWRkcmVzc19jaXR5OiBmb3JtYXRDaXR5LFxuICAgICAgICAgIGFkZHJlc3NfY291bnRyeTogZm9ybWF0Q291bnRyeSxcbiAgICAgICAgICBhZGRyZXNzX2xpbmUxOiBmb3JtYXRTdHJlZXQxLFxuICAgICAgICAgIGFkZHJlc3NfbGluZTI6IGZvcm1hdFN0cmVldDIsXG4gICAgICAgICAgYWRkcmVzc19zdGF0ZTogZm9ybWF0U3RhdGUsXG4gICAgICAgICAgYWRkcmVzc196aXA6IGZvcm1hdFppcCxcbiAgICAgICAgICBjdmM6IGZvcm1hdEN2Yy50b1N0cmluZygpLFxuICAgICAgICAgIGV4cF9tb250aDogZm9ybWF0RXhwTW9udGgudG9TdHJpbmcoKSxcbiAgICAgICAgICBleHBfeWVhcjogZm9ybWF0RXhwWWVhci50b1N0cmluZygpLFxuICAgICAgICAgIG5hbWU6IGZ1bGxOYW1lLFxuICAgICAgICAgIG51bWJlcjogZm9ybWF0TnVtYmVyLnRvU3RyaW5nKClcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICAgICAgLnRoZW4oKHRva2VuKSA9PiBzdHJpcGVDbGllbnQuY3VzdG9tZXJzLmNyZWF0ZVNvdXJjZShcbiAgICAgICAgICBzdHJpcGVBY2NvdW50SWQsXG4gICAgICAgICAge3NvdXJjZTogdG9rZW4uaWR9XG4gICAgICAgICkpXG4gICAgICAgIC50aGVuKChuZXdTb3VyY2UpID0+IHtcbiAgICAgICAgLy8gVXNlIHR5cGUgYXNzZXJ0aW9uIGZvciBjYXJkIHByb3BlcnRpZXNcbiAgICAgICAgICBjb25zdCBjYXJkU291cmNlID0gbmV3U291cmNlIGFzIHVua25vd24gYXMgQ2FyZDtcbiAgICAgICAgICBjb25zdCBicmFuZCA9IGNhcmRTb3VyY2UuYnJhbmQgfHwgJyc7XG4gICAgICAgICAgY29uc3QgY3ZjQ2hlY2sgPSBjYXJkU291cmNlLmN2Y19jaGVjayB8fCAnJztcbiAgICAgICAgICBjb25zdCBsYXN0NCA9IGNhcmRTb3VyY2UubGFzdDQgfHwgJyc7XG5cbiAgICAgICAgICAvLyBDcmVhdGUgc2Vzc2lvblxuICAgICAgICAgIGNvbnN0IG5vdzogbnVtYmVyID0gRGF0ZS5ub3coKTtcbiAgICAgICAgICBjb25zdCBpbnNlcnQgPSB7XG4gICAgICAgICAgICAuLi5wYXltZW50Q2FyZCxcbiAgICAgICAgICAgIF9rZXk6IGNyZWF0ZUhhc2goYHVzZXItcGF5bWVudC0ke3Nlc3Npb25JZH1gKSxcbiAgICAgICAgICAgIGFjY291bnROdW1iZXI6IGxhc3Q0LFxuICAgICAgICAgICAgYWRkZWQ6IG5vdyxcbiAgICAgICAgICAgIGJyYW5kLFxuICAgICAgICAgICAgY3ZjQ2hlY2ssXG4gICAgICAgICAgICBleHBNb250aCxcbiAgICAgICAgICAgIGV4cFllYXIsXG4gICAgICAgICAgICBtb2RpZmllZDogbm93LFxuICAgICAgICAgICAgdXNlcklkOiBzZXNzaW9uSWRcbiAgICAgICAgICB9O1xuICAgICAgICAgIGNvbnN0IGluc2VydEFxbFFyeTogQXFsUXVlcnkgPSBhcWxgSU5TRVJUICR7aW5zZXJ0fSBJTiBjcmVkaXRDYXJkcyBSRVRVUk4gTkVXYDtcblxuICAgICAgICAgIHJldHVybiBkYXRhYmFzZS5xdWVyeShpbnNlcnRBcWxRcnkpXG4gICAgICAgICAgICAudGhlbigoY3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgICAgICAgICAgLnRoZW4oKG5ld0NhcmQ6IFBheW1lbnRDYXJkVHlwZSkgPT4ge1xuICAgICAgICAgICAgICBpZihuZXdDYXJkKSB7XG4gICAgICAgICAgICAgIC8vIEFkZCBsaW5rZWQgZWRnZVxuICAgICAgICAgICAgICAgIGNvbnN0IHtfaWQ6IGNhcmRJZCwgX2tleTogY2FyZEtleX0gPSBjYXJkO1xuICAgICAgICAgICAgICAgIGNvbnN0IGVkZ2VDb2xsZWN0aW9uOiBFZGdlQ29sbGVjdGlvbiA9IGRhdGFiYXNlLmNvbGxlY3Rpb24oJ2hhc1BheW1lbnQnKTtcbiAgICAgICAgICAgICAgICBjb25zdCBlZGdlSWQgPSBjcmVhdGVIYXNoKGBwYXltZW50LSR7Y2FyZEtleX1gKTtcbiAgICAgICAgICAgICAgICBjb25zdCBlZGdlID0ge1xuICAgICAgICAgICAgICAgICAgX2Zyb206IGB1c2Vycy8ke3Nlc3Npb25JZH1gLFxuICAgICAgICAgICAgICAgICAgX2tleTogZWRnZUlkLFxuICAgICAgICAgICAgICAgICAgX3RvOiBjYXJkSWRcbiAgICAgICAgICAgICAgICB9O1xuXG4gICAgICAgICAgICAgICAgcmV0dXJuIGVkZ2VDb2xsZWN0aW9uLnNhdmUoZWRnZSwge3JldHVybk5ldzogdHJ1ZX0pLnRoZW4oKCkgPT4gY2FyZCk7XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICByZXR1cm4gbmV3Q2FyZDtcbiAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgICAgICAgICBsYWJlbDogJ3BheW1lbnRfZXJyb3InXG4gICAgICAgICAgICB9LCBlcnJvciwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG4gICAgICAgIH0pO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZUNyZWRpdENhcmQgPSAoY29udGV4dDogQXBpQ29udGV4dCwgY2FyZDogUGF5bWVudENhcmRUeXBlKTogUHJvbWlzZTxQYXltZW50Q2FyZFR5cGU+ID0+IHtcbiAgY29uc3Qge2RhdGFiYXNlLCBzZXNzaW9uOiB7dXNlcklkOiBzZXNzaW9uSWR9fSA9IGNvbnRleHQ7XG5cbiAgY29uc3Qge1xuICAgIGNpdHksXG4gICAgY291bnRyeSxcbiAgICBleHBNb250aCxcbiAgICBleHBZZWFyLFxuICAgIGZ1bGxOYW1lLFxuICAgIGlkLFxuICAgIHN0cmVldDEsXG4gICAgc3RhdGUsXG4gICAgemlwXG4gIH06IFBheW1lbnRDYXJkVHlwZSA9IGNhcmQ7XG5cbiAgY29uc3QgZm9ybWF0SWQ6IHN0cmluZyA9IHBhcnNlSWQoaWQpO1xuXG4gIGlmKGZvcm1hdElkKSB7XG4gICAgdGhyb3cgbmV3IFVzZXJFcnJvcigncmVxdWlyZWRfY3JlZGl0X2NhcmRfaWQnKTtcbiAgfVxuXG4gIGNvbnN0IHBheW1lbnRDYXJkOiBQYXltZW50Q2FyZFR5cGUgPSB7fTtcbiAgY29uc3QgZm9ybWF0RXhwTW9udGg6IG51bWJlciA9IHBhcnNlTnVtKGV4cE1vbnRoLCAyKTtcbiAgY29uc3QgZm9ybWF0RXhwWWVhcjogbnVtYmVyID0gcGFyc2VOdW0oZXhwWWVhciwgMik7XG4gIGNvbnN0IGZvcm1hdENpdHk6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcihjaXR5LCAzMik7XG4gIGNvbnN0IGZvcm1hdENvdW50cnk6IHN0cmluZyA9IHBhcnNlQ2hhcihjb3VudHJ5LCAyKTtcbiAgY29uc3QgZm9ybWF0RnVsbE5hbWU6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcihmdWxsTmFtZSwgMzIpO1xuICBjb25zdCBmb3JtYXRTdHJlZXQxOiBzdHJpbmcgPSBwYXJzZVN0cmluZyhzdHJlZXQxLCAzMik7XG4gIGNvbnN0IGZvcm1hdFN0YXRlOiBzdHJpbmcgPSBwYXJzZUNoYXIoc3RhdGUsIDIpO1xuICBjb25zdCBmb3JtYXRaaXA6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcih6aXAsIDEwKTtcblxuICBpZihmb3JtYXRFeHBNb250aCkge1xuICAgIHBheW1lbnRDYXJkLmV4cE1vbnRoID0gZm9ybWF0RXhwTW9udGg7XG4gIH1cblxuICBpZihmb3JtYXRFeHBZZWFyKSB7XG4gICAgcGF5bWVudENhcmQuZXhwWWVhciA9IGZvcm1hdEV4cFllYXI7XG4gIH1cblxuICBpZihmb3JtYXRDaXR5KSB7XG4gICAgcGF5bWVudENhcmQuY2l0eSA9IGZvcm1hdENpdHk7XG4gIH1cblxuICBpZihmb3JtYXRDb3VudHJ5KSB7XG4gICAgcGF5bWVudENhcmQuY291bnRyeSA9IGZvcm1hdENvdW50cnk7XG4gIH1cblxuICBpZihmb3JtYXRGdWxsTmFtZSkge1xuICAgIHBheW1lbnRDYXJkLmZ1bGxOYW1lID0gZm9ybWF0RnVsbE5hbWU7XG4gIH1cblxuICBpZihmb3JtYXRTdHJlZXQxKSB7XG4gICAgcGF5bWVudENhcmQuc3RyZWV0MSA9IGZvcm1hdFN0cmVldDE7XG4gIH1cblxuICBpZihmb3JtYXRTdGF0ZSkge1xuICAgIHBheW1lbnRDYXJkLnN0YXRlID0gZm9ybWF0U3RhdGU7XG4gIH1cblxuICBpZihmb3JtYXRaaXApIHtcbiAgICBwYXltZW50Q2FyZC56aXAgPSBmb3JtYXRaaXA7XG4gIH1cblxuICBjb25zdCB1cGRhdGUgPSBwYXltZW50Q2FyZDtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBcbiAgICAgIExFVCB1cGRhdGVkQ2FyZCA9IEZJUlNUKFxuICAgICAgICBGT1IgYyBJTiBjcmVkaXRDYXJkc1xuICAgICAgICBGSUxURVIgYy5fa2V5ID09ICR7Zm9ybWF0SWR9ICYmIGMudXNlcklkID09ICR7c2Vzc2lvbklkfVxuICAgICAgICBVUERBVEUgYyBXSVRIICR7dXBkYXRlfSBJTiBjcmVkaXRDYXJkc1xuICAgICAgICBMSU1JVCAxXG4gICAgICAgIFJFVFVSTiBORVdcbiAgICAgIClcbiAgICAgIExFVCB1c2VyID0gRklSU1QoXG4gICAgICAgIEZPUiB1IElOIHVzZXJzXG4gICAgICAgIEZJTFRFUiB1Ll9rZXkgPT0gJHtzZXNzaW9uSWR9XG4gICAgICAgIExJTUlUIDFcbiAgICAgICAgUkVUVVJOIHVcbiAgICAgIClcbiAgICAgIFJFVFVSTiB7dXNlcjogdXNlciwgY2FyZDogdXBkYXRlZENhcmR9YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHJlc3VsdHMgPSB7Y2FyZDoge30sIHVzZXI6IHt9fSkgPT4ge1xuICAgICAgY29uc3QgdXBkYXRlZENhcmQ6IFBheW1lbnRDYXJkVHlwZSA9IHJlc3VsdHMuY2FyZDtcbiAgICAgIGNvbnN0IHt1c2VyfSA9IHJlc3VsdHM7XG5cbiAgICAgIGlmKCF1cGRhdGVkQ2FyZCkge1xuICAgICAgICB0aHJvdyBuZXcgVXNlckVycm9yKCdub3RfZm91bmQnKTtcbiAgICAgIH1cblxuICAgICAgY29uc3Qge3N0cmlwZUN1c3RvbWVySWR9ID0gdXNlcjtcbiAgICAgIGNvbnN0IHtzdHJpcGVJZH0gPSBjYXJkO1xuXG4gICAgICAvLyBTdHJpcGVcbiAgICAgIGNvbnN0IHN0cmlwZUNsaWVudCA9IG5ldyBTdHJpcGUoQ29uZmlnLmdldCgnc3RyaXBlLnRva2VuJyksIHthcGlWZXJzaW9uLCB0eXBlc2NyaXB0OiB0cnVlfSk7XG4gICAgICBjb25zdCB1cGRhdGU6IFN0cmlwZS5DdXN0b21lclVwZGF0ZVNvdXJjZVBhcmFtcyA9IHtcbiAgICAgICAgYWRkcmVzc19jaXR5OiBmb3JtYXRDaXR5LFxuICAgICAgICBhZGRyZXNzX2NvdW50cnk6IGZvcm1hdENvdW50cnksXG4gICAgICAgIGFkZHJlc3NfbGluZTE6IGZvcm1hdFN0cmVldDEsXG4gICAgICAgIGFkZHJlc3Nfc3RhdGU6IGZvcm1hdFN0YXRlLFxuICAgICAgICBhZGRyZXNzX3ppcDogZm9ybWF0WmlwLFxuICAgICAgICBleHBfbW9udGg6IGZvcm1hdEV4cE1vbnRoLnRvU3RyaW5nKCksXG4gICAgICAgIGV4cF95ZWFyOiBmb3JtYXRFeHBZZWFyLnRvU3RyaW5nKCksXG4gICAgICAgIG5hbWU6IGZvcm1hdEZ1bGxOYW1lXG4gICAgICB9O1xuXG4gICAgICByZXR1cm4gc3RyaXBlQ2xpZW50LmN1c3RvbWVyc1xuICAgICAgICAudXBkYXRlU291cmNlKHN0cmlwZUN1c3RvbWVySWQsIHN0cmlwZUlkLCB1cGRhdGUpXG4gICAgICAgIC50aGVuKCgpID0+IGNhcmQpXG4gICAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coJ3BheW1lbnRzOjp1cGRhdGVDYXJkOjplcnJvcicsIGVycm9yKTtcbiAgICAgICAgICB0aHJvdyBuZXcgVXNlckVycm9yKCdwYXltZW50X2Vycm9yJyk7XG4gICAgICAgIH0pO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldENyZWRpdENhcmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQpOiBQcm9taXNlPFBheW1lbnRDYXJkVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICdnZXRDcmVkaXRDYXJkcyc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBjIElOIGNyZWRpdENhcmRzXG4gICAgRklMVEVSIGMudXNlcklkID09ICR7c2Vzc2lvbklkfVxuICAgIFJFVFVSTiBjYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAudGhlbigobGlzdDogUGF5bWVudENhcmRUeXBlW10gPSBbXSkgPT4gbGlzdClcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBkZWxldGVDcmVkaXRDYXJkID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGNhcmRJZDogc3RyaW5nKTogUHJvbWlzZTxib29sZWFuPiA9PiB7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXRDYXJkSWQ6IHN0cmluZyA9IHBhcnNlSWQoY2FyZElkKTtcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBcbiAgICBMRVQgY2FyZCA9IEZJUlNUKFxuICAgICAgRk9SIGMgSU4gY3JlZGl0Q2FyZHNcbiAgICAgIEZJTFRFUiBjLl9rZXkgPT0gJHtmb3JtYXRDYXJkSWR9ICYmIGMudXNlcklkID09ICR7c2Vzc2lvbklkfVxuICAgICAgTElNSVQgMVxuICAgICAgUkVNT1ZFIGMgSU4gY3JlZGl0Q2FyZHNcbiAgICAgIFJFVFVSTiBPTERcbiAgICApXG4gICAgTEVUIHVzZXIgPSBGSVJTVChcbiAgICAgIEZPUiB1IElOIHVzZXJzXG4gICAgICBGSUxURVIgdS5fa2V5ID09ICR7c2Vzc2lvbklkfVxuICAgICAgTElNSVQgMVxuICAgICAgUkVUVVJOIHVcbiAgICApXG4gICAgUkVUVVJOIHt1c2VyOiB1c2VyLCBjYXJkOiBjYXJkfWA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKChyZXN1bHQgPSB7Y2FyZDoge30sIHVzZXI6IHt9fSkgPT4ge1xuICAgICAgaWYoIXJlc3VsdCkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHtjYXJkLCB1c2VyfSA9IHJlc3VsdDtcbiAgICAgIGNvbnN0IHtfa2V5OiBjYXJkS2V5fSA9IGNhcmQ7XG5cbiAgICAgIC8vIFJlbW92ZSBsaW5rZWQgZWRnZXNcbiAgICAgIGNvbnN0IGVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaGFzUGF5bWVudCcpO1xuXG4gICAgICByZXR1cm4gZWRnZUNvbGxlY3Rpb24ub3V0RWRnZXMoY2FyZEtleSwge30pXG4gICAgICAgIC50aGVuKGFzeW5jIChyZXNwb25zZSkgPT4ge1xuICAgICAgICAgIC8vIEV4dHJhY3QgZWRnZXMgZnJvbSB0aGUgcmVzcG9uc2VcbiAgICAgICAgICBjb25zdCBlZGdlcyA9IEFycmF5LmlzQXJyYXkocmVzcG9uc2UpID8gcmVzcG9uc2UgOiBbXTtcblxuICAgICAgICAgIGlmKGVkZ2VzLmxlbmd0aCkge1xuICAgICAgICAgICAgYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICAgICAgICAgIGVkZ2VzLm1hcCgoZWRnZSkgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IHtfa2V5OiBlZGdlS2V5fSA9IGVkZ2U7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVtb3ZlQXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBSRU1PVkUge19rZXk6JHtlZGdlS2V5fX0gSU4gaGFzUGF5bWVudGA7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KHJlbW92ZUFxbFFyeSk7XG4gICAgICAgICAgICAgIH0pKVxuICAgICAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgICAgLy8gU3RyaXBlXG4gICAgICAgICAgICAgICAgY29uc3Qgc3RyaXBlQ2xpZW50ID0gbmV3IFN0cmlwZShDb25maWcuZ2V0KCdzdHJpcGUudG9rZW4nKSwge2FwaVZlcnNpb24sIHR5cGVzY3JpcHQ6IHRydWV9KTtcblxuICAgICAgICAgICAgICAgIHJldHVybiBzdHJpcGVDbGllbnQuY3VzdG9tZXJzXG4gICAgICAgICAgICAgICAgICAuZGVsZXRlU291cmNlKHVzZXIuc3RyaXBlQ3VzdG9tZXJJZCwgY2FyZC5zdHJpcGVJZClcbiAgICAgICAgICAgICAgICAgIC50aGVuKCgpID0+IHRydWUpXG4gICAgICAgICAgICAgICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjb25zb2xlLmxvZygncGF5bWVudHM6OmRlbGV0ZUNhcmQ6OmVycm9yJywgZXJyb3IpO1xuICAgICAgICAgICAgICAgICAgICB0aHJvdyBuZXcgVXNlckVycm9yKCdwYXltZW50X2Vycm9yJyk7XG4gICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgfSk7XG5cbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfSk7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZGVsZXRlQmFua0FjY291bnQgPSAoY29udGV4dDogQXBpQ29udGV4dCwgYmFua0lkOiBzdHJpbmcpOiBQcm9taXNlPGJvb2xlYW4+ID0+IHtcbiAgY29uc3Qge2RhdGFiYXNlLCBzZXNzaW9uOiB7dXNlcklkOiBzZXNzaW9uSWR9fSA9IGNvbnRleHQ7XG5cbiAgLy8gQ2xlYW4gZGJcbiAgY29uc3QgdXBkYXRlOiBVc2VyVHlwZSA9IHtcbiAgICBiYW5rQWNjb3VudDogJycsXG4gICAgYmFua0Z1bGxOYW1lOiAnJyxcbiAgICBiYW5rSWQ6ICcnLFxuICAgIGJhbmtSb3V0aW5nOiAnJyxcbiAgICBtb2RpZmllZDogRGF0ZS5ub3coKVxuICB9O1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQREFURSAke3Nlc3Npb25JZH0gV0lUSCAke3VwZGF0ZX0gSU4gdXNlcnMgTElNSVQgMSBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHVzZXI6IFVzZXJUeXBlKSA9PiB7XG4gICAgICBjb25zdCB7c3RyaXBlQWNjb3VudElkfSA9IHVzZXI7XG5cbiAgICAgIC8vIFN0cmlwZVxuICAgICAgY29uc3Qgc3RyaXBlQ2xpZW50ID0gbmV3IFN0cmlwZShDb25maWcuZ2V0KCdzdHJpcGUudG9rZW4nKSwge2FwaVZlcnNpb24sIHR5cGVzY3JpcHQ6IHRydWV9KTtcblxuICAgICAgcmV0dXJuIHN0cmlwZUNsaWVudC5jdXN0b21lcnNcbiAgICAgICAgLmRlbGV0ZVNvdXJjZShzdHJpcGVBY2NvdW50SWQsIGJhbmtJZClcbiAgICAgICAgLnRoZW4oKCkgPT4gdHJ1ZSlcbiAgICAgICAgLmNhdGNoKCgpID0+IFByb21pc2UucmVzb2x2ZShmYWxzZSkpO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZVBheW1lbnRUcmFuc2ZlciA9IChjb250ZXh0OiBBcGlDb250ZXh0LCB0cmFuc2ZlcjogUGF5bWVudFRyYW5zZmVyKTogUHJvbWlzZTxQYXltZW50VHJhbnNmZXI+ID0+IHtcbiAgY29uc3Qge2RhdGFiYXNlLCBzZXNzaW9uOiB7dXNlcklkOiBzZXNzaW9uSWR9fSA9IGNvbnRleHQ7XG4gIGNvbnN0IHthbW91bnQsIGN1cnJlbmN5fSA9IHRyYW5zZmVyO1xuICBjb25zdCBmb3JtYXRBbW91bnQ6IG51bWJlciA9IHBhcnNlTnVtKGFtb3VudCk7XG4gIGNvbnN0IGZvcm1hdEN1cnJlbmN5OiBzdHJpbmcgPSBwYXJzZUNoYXIoY3VycmVuY3ksIDMsICdVU0QnKS50b1VwcGVyQ2FzZSgpO1xuXG4gIHJldHVybiBnZXRVc2VyKGNvbnRleHQsIHt1c2VySWQ6IHNlc3Npb25JZH0pXG4gICAgLnRoZW4oKHVzZXI6IFVzZXJUeXBlKSA9PiB7XG4gICAgICBjb25zdCB7c3RyaXBlQWNjb3VudElkfSA9IHVzZXI7XG5cbiAgICAgIC8vIFN0cmlwZVxuICAgICAgY29uc3Qgc3RyaXBlQ2xpZW50ID0gbmV3IFN0cmlwZShDb25maWcuZ2V0KCdzdHJpcGUudG9rZW4nKSwge2FwaVZlcnNpb24sIHR5cGVzY3JpcHQ6IHRydWV9KTtcblxuICAgICAgcmV0dXJuIHN0cmlwZUNsaWVudC50cmFuc2ZlcnNcbiAgICAgICAgLmNyZWF0ZSh7XG4gICAgICAgICAgYW1vdW50OiBmb3JtYXRBbW91bnQsXG4gICAgICAgICAgY3VycmVuY3k6IGZvcm1hdEN1cnJlbmN5LFxuICAgICAgICAgIGRlc3RpbmF0aW9uOiBzdHJpcGVBY2NvdW50SWRcbiAgICAgICAgfSlcbiAgICAgICAgLnRoZW4oKHN0cmlwZVRyYW5zZmVyKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coc3RyaXBlVHJhbnNmZXIpO1xuICAgICAgICAgIGNvbnN0IG5vdzogbnVtYmVyID0gRGF0ZS5ub3coKTtcbiAgICAgICAgICBjb25zdCBpbnNlcnQ6IFBheW1lbnRUcmFuc2ZlciA9IHtcbiAgICAgICAgICAgIGFkZGVkOiBub3csXG4gICAgICAgICAgICBhbW91bnQ6IGZvcm1hdEFtb3VudCxcbiAgICAgICAgICAgIGN1cnJlbmN5OiBmb3JtYXRDdXJyZW5jeSxcbiAgICAgICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgICAgICB1c2VySWQ6IHNlc3Npb25JZFxuICAgICAgICAgIH07XG4gICAgICAgICAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBJTlNFUlQgJHtpbnNlcnR9IElOIHRyYW5zZmVycyBSRVRVUk4gTkVXYDtcblxuICAgICAgICAgIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgICAgICAgICAudGhlbigoY3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgICAgICAgICAgLnRoZW4oKG5ld1RyYW5zZmVyOiBQYXltZW50VHJhbnNmZXIpID0+IG5ld1RyYW5zZmVyKTtcbiAgICAgICAgfSk7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlUGF5bWVudEhvbGQgPSAoY29udGV4dDogQXBpQ29udGV4dCwgcGF5bWVudDogUGF5bWVudENoYXJnZSk6IFByb21pc2U8UGF5bWVudENoYXJnZT4gPT4ge1xuICBjb25zdCB7ZGF0YWJhc2UsIHNlc3Npb246IHt1c2VySWQ6IHNlc3Npb25JZH19ID0gY29udGV4dDtcbiAgY29uc3Qge2Ftb3VudCwgY2FwdHVyZSwgY2FyZElkLCBjdXJyZW5jeSwgZGVzY3JpcHRpb259ID0gcGF5bWVudDtcbiAgY29uc3QgZm9ybWF0Q3VycmVuY3kgPSBwYXJzZUNoYXIoY3VycmVuY3ksIDMsICdVU0QnKS50b1VwcGVyQ2FzZSgpO1xuXG4gIGNvbnN0IHN0cmlwZUNsaWVudCA9IG5ldyBTdHJpcGUoQ29uZmlnLmdldCgnc3RyaXBlLnRva2VuJyksIHthcGlWZXJzaW9uLCB0eXBlc2NyaXB0OiB0cnVlfSk7XG5cbiAgcmV0dXJuIHN0cmlwZUNsaWVudC5jaGFyZ2VzXG4gICAgLmNyZWF0ZSh7XG4gICAgICBhbW91bnQsXG4gICAgICBjYXB0dXJlLFxuICAgICAgY3VycmVuY3k6IGZvcm1hdEN1cnJlbmN5LFxuICAgICAgZGVzY3JpcHRpb24sXG4gICAgICBzb3VyY2U6IGNhcmRJZFxuICAgIH0pXG4gICAgLnRoZW4oKHN0cmlwZUNoYXJnZSkgPT4ge1xuICAgICAgY29uc3Qgbm93OiBudW1iZXIgPSBEYXRlLm5vdygpO1xuICAgICAgY29uc3QgaW5zZXJ0OiBQYXltZW50Q2hhcmdlID0ge1xuICAgICAgICBhZGRlZDogbm93LFxuICAgICAgICBhbW91bnQsXG4gICAgICAgIGNhcHR1cmUsXG4gICAgICAgIGNhcmRJZCxcbiAgICAgICAgY2hhcmdlRmFpbENvZGU6IHN0cmlwZUNoYXJnZS5mYWlsdXJlX2NvZGUsXG4gICAgICAgIGNoYXJnZUZhaWxNc2c6IHN0cmlwZUNoYXJnZS5mYWlsdXJlX21lc3NhZ2UsXG4gICAgICAgIGNoYXJnZUlkOiBzdHJpcGVDaGFyZ2UuaWQsXG4gICAgICAgIGNoYXJnZVN0YXR1czogc3RyaXBlQ2hhcmdlLnN0YXR1cyxcbiAgICAgICAgY3VycmVuY3k6IGZvcm1hdEN1cnJlbmN5LFxuICAgICAgICBkZXNjcmlwdGlvbixcbiAgICAgICAgbW9kaWZpZWQ6IG5vdyxcbiAgICAgICAgdXNlcklkOiBzZXNzaW9uSWRcbiAgICAgIH07XG4gICAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2luc2VydH0gSU4gcGF5bWVudHMgUkVUVVJOIE5FV2A7XG5cbiAgICAgIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgICAgIC50aGVuKChjdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgICAgIC50aGVuKChuZXdQYXltZW50OiBQYXltZW50Q2hhcmdlKSA9PiBuZXdQYXltZW50KTtcbiAgICB9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZygncGF5bWVudHM6OmNyZWF0ZUhvbGQ6OmVycm9yJywgZXJyb3IpO1xuICAgICAgdGhyb3cgbmV3IFVzZXJFcnJvcigncGF5bWVudF9lcnJvcicpO1xuICAgIH0pO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBSUEsbUJBQWtGO0FBQ2xGLHNCQUFrQjtBQUVsQixvQkFBbUI7QUFFbkIsb0JBQXFCO0FBRXJCLG1CQUFzQjtBQUN0QixtQkFBeUI7QUFDekIsNEJBQWtDO0FBSWxDLE1BQU0sZ0JBQWdCO0FBQ3RCLE1BQU0sYUFBYTtBQUVaLE1BQU0scUJBQXFCLENBQUMsWUFBMEM7QUFDM0UsUUFBTSxTQUFTO0FBQ2YsUUFBTSxFQUFDLFVBQVUsU0FBUyxFQUFDLFFBQVEsV0FBVyxTQUFRLEVBQUMsSUFBSTtBQUczRCxRQUFNLGVBQWUsSUFBSSxjQUFBQSxRQUFPLHFCQUFP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TztBQUFBLFFBQ1AsUUFBUTtBQUFBLFFBQ1IsVUFBVTtBQUFBLFFBQ1YsVUFBVTtBQUFBLFFBQ1YsUUFBUTtBQUFBLE1BQ1Y7QUFDQSxZQUFNLFNBQW1CLDZCQUFhLE1BQU07QUFFNUMsYUFBTyxTQUFTLE1BQU0sTUFBTSxFQUN6QixLQUFLLENBQUMsV0FBVyxPQUFPLEtBQUssQ0FBQyxFQUM5QixLQUFLLENBQUMsZ0JBQWlDLFdBQVc7QUFBQSxJQUN2RCxDQUFDO0FBQUEsRUFDTCxDQUFDO0FBQ0w7QUFFTyxNQUFNLG9CQUFvQixDQUFDLFNBQXFCLFlBQW1EO0FBQ3hHLFFBQU0sRUFBQyxVQUFVLFNBQVMsRUFBQyxRQUFRLFVBQVMsRUFBQyxJQUFJO0FBQ2pELFFBQU0sRUFBQyxRQUFRLFNBQVMsUUFBUSxVQUFVLFlBQVcsSUFBSTtBQUN6RCxRQUFNLHFCQUFpQix3QkFBVSxVQUFVLEdBQUcsS0FBSyxFQUFFLFlBQVk7QUFFakUsUUFBTSxlQUFlLElBQUksY0FBQUEsUUFBTyxxQkFBTyxJQUFJLGNBQWMsR0FBRyxFQUFDLFlBQVksWUFBWSxLQUFJLENBQUM7QUFFMUYsU0FBTyxhQUFhLFFBQ2pCLE9BQU87QUFBQSxJQUNOO0FBQUEsSUFDQTtBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1Y7QUFBQSxJQUNBLFFBQVE7QUFBQSxFQUNWLENBQUMsRUFDQSxLQUFLLENBQUMsaUJBQWlCO0FBQ3RCLFVBQU0sTUFBYyxLQUFLLElBQUk7QUFDN0IsVUFBTSxTQUF3QjtBQUFBLE1BQzVCLE9BQU87QUFBQSxNQUNQO0FBQUEsTUFDQTtBQUFBLE1BQ0E7QUFBQSxNQUNBLGdCQUFnQixhQUFhO0FBQUEsTUFDN0IsZUFBZSxhQUFhO0FBQUEsTUFDNUIsVUFBVSxhQUFhO0FBQUEsTUFDdkIsY0FBYyxhQUFhO0FBQUEsTUFDM0IsVUFBVTtBQUFBLE1BQ1Y7QUFBQSxNQUNBLFVBQVU7QUFBQSxNQUNWLFFBQVE7QUFBQSxJQUNWO0FBQ0EsVUFBTSxTQUFtQiw2QkFBYSxNQUFNO0FBRTVDLFdBQU8sU0FBUyxNQUFNLE1BQU0sRUFDekIsS0FBSyxDQUFDLFdBQVcsT0FBTyxLQUFLLENBQUMsRUFDOUIsS0FBSyxDQUFDLGVBQThCLFVBQVU7QUFBQSxFQUNuRCxDQUFDLEVBQ0EsTUFBTSxDQUFDLFVBQWlCO0FBQ3ZCLFlBQVEsSUFBSSwrQkFBK0IsS0FBSztBQUNoRCxVQUFNLElBQUksZ0NBQVUsZUFBZTtBQUFBLEVBQ3JDLENBQUM7QUFDTDsiLAogICJuYW1lcyI6IFsiU3RyaXBlIiwgInVwZGF0ZSJdCn0K
|