> 백엔드 개발 > 파이썬 튜토리얼 > 오픈소스 협업 진행

오픈소스 협업 진행

Linda Hamilton
풀어 주다: 2024-12-10 16:32:17
원래의
708명이 탐색했습니다.

Open-Source Collaboration Progress

개요

최근 저는 이전에 익숙하지 않았던 프레임워크인 Sanic과 Slack Bolt를 통합하는 프로젝트를 진행하면서 흥미로운 도전에 직면했습니다. 이로 인해 예상치 못한 지원 중단 경고와 유형 관련 문제가 발생했습니다. 문제를 해결한 방법, 배운 교훈, 문제를 해결한 정확한 코드 변경 사항을 안내해 드리겠습니다.

Sanic과 Slack Bolt는 무엇인가요?

산닉

Sanic은 Python의 고성능 비동기 웹 프레임워크입니다. 빠르게 설계되었으며 Python의 asyncio 기능을 활용하여 대량의 요청을 효율적으로 처리합니다. 최소한의 디자인으로 경량 웹 애플리케이션, 마이크로서비스 및 API 레이어에 적합합니다.

슬랙 볼트

Slack Bolt는 Slack 앱 구축을 위한 프레임워크입니다. Slack API의 복잡성을 추상화하여 개발자가 대화형 및 이벤트 중심 Slack 애플리케이션을 만드는 데 집중할 수 있도록 합니다. Bolt를 사용하면 명령, 단축키, 이벤트 등을 쉽게 관리할 수 있습니다.

도전

통합을 구현하는 동안 테스트를 실행하고 요청을 처리할 때 Sanic의 쿠키 처리와 관련된 몇 가지 경고가 발생했습니다. 내가 본 경고의 예는 다음과 같습니다.

DeprecationWarning: [DEPRECATION] Setting cookie values using the dict pattern has been deprecated.
DeprecationWarning: [DEPRECATION] Accessing cookies from the CookieJar by dict key is deprecated.
TypeError: Argument "path" to "add_cookie" of "BaseHTTPResponse" has incompatible type "Optional[Any]"; expected "str"
로그인 후 복사

근본 원인은 Sanic v23.3부터 더 이상 권장되지 않는 Sanic의 오래된 dict 기반 쿠키 처리 구문을 사용했기 때문입니다. 대신 호환성을 보장하고 이러한 경고를 제거하려면 새로운 add_cookie 메소드를 사용해야 합니다.

해결책

주요 변경 사항은 dict 기반 쿠키 처리를 add_cookie 메소드로 대체하여 전달된 모든 쿠키 매개변수가 올바른 유형인지 확인하는 것이었습니다.

업데이트된 코드 조각은 다음과 같습니다.

# Iterate over cookies and add them using Sanic's add_cookie method
for cookie in bolt_resp.cookies():
    for key, c in cookie.items():
        # Convert "expires" field if provided
        expire_value = c.get("expires")
        expires = datetime.strptime(expire_value, "%a, %d %b %Y %H:%M:%S %Z") if expire_value else None

        # Convert "max-age" if provided
        max_age = int(c["max-age"]) if c.get("max-age") else None

        # Ensure values are of the correct type before passing to add_cookie
        path = str(c.get("path")) if c.get("path") else "/"
        domain = str(c.get("domain")) if c.get("domain") else None

        # Add cookie with Sanic's add_cookie method
        resp.add_cookie(
            key=key,
            value=c.value,
            expires=expires,
            path=path,
            domain=domain,
            max_age=max_age,
            secure=True,
            httponly=True,
        )

로그인 후 복사

교체된 Dict 기반 구문: 이전 접근 방식은 더 이상 사용되지 않는 dict 구문을 사용하여 resp.cookies를 직접 조작하는 데 의존했습니다. 대신 resp.add_cookie()를 사용하여 향후 호환되는 방식으로 쿠키를 설정했습니다.

적절한 데이터 유형 보장: 경로 및 도메인과 같은 매개변수는 때때로 없음이거나 문자열이 아닙니다. 이러한 값을 add_cookie에 전달하기 전에 명시적으로 문자열로 변환하거나 기본값(경로의 경우 "/", 도메인의 경우 없음)을 설정했습니다.

처리된 선택적 쿠키 필드: 만료는 제공된 경우 "%a, %d %b %Y %H:%M:%S %Z" 형식을 사용하여 날짜/시간 개체로 구문 분석되었습니다.
max-age는 가능한 경우 정수로 변환되었습니다.

이러한 변경으로 모든 경고와 오류가 해결되어 통합이 Sanic의 최신 관행을 준수할 수 있게 되었습니다.

최종 생각

저는 Sanic에 대한 사전 경험이 없었기 때문에 해당 문서를 이해하는 것이 중요했습니다. Sanic이 쿠키와 요청을 처리하는 방법을 배우면 이전 구문이 왜 문제가 되는지, 그리고 새로운 add_cookie 방법이 어떻게 작동하는지 깨닫는 데 도움이 되었습니다.

Slack Bolt와 Sanic의 통합은 보람찬 도전이었습니다. Sanic에 대한 이해가 향상되었을 뿐만 아니라 프레임워크 모범 사례를 최신 상태로 유지하는 것의 중요성도 강조되었습니다. 유사한 문제에 직면한 경우 이 블로그 게시물이 명확성을 제공하고 문제를 보다 효율적으로 해결하는 데 도움이 되기를 바랍니다.

위 내용은 오픈소스 협업 진행의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿