Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(router): [V2] Introduce V2Auth and use it for payment_methods_list_enabled #7038

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

AnuthaDev
Copy link
Contributor

@AnuthaDev AnuthaDev commented Jan 15, 2025

Type of Change

  • Bugfix
  • New feature
  • Enhancement
  • Refactoring
  • Dependency updates
  • Documentation
  • CI/CD

Description

Added an enum V2Auth (name subject to change) to encapsulate different authentication scenarios. Currently only works for Client Authentication using publishable_key and ephemeral_key in Authorization header

Additional Changes

  • This PR modifies the API contract
  • This PR modifies the database schema
  • This PR modifies application configuration/environment variables

Motivation and Context

Closes #7037

How did you test it?

1a. Payment method intent create request:

curl --location 'http://localhost:8080/v2/payment-methods/create-intent' \
--header 'Content-Type: application/json' \
--header 'Accept: application/json' \
--header 'X-Profile-Id: pro_hOlRnOdewwhXSV9l7TJJ' \
--header 'api-key: dev_XLbxcbVTqGoxcd8rVlt48b0QhbleB8ZuiqeSj2XXToUBXPDbVzeS0I5cMCaSnsYb' \
--data '{
  "customer_id": "12345_cus_0194a71908247490bbc38202cece425b"
}'

1b. Payment method intent create response:

{
    "id": "12345_pm_0194a71929907523adbb332ddb699f0f",
    "merchant_id": "cloth_seller_a8Sp7qm2hHWJbjAuffaz",
    "customer_id": "12345_cus_0194a71908247490bbc38202cece425b",
    "payment_method_type": null,
    "payment_method_subtype": null,
    "recurring_enabled": false,
    "created": "2025-01-27T09:30:31.703Z",
    "last_used_at": "2025-01-27T09:30:31.703Z",
    "client_secret": "cs_0194a71929917da2b83fafc6c97388d1",
    "payment_method_data": null
}

2a. List payment methods enabled request:

curl --location 'http://localhost:8080/v2/payment-methods/12345_pm_0194a71929907523adbb332ddb699f0f/list-enabled-payment-methods' \
--header 'Content-Type: application/json' \
--header 'x-profile-id: pro_hOlRnOdewwhXSV9l7TJJ' \
--header 'Authorization: publishable-key=pk_dev_8dc540967cb24672bea6d5afed3720e4, client-secret=cs_0194a71929917da2b83fafc6c97388d1' \
--header 'x-customer-id: 12345_cus_0194a71908247490bbc38202cece425b'

2b. List payment methods enabled response:

{
    "payment_methods_enabled": [
        {
            "payment_method_type": "card_redirect",
            "payment_method_subtype": "card_redirect",
            "required_fields": []
        },
        {
            "payment_method_type": "card",
            "payment_method_subtype": "credit",
            "required_fields": [
                {
                    "required_field": "payment_method_data.card.card_number",
                    "display_name": "card_number",
                    "field_type": "user_card_number",
                    "value": null
                },
                {
                    "required_field": "payment_method_data.card.card_exp_year",
                    "display_name": "card_exp_year",
                    "field_type": "user_card_expiry_year",
                    "value": null
                },
                {
                    "required_field": "payment_method_data.card.card_cvc",
                    "display_name": "card_cvc",
                    "field_type": "user_card_cvc",
                    "value": null
                },
                {
                    "required_field": "payment_method_data.card.card_exp_month",
                    "display_name": "card_exp_month",
                    "field_type": "user_card_expiry_month",
                    "value": null
                }
            ]
        },
        {
            "payment_method_type": "card",
            "payment_method_subtype": "debit",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "google_pay",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "apple_pay",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "we_chat_pay",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "ali_pay",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "paypal",
            "required_fields": []
        },
        {
            "payment_method_type": "wallet",
            "payment_method_subtype": "mb_way",
            "required_fields": []
        },
        {
            "payment_method_type": "pay_later",
            "payment_method_subtype": "klarna",
            "required_fields": []
        },
        {
            "payment_method_type": "pay_later",
            "payment_method_subtype": "affirm",
            "required_fields": []
        },
        {
            "payment_method_type": "pay_later",
            "payment_method_subtype": "afterpay_clearpay",
            "required_fields": []
        },
        {
            "payment_method_type": "pay_later",
            "payment_method_subtype": "walley",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "giropay",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "ideal",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "eps",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "bancontact_card",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "przelewy24",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "sofort",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "blik",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "trustly",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "online_banking_finland",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_redirect",
            "payment_method_subtype": "online_banking_poland",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_transfer",
            "payment_method_subtype": "ach",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_transfer",
            "payment_method_subtype": "sepa",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_transfer",
            "payment_method_subtype": "bacs",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_debit",
            "payment_method_subtype": "ach",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_debit",
            "payment_method_subtype": "sepa",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_debit",
            "payment_method_subtype": "bacs",
            "required_fields": []
        },
        {
            "payment_method_type": "bank_debit",
            "payment_method_subtype": "becs",
            "required_fields": []
        }
    ]
}

Checklist

  • I formatted the code cargo +nightly fmt --all
  • I addressed lints thrown by cargo clippy
  • I reviewed the submitted code
  • I added unit tests for my changes where possible

Copy link

semanticdiff-com bot commented Jan 15, 2025

Review changes with  SemanticDiff

Changed Files
File Status
  crates/api_models/src/events/payment.rs  78% smaller
  crates/router/src/db/kafka_store.rs  55% smaller
  crates/router/src/db/ephemeral_key.rs  52% smaller
  crates/router/src/types/storage/ephemeral_key.rs  50% smaller
  crates/router/src/core/payments/helpers.rs  41% smaller
  crates/common_utils/src/events.rs  40% smaller
  crates/diesel_models/src/ephemeral_key.rs  39% smaller
  crates/router/src/types/api/payments.rs  26% smaller
  crates/router/src/core/payments/transformers.rs  19% smaller
  crates/api_models/src/ephemeral_key.rs  19% smaller
  crates/router/src/db.rs  15% smaller
  crates/router/src/core/payment_methods.rs  14% smaller
  crates/openapi/src/openapi_v2.rs  11% smaller
  crates/router/src/routes/payment_methods.rs  8% smaller
  api-reference-v2/openapi_spec.json  5% smaller
  crates/router/src/services/authentication.rs  4% smaller
  crates/router/src/core/payment_methods/transformers.rs  1% smaller
  crates/api_models/src/payment_methods.rs  0% smaller
  crates/api_models/src/payments.rs  0% smaller
  crates/api_models/src/webhooks.rs  0% smaller
  crates/common_utils/src/id_type.rs  0% smaller
  crates/common_utils/src/id_type/client_secret.rs  0% smaller
  crates/common_utils/src/id_type/ephemeral_key.rs  0% smaller
  crates/router/src/core/utils.rs  0% smaller
  crates/router/src/lib.rs  0% smaller
  crates/router/src/routes/app.rs  0% smaller
  crates/router/src/routes/ephemeral_key.rs  0% smaller
  crates/router/src/types.rs  0% smaller

@hyperswitch-bot hyperswitch-bot bot added the M-api-contract-changes Metadata: This PR involves API contract changes label Jan 15, 2025
@@ -1,5 +1,7 @@
#[cfg(feature = "v1")]
pub use api_models::payments::PaymentsRequest;
#[cfg(feature = "v1")]
pub use api_models::payments::{PaymentListResponse, PaymentListResponseV2, PaymentsResponse};
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why do we need to re export this, ideally we should not have any re exports

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Needed to move these out of the existing re-exports to add the v1 feature gate. Removing re-exports can be taken up as a separate task

crates/router/src/types/storage/ephemeral_key.rs Outdated Show resolved Hide resolved
crates/diesel_models/src/ephemeral_key.rs Outdated Show resolved Hide resolved
@AnuthaDev AnuthaDev force-pushed the payment_methods_list_auth branch 3 times, most recently from 1409f93 to 859b32d Compare January 27, 2025 09:20
@AnuthaDev AnuthaDev force-pushed the payment_methods_list_auth branch from 859b32d to 7f9d4e3 Compare January 27, 2025 10:29
@AnuthaDev AnuthaDev marked this pull request as ready for review January 27, 2025 10:29
@AnuthaDev AnuthaDev requested review from a team as code owners January 27, 2025 10:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
M-api-contract-changes Metadata: This PR involves API contract changes
Projects
None yet
Development

Successfully merging this pull request may close these issues.

feat(router): Unify Auth in single layer (V2)
2 participants