Maison >développement back-end >Tutoriel Python >Progrès de la collaboration open source

Progrès de la collaboration open source

Linda Hamilton
Linda Hamiltonoriginal
2024-12-10 16:32:17729parcourir

Open-Source Collaboration Progress

Aperçu

Récemment, j'ai été confronté à un défi intéressant en travaillant sur un projet intégrant Slack Bolt avec Sanic - un framework que je ne connaissais pas auparavant, qui a conduit à des avertissements de dépréciation inattendus et à des problèmes liés au type. Je vais vous expliquer comment j'ai résolu le problème, les leçons que j'ai apprises et les modifications précises du code qui ont résolu le problème.

Que sont Sanic et Slack Bolt ?

Sanic

Sanic est un framework Web asynchrone hautes performances en Python. Conçu pour être rapide, il tire parti des capacités asyncio de Python pour gérer efficacement de gros volumes de requêtes. Sa conception minimaliste le rend adapté aux applications Web légères, aux microservices et aux couches API.

Boulon mou

Slack Bolt est un framework permettant de créer des applications Slack. Il résume la complexité des API de Slack, permettant aux développeurs de se concentrer sur la création d'applications Slack interactives et événementielles. Avec Bolt, vous pouvez gérer facilement les commandes, les raccourcis, les événements et bien plus encore.

Le défi

Lors de la mise en œuvre de l'intégration, j'ai rencontré plusieurs avertissements liés à la gestion des cookies de Sanic lors de l'exécution des tests et du traitement des requêtes. Voici un exemple des avertissements que j'ai vu :

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"

La cause première était l'utilisation de l'ancienne syntaxe de gestion des cookies basée sur dict de Sanic, qui n'est plus recommandée depuis Sanic v23.3. Au lieu de cela, la nouvelle méthode add_cookie doit être utilisée pour garantir la compatibilité et éliminer ces avertissements.

La solution

Le changement clé consistait à remplacer la gestion des cookies basée sur dict par la méthode add_cookie, garantissant que tous les paramètres de cookies transmis étaient du type correct.

Voici l'extrait de code mis à jour :

# 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,
        )

Syntaxe basée sur Dict remplacée : L'ancienne approche reposait sur la manipulation directe de resp.cookies à l'aide de la syntaxe dict, qui est obsolète. Au lieu de cela, nous avons utilisé resp.add_cookie() pour définir les cookies de manière rétrocompatible.

Types de données appropriés garantis : Les paramètres tels que le chemin et le domaine étaient parfois des chaînes Aucune ou non. Nous avons explicitement converti ces valeurs en chaînes ou défini des valeurs par défaut ("/" pour le chemin, Aucun pour le domaine) avant de les transmettre à add_cookie.

Champs de cookies facultatifs gérés : expire a été analysé dans un objet datetime s'il est fourni, en utilisant le format "%a, %d %b %Y %H:%M:%S %Z".
max-age a été converti en nombre entier si disponible.

Ces modifications ont résolu tous les avertissements et erreurs, garantissant que l'intégration respecte les pratiques modernes de Sanic.

Pensées finales

Comme je n'avais aucune expérience préalable avec Sanic, comprendre sa documentation était essentiel. Apprendre comment Sanic gère les cookies et les requêtes m'a aidé à comprendre pourquoi l'ancienne syntaxe posait problème et comment fonctionne la nouvelle méthode add_cookie.

L'intégration de Slack Bolt à Sanic s'est avérée être un défi enrichissant. Non seulement cela a amélioré ma compréhension de Sanic, mais cela a également souligné l'importance de rester à jour avec les meilleures pratiques du framework. Si vous êtes confronté à des problèmes similaires, j'espère que cet article de blog vous apportera de la clarté et vous aidera à résoudre votre problème plus efficacement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn