API de l'Adaptateur d'Astro
Astro est conçu pour faciliter le déploiement vers n’importe quel fournisseur de cloud pour le SSR (rendu côté serveur). Cette capacité est fournie par les adaptateurs, qui sont des intégrations. Consultez le guide SSR (EN) pour apprendre à utiliser un adaptateur existant.
Qu’est-ce qu’un adaptateur ?
Titre de la section Qu’est-ce qu’un adaptateur ?Un adaptateur est un type particulier d’intégration qui fournit un point d’entrée pour le rendu côté serveur. Un adaptateur a deux fonctions :
- Implémente les API spécifiques à l’hôte pour gérer les requêtes.
- Configure la compilation en fonction des conventions de l’hôte.
Construire un adaptateur
Titre de la section Construire un adaptateurUn adaptateur est une intégration et peut faire tout ce qu’une intégration peut faire.
Un adaptateur doit appeler l’API setAdapter
dans le hook astro:config:done
comme suit :
L’objet passé dans setAdapter
est défini comme ceci :
Les propriétés sont les suivantes :
- name : Un nom unique pour votre adaptateur, utilisé pour la journalisation.
- serverEntrypoint : Le point d’entrée pour l’affichage côté serveur.
- exports : Un tableau d’exportations nommées lorsqu’il est utilisé en conjonction avec
createExports
(expliqué ci-dessous). - adapterFeatures : Un objet qui active des fonctionnalités spécifiques qui doivent être supportées par l’adaptateur. Ces fonctionnalités vont changer la sortie construite, et l’adaptateur doit implémenter la logique appropriée pour gérer la sortie différente.
- supportedAstroFeatures : Une liste des caractéristiques intégrées d’Astro. Cela permet à Astro de déterminer quelles fonctionnalités un adaptateur ne peut pas ou ne veut pas supporter afin que les messages d’erreur appropriés puissent être fournis.
Point d’entrée du serveur
Titre de la section Point d’entrée du serveurL’API de l’adaptateur Astro tente de fonctionner avec n’importe quel type d’hôte, et offre un moyen flexible de se conformer aux API de l’hôte.
Exportations
Titre de la section ExportationsCertains hôtes sans serveur attendent de vous que vous exportiez une fonction, comme handler
:
Avec l’API de l’adaptateur, vous y parvenez en implémentant createExports
dans votre serverEntrypoint
:
Ensuite, dans votre intégration, lorsque vous appelez setAdapter
, fournissez ce nom dans exports
:
Certains hôtes attendent que vous démarriez le serveur vous-mêmes, par exemple en écoutant un port. Pour ces types d’hôtes, l’API de l’adaptateur vous permet d’exporter une fonction start
qui sera appelée lors de l’exécution du script bundle.
astro/app
Titre de la section astro/appCe module est utilisé pour afficher les pages qui ont été pré-construites par astro build
. Astro utilise les objets standards Request et Response. Les hôtes qui ont une API différente pour les requêtes/réponses doivent convertir ces types dans leur adaptateur.
Les méthodes suivantes sont proposées :
app.render(request: Request, options?: RenderOptions)
Titre de la section app.render(request: Request, options?: RenderOptions)Cette méthode appelle la page Astro qui correspond à la demande, l’affiche et renvoie une promesse à un objet Response. Cette méthode fonctionne également pour les routes API qui n’affichent pas de pages.
RenderOptions
Titre de la section RenderOptionsLa méthode app.render()
accepte un argument obligatoire request
, et un objet optionnel RenderOptions
pour addCookieHeader
, clientAddress
, locals
, et routeData
.
addCookieHeader
Titre de la section addCookieHeaderAjouter ou non automatiquement tous les cookies écrits par Astro.cookie.set()
aux en-têtes de la réponse.
Lorsqu’ils sont définis à true
, ils seront ajoutés à l’en-tête Set-Cookie
de la réponse sous forme de paires clé-valeur séparées par des virgules. Vous pouvez utiliser l’API standard response.headers.getSetCookie()
pour les lire individuellement.
Si la valeur est false
(par défaut), les cookies ne seront disponibles qu’à partir de App.getSetCookieFromResponse(response)
.
clientAddress
Titre de la section clientAddressL’adresse IP du client qui sera disponible en tant que Astro.clientAddress
dans les pages, et en tant que ctx.clientAddress
dans les routes de l’API et le middleware.
L’exemple ci-dessous lit l’en-tête x-forwarded-for
et le transmet comme clientAddress
. Cette valeur devient disponible pour l’utilisateur en tant que Astro.clientAddress
.
L’objet context.locals
utilisé pour stocker et accéder aux informations pendant le cycle de vie d’une requête.
L’exemple ci-dessous lit un en-tête nommé x-private-header
, tente de l’analyser comme un objet et de le passer à locals
, qui peut alors être passé à n’importe quelle fonction middleware.
routeData
Titre de la section routeDataFournissez une valeur pour routeData
si vous connaissez déjà la route à afficher. Vous éviterez ainsi l’appel interne à app.match
pour déterminer la route à afficher.
app.match(request)
Titre de la section app.match(request)Cette méthode est utilisée pour déterminer si une demande est conforme aux règles de routage de l’application Astro.
Vous pouvez généralement appeler app.render(request)
sans utiliser .match
car Astro gère les 404 si vous fournissez un fichier 404.astro
. Utilisez app.match(request)
si vous voulez gérer les 404 d’une manière différente.
Autoriser l’installation via astro add
Titre de la section Autoriser l’installation via astro addLa commande astro add
permet aux utilisateurs d’ajouter facilement des intégrations et des adaptateurs à leur projet. Si vous voulez que votre adaptateur soit installable avec cet outil, ajoutez astro-adapter
au champ keywords
dans votre package.json
:
Une fois que vous avez publié votre adaptateur sur npm, lancer astro add example
installera votre paquet avec toutes les dépendances spécifiées dans votre package.json
. Nous demanderons également aux utilisateurs de mettre à jour manuellement la configuration de leur projet.
Fonctionnalités d’Astro
Titre de la section Fonctionnalités d’Astro
Ajouté à la version :
astro@3.0.0
Les fonctionnalités Astro permettent à un adaptateur d’indiquer à Astro s’il est en mesure de prendre en charge une fonctionnalité, ainsi que le niveau de prise en charge de l’adaptateur.
Lors de l’utilisation de ces propriétés, Astro
- exécute une validation spécifique ;
- émet des informations contextuelles dans les journaux ;
Ces opérations sont exécutées en fonction des fonctionnalités prises en charge ou non, de leur niveau de prise en charge et de la configuration utilisée par l’utilisateur.
La configuration suivante indique à Astro que cet adaptateur dispose d’un support expérimental pour les ressources, mais qu’il n’est pas compatible avec les services intégrés Sharp et Squoosh :
Astro enregistre un avertissement dans le terminal :
est une erreur si le service utilisé pour les ressources n’est pas compatible avec l’adaptateur :
Fonctionnalités de l’adaptateur
Titre de la section Fonctionnalités de l’adaptateurUn ensemble de fonctionnalités qui modifient la sortie des fichiers émis. Lorsqu’un adaptateur opte pour ces fonctionnalités, il obtiendra des informations supplémentaires à l’intérieur de hooks spécifiques.
functionPerRoute
Titre de la section functionPerRouteIl s’agit d’une fonctionnalité qui n’est activée qu’en cas d’utilisation de SSR. Par défaut, Astro émet un seul fichier entry.mjs
, qui est responsable de l’affichage de la page à chaque requête.
Lorsque functionPerRoute
est true
, Astro va créer un fichier séparé pour chaque route définie dans le projet.
Chaque fichier émis n’affichera qu’une seule page. Les pages seront émises dans un répertoire dist/pages/
(ou sous un répertoire /pages/
dans le répertoire spécifié pour outDir
), et les fichiers émis garderont le même chemin que le dossier src/pages/
.
Les fichiers contenus dans le répertoire pages/
de la compilation reflèteront la structure de répertoire de vos fichiers de pages dans src/pages/
, par exemple :
Répertoiredist/
- …
Répertoirepages/
- …
Répertoireblog/
- …
- entry._slug_.astro.mjs
- entry.about.astro.mjs
- entry.index.astro.mjs
Activez la fonctionnalité en passant true
à l’adaptateur.
Ensuite, utilisez le hook astro:build:ssr
, qui vous donnera un objet entryPoints
qui fait correspondre une route de page au fichier physique créé après la construction.
L’élément entryFile
est de type URL
et représente le chemin physique du fichier dans le système de fichiers. Cela signifie que les chemins changent en fonction du système d’exploitation sur lequel le code s’exécute.
Environnements sans serveur
Titre de la section Environnements sans serveurDéfinir functionPerRoute : true
dans un environnement sans serveur crée un fichier JavaScript (handler) pour chaque route. Un handler peut avoir différents noms en fonction de votre plateforme d’hébergement : lambda, fonction, page, etc.
Chacunes de ces routes sont soumises à un démarrage à froid lorsque le gestionnaire s’exécute, ce qui peut entraîner un certain retard. Ce retard est influencé par différents facteurs.
Avec functionPerRoute : false
, il n’y a qu’un seul gestionnaire chargé d’afficher toutes vos routes. Lorsque ce gestionnaire est déclenché pour la première fois, vous êtes soumis à un démarrage à froid. Ensuite, tous les autres itinéraires devraient fonctionner sans délai. Cependant, vous perdrez le bénéfice de la division du code que functionPerRoute : true
fournit.
Il est important que vous compreniez votre plateforme d’hébergement et son fonctionnement, afin de choisir la configuration functionPerRoute
appropriée pour votre projet.
edgeMiddleware
Titre de la section edgeMiddlewareDéfinit si le code du middleware SSR sera regroupé lors de la construction.
Lorsque cette option est activée, elle empêche le code du middleware d’être regroupé et importé par toutes les pages au cours de la construction :
Ensuite, utilisez le hook astro:build:ssr
, qui vous donnera un middlewareEntryPoint
, une URL
vers le fichier physique sur le système de fichiers.