Ferndesk
Subcarpetas personalizadas

Pon tu documentación en una subcarpeta con Cloudflare

Sigue esta guía para alojar tu centro de ayuda de Ferndesk en una subcarpeta personalizada (como yourdomain.com/help) utilizando Cloudflare Workers como un proxy inverso.

Esto toma aproximadamente 10 minutos y requiere pocos conocimientos técnicos. Lo hemos escrito para que sea lo más fácil de seguir posible.

¿Te has quedado atascado? Contacta con [email protected] y te ayudaremos a completar tu configuración.

Requisitos previos

  • Un espacio de trabajo de Ferndesk con acceso de administrador

  • Un dominio de tu propiedad (ya apuntado a Cloudflare)

  • Familiaridad básica con el panel de control de Cloudflare

El plan gratuito de Cloudflare permite 100,000 solicitudes de Worker al día. Para centros de ayuda en producción con mucho tráfico, considera actualizar a un plan de pago con facturación por uso.

Paso 1: Configurar la subcarpeta personalizada en Ferndesk

Primero, configura tu centro de ayuda de Ferndesk para usar una ruta de subcarpeta personalizada.

  1. Inicia sesión en tu espacio de trabajo de Ferndesk, expande Help Center en la barra lateral izquierda y haz clic en Customize.

  2. Haz clic en Custom domain

  3. Selecciona la opción Custom sub-folder

  4. Introduce tu dominio en el campo Domain (por ejemplo, yourdomain.com).

  5. Introduce la ruta de la subcarpeta deseada en el campo Subdirectory (por ejemplo, /help o /docs).

  6. Haz clic en Configure sub-folder.

Una vez configurado, Ferndesk generará los registros DNS y la información del endpoint necesarios. Anota estos detalles; los utilizarás al configurar el proxy inverso.

Paso 2: Crear un Cloudflare Worker

Ahora crea un nuevo Cloudflare Worker que actuará como un proxy inverso.

  1. Inicia sesión en tu panel de control de Cloudflare.

  2. Bajo BUILD Compute & AI, navega a Workers & Pages desde la barra lateral izquierda.

    Panel de control de Cloudflare mostrando la opción de menú Workers & Pages resaltada en la barra lateral izquierda bajo la sección BUILD
  3. Haz clic en Create application en la esquina superior derecha.

    Panel de control de Cloudflare Workers & Pages con el botón Create application visible en la parte superior derecha
  4. Bajo Start with Hello World!, haz clic en Get started.

  5. Ponle a tu Worker un nombre descriptivo como ferndesk-reverse-proxy y haz clic en Deploy.

Paso 3: Configurar las rutas del worker

Configura la regla de enrutamiento que dirige el tráfico desde tu subcarpeta personalizada al Cloudflare Worker.

  1. En la configuración del Worker, navega a la pestaña Settings.

  2. Desplázate hasta Domains & Routes y haz clic en Add.

  3. Se abrirá una ventana modal. Selecciona la opción Route.

    Diálogo modal para configurar dominios y rutas con la opción Route resaltada
  4. En el menú desplegable Zone, selecciona tu dominio (por ejemplo, yourdomain.com).

  5. En el campo Route, introduce el patrón para la ruta de tu subcarpeta. Usa yourdomain.com/help para capturar todas las solicitudes a la ruta /help y sus subrutas.

  6. Deja Failure mode establecido en Fail closed (block) por seguridad.

  7. Haz clic en Add route.

    Modal de configuración de ruta que muestra la zona establecida en yourdomain.com y el patrón de ruta establecido en *yourdomain.com/help* con opciones de modo de fallo

IMPORTANTE: Debes añadir una ruta separada para el directorio de recursos de Ferndesk _ferndesk. Sigue los pasos a continuación para completar tu configuración.

Paso 3b: Añadir la ruta _ferndesk

  1. Desplázate hasta Domains & Routes y haz clic en Add.

  2. Se abrirá una ventana modal. Selecciona la opción Route.

    Diálogo modal para configurar dominios y rutas con la opción Route resaltada
  3. En el menú desplegable Zone, selecciona tu dominio (por ejemplo, yourdomain.com).

  4. En el campo Route, introduce el patrón para la ruta de tu subcarpeta. Usa yourdomain.com/_ferndesk para capturar todas las solicitudes a la ruta /_ferndesk y sus subrutas.

  5. Deja Failure mode establecido en Fail closed (block) por seguridad.

  6. Haz clic en Add route.

Paso 4: Editar el código del Worker

Ahora actualiza el código del Worker para gestionar la lógica del proxy inverso. El Worker interceptará las solicitudes a tu subcarpeta y las reenviará a Ferndesk.

  1. Haz clic en Edit code (o accede al editor de código desde el panel del Worker).

  2. Sustituye todo el código de worker.js por el script de proxy inverso que aparece a continuación.

    // 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);
    }

    Sustituye HELP_HOST por el dominio real de Ferndesk proporcionado al configurar tu subcarpeta personalizada. Sustituye PROXY_PREFIX si utilizas una ruta de subcarpeta diferente (por ejemplo, /docs en lugar de /help).

  3. Haz clic en Deploy para publicar tus cambios.

Paso 5: Verificar la configuración

Comprueba que ahora se puede acceder a tu centro de ayuda en la ruta de tu subcarpeta personalizada.

  1. Abre una nueva pestaña en el navegador y navega a https://yourdomain.com/help.

  2. Deberías ver tu centro de ayuda de Ferndesk cargado con tu imagen de marca.

  3. Prueba algunas páginas haciendo clic en los enlaces para asegurarte de que la navegación funciona correctamente.

Si tu centro de ayuda se carga correctamente y muestra tu contenido, ¡el proxy inverso está funcionando bien! Tus clientes ya pueden acceder a tu centro de ayuda en tu dominio personalizado.

¿Algo ha ido mal? Contáctanos en [email protected] y te ayudaremos a completar tu configuración.

Solución de problemas

Problema

Causa

Solución

Error 404 Not Found al visitar la URL

La ruta no está configurada correctamente o el Worker no se ha desplegado

Verifica que el patrón de la ruta coincida exactamente con tu dominio y la ruta de la subcarpeta. Comprueba que el Worker esté desplegado y activo en la sección Domains & Routes.

Página en blanco o diseño roto

El dominio de Ferndesk en el código del Worker es incorrecto

Verifica que la variable ferndesk_host en el código de tu Worker coincida con el dominio proporcionado por Ferndesk. Despliega el código corregido.

No se cargan el CSS ni las imágenes

Las URL relativas en la respuesta de Ferndesk no se están reescribiendo

Es posible que debas añadir la reescritura de encabezados de respuesta para gestionar los recursos relativos. Contacta con el soporte de Ferndesk para una configuración avanzada del proxy.

Solicitudes del Worker limitadas a 100,000/día

Se ha alcanzado el límite de velocidad del plan gratuito de Cloudflare

Actualiza tu plan de Cloudflare a la facturación por uso para obtener solicitudes ilimitadas más allá del nivel gratuito.

¿Te fue útil?