Placez votre documentation dans un sous-dossier avec Cloudflare
Suivez ce guide pour héberger votre centre d'aide Ferndesk dans un sous-dossier personnalisé (comme yourdomain.com/help) en utilisant Cloudflare Workers comme proxy inverse.
Cela prend environ 10 minutes et nécessite peu de connaissances techniques. Nous l'avons rédigé pour qu'il soit aussi facile à suivre que possible.
Vous êtes bloqué ? Contactez [email protected] et nous vous aiderons à terminer votre configuration.
Prérequis
Un espace de travail Ferndesk avec un accès administrateur
Un domaine que vous possédez (déjà pointé vers Cloudflare)
Une familiarité de base avec le tableau de bord de Cloudflare
Le forfait gratuit de Cloudflare permet 100 000 requêtes Worker par jour. Pour les centres d'aide en production avec un trafic élevé, envisagez de passer à un forfait payant avec facturation à l'usage.
Étape 1 : Configurer le sous-dossier personnalisé dans Ferndesk
Tout d'abord, configurez votre centre d'aide Ferndesk pour utiliser un chemin de sous-dossier personnalisé.
Connectez-vous à votre espace de travail Ferndesk, développez Help Center dans la barre latérale gauche, puis cliquez sur Customize.
Cliquez sur Custom domain
Sélectionnez l'option Custom sub-folder
Saisissez votre domaine dans le champ Domain (par ex.,
yourdomain.com).Saisissez le chemin du sous-dossier souhaité dans le champ Subdirectory (par ex.,
/helpou/docs).Cliquez sur Configure sub-folder.
Une fois configuré, Ferndesk générera les enregistrements DNS et les informations de point de terminaison nécessaires. Notez ces détails — vous les utiliserez lors de la configuration du proxy inverse.
Étape 2 : Créer un Cloudflare Worker
Créez maintenant un nouveau Cloudflare Worker qui agira comme un proxy inverse.
Connectez-vous à votre tableau de bord Cloudflare.
Sous BUILD → Compute & AI, accédez à Workers & Pages depuis la barre latérale gauche.
Cliquez sur Create application dans le coin supérieur droit.
Sous Start with Hello World!, cliquez sur Get started.
Donnez à votre Worker un nom descriptif comme
ferndesk-reverse-proxy, puis cliquez sur Deploy.
Étape 3 : Configurer les routes du Worker
Configurez la règle de routage qui dirige le trafic de votre sous-dossier personnalisé vers le Cloudflare Worker.
Dans les paramètres du Worker, accédez à l'onglet Settings.
Faites défiler jusqu'à Domains & Routes et cliquez sur Add.
Une fenêtre modale s'ouvrira. Sélectionnez l'option Route.
Dans la liste déroulante Zone, sélectionnez votre domaine (par ex.,
yourdomain.com).Dans le champ Route, saisissez le motif du chemin de votre sous-dossier. Utilisez
yourdomain.com/helppour capturer toutes les requêtes vers le chemin/helpet ses sous-chemins.Laissez le Failure mode réglé sur Fail closed (block) pour des raisons de sécurité.
Cliquez sur Add route.
IMPORTANT : Vous devez ajouter une route séparée pour le répertoire des ressources Ferndesk _ferndesk. Suivez les étapes ci-dessous pour terminer votre configuration.
Étape 3b : Ajouter la route _ferndesk
Faites défiler jusqu'à Domains & Routes et cliquez sur Add.
Une fenêtre modale s'ouvrira. Sélectionnez l'option Route.
Dans la liste déroulante Zone, sélectionnez votre domaine (par ex.,
yourdomain.com).Dans le champ Route, saisissez le motif du chemin de votre sous-dossier. Utilisez
yourdomain.com/_ferndeskpour capturer toutes les requêtes vers le chemin/_ferndesket ses sous-chemins.Laissez le Failure mode réglé sur Fail closed (block) pour des raisons de sécurité.
Cliquez sur Add route.
Étape 4 : Modifier le code du Worker
Mettez maintenant à jour le code du Worker pour gérer la logique du proxy inverse. Le Worker interceptera les requêtes vers votre sous-dossier et les transmettra à Ferndesk.
Cliquez sur Edit code (ou accédez à l'éditeur de code depuis le tableau de bord du Worker).
Remplacez l'intégralité du code
worker.jspar le script de proxy inverse ci-dessous.// ONLY edit these const HELP_HOST = 'your-slug.hc.ferndesk.com'; // your Ferndesk help center host copied from your dashboard const PROXY_PREFIX = '/help'; // the path you want your help center to live on addEventListener('fetch', (event) => { event.respondWith(handleRequest(event.request)); }); async function handleRequest(request) { const originalUrl = new URL(request.url); if (originalUrl.pathname.endsWith('/') && originalUrl.pathname !== '/') { originalUrl.pathname = originalUrl.pathname.slice(0, -1); return Response.redirect(originalUrl.toString(), 301); } if ( originalUrl.pathname !== PROXY_PREFIX && !originalUrl.pathname.startsWith(`${PROXY_PREFIX}/`) && !originalUrl.pathname.startsWith('/_ferndesk/') ) { return fetch(request); } // Build the upstream request with the prefix removed const upstreamUrl = new URL(originalUrl.toString()); upstreamUrl.hostname = HELP_HOST; if (upstreamUrl.pathname === PROXY_PREFIX) { upstreamUrl.pathname = '/'; } else if (upstreamUrl.pathname.startsWith(`${PROXY_PREFIX}/`)) { upstreamUrl.pathname = upstreamUrl.pathname.slice(PROXY_PREFIX.length) || '/'; } const proxyRequest = new Request(upstreamUrl.toString(), request); // CRITICAL: Needed to resolve requests correctly proxyRequest.headers.set('X-Ferndesk-Base-Path', PROXY_PREFIX); proxyRequest.headers.set('X-Forwarded-Host', originalUrl.host); proxyRequest.headers.set('X-Ferndesk-Original-Host', originalUrl.host); return fetch(proxyRequest); }Remplacez
HELP_HOSTpar le domaine Ferndesk réel fourni lors de la configuration de votre sous-dossier personnalisé. RemplacezPROXY_PREFIXsi vous utilisez un chemin de sous-dossier différent (par ex.,/docsau lieu de/help).Cliquez sur Deploy pour publier vos modifications.
Étape 5 : Vérifier la configuration
Vérifiez que votre centre d'aide est désormais accessible via le chemin de votre sous-dossier personnalisé.
Ouvrez un nouvel onglet de navigateur et accédez à
https://yourdomain.com/help.Vous devriez voir votre centre d'aide Ferndesk chargé avec votre image de marque.
Testez quelques pages en cliquant sur des liens pour vous assurer que la navigation fonctionne correctement.
Si votre centre d'aide se charge correctement et affiche votre contenu, le proxy inverse fonctionne bien ! Vos clients peuvent désormais accéder à votre centre d'aide sur votre domaine personnalisé.
Quelque chose ne va pas ? Contactez-nous à [email protected] et nous vous aiderons à terminer votre configuration.
Dépannage
Problème | Cause | Solution |
|---|---|---|
Erreur 404 Not Found lors de la visite de l'URL | La route n'est pas configurée correctement ou le Worker n'est pas déployé | Vérifiez que le motif de la route correspond exactement à votre domaine et au chemin du sous-dossier. Vérifiez que le Worker est déployé et actif dans la section Domains & Routes. |
Page blanche ou mise en forme cassée | Le domaine Ferndesk dans le code du Worker est incorrect | Vérifiez que la variable |
Le CSS et les images ne se chargent pas | Les URL relatives dans la réponse de Ferndesk ne sont pas réécrites | Vous devrez peut-être ajouter la réécriture des en-têtes de réponse pour gérer les ressources relatives. Contactez le support Ferndesk pour une configuration de proxy avancée. |
Requêtes Worker limitées à 100 000/jour | Limite de débit du forfait gratuit Cloudflare atteinte | Passez votre forfait Cloudflare à la facturation à l'usage pour des requêtes illimitées au-delà du niveau gratuit. |