Stripe checkout не может получить доступ к моей странице успеха django apps на heroku

Я относительно неопытный программист на python/django и столкнулся с проблемой, которую я не могу решить самостоятельно, несмотря на поиск помощи. Английский не является моим родным языком, поэтому, пожалуйста, не обращайте внимания на языковые ошибки в моей попытке объяснить мою проблему.

Мое приложение django 3.2 использует stripe checkout для оплаты. Во время разработки на локальной машине я мог обработать платеж и вернуться на страницу успеха моего приложения, но после того, как я развернул его на heroku, оно обрабатывает платеж, но не возвращается на страницу успеха моего приложения. Я установил пакет corsheaders и попробовал все возможные настройки, предложенные здесь на stackoverflow и в других местах. Ниже я привожу свои настройки, а также код вида stripe checkout. Любая помощь будет высоко оценена.

все соответствующие настройки следующие


BASE_DIR = Path(__file__).resolve().parent.parent


ALLOWED_HOSTS = ['*']
CORS_ORIGIN_ALLOW_ALL = True
CSRF_COOKIE_SECURE = True
SESSION_COOKIE_SECURE = True

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    # 3rd party
    'rest_framework',
    'corsheaders',
    'crispy_forms',
    'sorl.thumbnail',
    'cloudinary',
    'storages',

    # local
    'accounts.apps.AccountsConfig',
    'main.apps.MainConfig',
    'api.apps.ApiConfig',
    'cart.apps.CartConfig',
    'payment.apps.PaymentConfig',
    'order.apps.OrderConfig',
    'setmenu.apps.SetmenuConfig',
]

MIDDLEWARE = [
    'corsheaders.middleware.CorsMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [str(BASE_DIR.joinpath('templates'))],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

core.urls.py

urlpatterns = [
    path('admin/', admin.site.urls),
    path('accounts/', include('accounts.urls')),
    path('accounts/', include('django.contrib.auth.urls')),
    path('api/v1/', include('api.urls')),
    path('cart/', include('cart.urls', namespace='carturls')),
    path('setmenu/', include('setmenu.urls', namespace='setmenu')),
    path('orders/', include('order.urls', namespace='orders')),
    path('payment/', include('payment.urls', namespace='payment')),
    path('', include('main.urls', namespace='main')),
]

payment urls.py

app_name = 'payment'

urlpatterns = [
    path('process/', login_required(views.payment_process), name='process'),
    path('done/', views.payment_done, name='done'),
    path('canceled/', views.payment_canceled, name='canceled'),
    path('webhook/', views.webhook, name='webhook')
]

Представление платежного приложения, которое обрабатывает платеж

def payment_process(request):
    order_id = request.session.get('order_id')
    order = get_object_or_404(Order, id=order_id)
    total_cost = int(order.get_total_amount() * 100)

    session = stripe.checkout.Session.create(
        line_items=[{
            'price_data': {
                'currency': 'inr',
                'product_data': {
                    'name': f'Order number {order_id}',
                },
                'unit_amount': f'{total_cost}',
            },
            'quantity': 1,
        }],
        mode='payment',
        success_url='https://myappname.herokuapp.com/payment/done',
        cancel_url='https://myappname.herokuapp.com/payment/canceled',
    )
    return redirect(session.url, code=303)

Даже если я ставлю done/, он не перенаправляет. Однако приведенные ниже ссылки успеха работают, и я перенаправляюсь на домашнюю страницу и страницу администратора соответственно.

success_url='https://myappname.herokuapp.com' и success_url='https://myappname.herokuapp.com/admin'

Но, конечно, в идеале он должен возвращаться на конкретную страницу успеха. Тот факт, что он успешно перенаправляет на https://myappname.herokuapp.com/admin, беспокоит меня еще больше, почему он не переходит на https://myappname.herokuapp.com/payment/done

Я пытался отбросить платежные урлы и поместить маршруты оплаты в основные урлы, думая, что он не обращается к пользовательским урлам, но это тоже не сработало.

Пожалуйста, направьте меня в нужное русло. Я склоняюсь к мысли, что мои настройки Cors не верны, но тогда я разрешил все хосты и cors_origin_allow_all true.corsheaders middleware также находится на вершине, как было предложено, но все же он не перенаправляет с stripe. Поэтому я чувствую, что уперся в стену.

Большое спасибо за помощь

Вернуться на верх