Configuración del Servidor¶
Usando la imagen de Docker predeterminada, toda la configuración necesaria se puede realizar desde el navegador. Sin embargo, dependiendo del despliegue, puede ser necesario personalizar la configuración del servidor.
Esta página enumera todos los métodos para cambiar la configuración y todas las opciones de configuración existentes.
Archivo de configuración vs. variables de entorno¶
Para la configuración, puedes usar un archivo de configuración o variables de entorno.
Cuando utilizas la configuración basada en Docker Compose, puedes incluir un archivo de configuración añadiendo el siguiente elemento de lista bajo la clave volumes: en el bloque grampsweb::
- /ruta/a/config.cfg:/app/config/config.cfg
/ruta/a/config.cfg es la ruta al archivo de configuración en el sistema de archivos de tu servidor (el lado derecho se refiere a la ruta en el contenedor y no debe ser cambiado).
Al usar variables de entorno,
- prefija cada nombre de configuración con
GRAMPSWEB_para obtener el nombre de la variable de entorno - Usa dobles guiones bajos para configuraciones de diccionario anidadas, por ejemplo
GRAMPSWEB_THUMBNAIL_CACHE_CONFIG__CACHE_DEFAULT_TIMEOUTestablecerá el valor de la opción de configuraciónTHUMBNAIL_CACHE_CONFIG['CACHE_DEFAULT_TIMEOUT']
Ten en cuenta que las opciones de configuración establecidas a través del entorno tienen prioridad sobre las que están en el archivo de configuración. Si ambas están presentes, la variable de entorno "gana".
Configuraciones de configuración existentes¶
Las siguientes opciones de configuración existen.
Configuraciones requeridas¶
| Clave | Descripción |
|---|---|
TREE |
El nombre de la base de datos del árbol genealógico a utilizar. Muestra los árboles disponibles con gramps -l. Si no existe un árbol con este nombre, se creará uno nuevo vacío. |
SECRET_KEY |
La clave secreta para flask. La clave no debe ser compartida públicamente. Cambiarla invalidará todos los tokens de acceso. |
USER_DB_URI |
La URL de la base de datos de usuarios. Se permite cualquier URL compatible con SQLAlchemy. |
Info
Puedes generar una clave secreta segura, por ejemplo, con el comando
python3 -c "import secrets;print(secrets.token_urlsafe(32))"
Configuraciones opcionales¶
| Clave | Descripción |
|---|---|
MEDIA_BASE_DIR |
Ruta a usar como directorio base para archivos multimedia, sobrescribiendo el directorio base de medios establecido en Gramps. Al usar S3, debe tener la forma s3://<bucket_name> |
SEARCH_INDEX_DB_URI |
URL de la base de datos para el índice de búsqueda. Solo se permiten sqlite o postgresql como backends. Por defecto es sqlite:///indexdir/search_index.db, creando un archivo SQLite en la carpeta indexdir relativa a la ruta donde se ejecuta el script |
STATIC_PATH |
Ruta para servir archivos estáticos (por ejemplo, un frontend web estático) |
BASE_URL |
URL base donde se puede acceder a la API (por ejemplo, https://mygramps.mydomain.com/). Esto es necesario, por ejemplo, para construir enlaces correctos de restablecimiento de contraseña |
CORS_ORIGINS |
Orígenes desde los cuales se permiten solicitudes CORS. Por defecto, todos están deshabilitados. Usa "*" para permitir solicitudes de cualquier dominio. |
EMAIL_HOST |
Host del servidor SMTP (por ejemplo, para enviar correos electrónicos de restablecimiento de contraseña) |
EMAIL_PORT |
Puerto del servidor SMTP. por defecto es 465 |
EMAIL_HOST_USER |
Nombre de usuario del servidor SMTP |
EMAIL_HOST_PASSWORD |
Contraseña del servidor SMTP |
EMAIL_USE_TLS |
Obsoleto (usa EMAIL_USE_SSL o EMAIL_USE_STARTTLS en su lugar). Booleano, si se debe usar TLS para enviar correos electrónicos. Por defecto es True. Al usar STARTTLS, establece esto en False y usa un puerto diferente de 25. |
EMAIL_USE_SSL |
Booleano, si se debe usar SSL/TLS implícito para SMTP (v3.6.0+). Por defecto es True si EMAIL_USE_TLS no se establece explícitamente. Típicamente se usa con el puerto 465. |
EMAIL_USE_STARTTLS |
Booleano, si se debe usar STARTTLS explícito para SMTP (v3.6.0+). Por defecto es False. Típicamente se usa con el puerto 587 o 25. |
DEFAULT_FROM_EMAIL |
Dirección "De" para correos electrónicos automatizados |
THUMBNAIL_CACHE_CONFIG |
Diccionario con configuraciones para la caché de miniaturas. Consulta Flask-Caching para posibles configuraciones. |
REQUEST_CACHE_CONFIG |
Diccionario con configuraciones para la caché de solicitudes. Consulta Flask-Caching para posibles configuraciones. |
PERSISTENT_CACHE_CONFIG |
Diccionario con configuraciones para la caché persistente, utilizada por ejemplo para telemetría. Consulta Flask-Caching para posibles configuraciones. |
CELERY_CONFIG |
Configuraciones para la cola de tareas en segundo plano de Celery. Consulta Celery para posibles configuraciones. |
REPORT_DIR |
Directorio temporal donde se almacenará la salida de los informes de Gramps |
EXPORT_DIR |
Directorio temporal donde se almacenará la salida de la exportación de la base de datos de Gramps |
REGISTRATION_DISABLED |
Si True, deshabilita el registro de nuevos usuarios (por defecto False) |
DISABLE_TELEMETRY |
Si True, deshabilita la telemetría de estadísticas (por defecto False). Consulta telemetría para más detalles. |
Info
Al usar variables de entorno para la configuración, las opciones booleanas como EMAIL_USE_TLS deben ser la cadena true o false (sensible a mayúsculas y minúsculas!).
Configuraciones solo para la base de datos backend de PostgreSQL¶
Esto es necesario si has configurado tu base de datos de Gramps para trabajar con el complemento de PostgreSQL.
| Clave | Descripción |
|---|---|
POSTGRES_USER |
El nombre de usuario para la conexión a la base de datos |
POSTGRES_PASSWORD |
La contraseña para el usuario de la base de datos |
Configuraciones relevantes para alojar múltiples árboles¶
Las siguientes configuraciones son relevantes al alojar múltiples árboles.
| Clave | Descripción |
|---|---|
MEDIA_PREFIX_TREE |
Booleano, si se debe usar una subcarpeta separada para los archivos multimedia de cada árbol. Por defecto es False, pero se recomienda encarecidamente usar True en una configuración de múltiples árboles |
NEW_DB_BACKEND |
El backend de base de datos a utilizar para los árboles genealógicos recién creados. Debe ser uno de sqlite, postgresql o sharedpostgresql. Por defecto es sqlite. |
POSTGRES_HOST |
El nombre del host del servidor PostgreSQL utilizado para crear nuevos árboles cuando se utiliza una configuración de múltiples árboles con el backend SharedPostgreSQL |
POSTGRES_PORT |
El puerto del servidor PostgreSQL utilizado para crear nuevos árboles cuando se utiliza una configuración de múltiples árboles con el backend SharedPostgreSQL |
Configuraciones para autenticación OIDC¶
Estas configuraciones son necesarias si deseas usar autenticación OpenID Connect (OIDC) con proveedores externos. Para instrucciones de configuración detalladas y ejemplos, consulta Autenticación OIDC.
| Clave | Descripción |
|---|---|
OIDC_ENABLED |
Booleano, si se debe habilitar la autenticación OIDC. Por defecto es False. |
OIDC_ISSUER |
URL del emisor del proveedor OIDC (para proveedores OIDC personalizados) |
OIDC_CLIENT_ID |
ID de cliente OAuth (para proveedores OIDC personalizados) |
OIDC_CLIENT_SECRET |
Secreto de cliente OAuth (para proveedores OIDC personalizados) |
OIDC_NAME |
Nombre de visualización personalizado para el proveedor. Por defecto es "OIDC" |
OIDC_SCOPES |
Alcances de OAuth. Por defecto es "openid email profile" |
OIDC_USERNAME_CLAIM |
La reclamación a usar para el nombre de usuario. Por defecto es "preferred_username" |
OIDC_OPENID_CONFIG_URL |
Opcional: URL al endpoint de configuración de OpenID Connect (si no se utiliza el estándar /.well-known/openid-configuration) |
OIDC_DISABLE_LOCAL_AUTH |
Booleano, si se debe deshabilitar la autenticación local de nombre de usuario/contraseña. Por defecto es False |
OIDC_AUTO_REDIRECT |
Booleano, si se debe redirigir automáticamente a OIDC cuando solo se configura un proveedor. Por defecto es False |
Proveedores OIDC integrados¶
Para proveedores integrados (Google, Microsoft, GitHub), usa estas configuraciones:
| Clave | Descripción |
|---|---|
OIDC_GOOGLE_CLIENT_ID |
ID de cliente para Google OAuth |
OIDC_GOOGLE_CLIENT_SECRET |
Secreto de cliente para Google OAuth |
OIDC_MICROSOFT_CLIENT_ID |
ID de cliente para Microsoft OAuth |
OIDC_MICROSOFT_CLIENT_SECRET |
Secreto de cliente para Microsoft OAuth |
OIDC_GITHUB_CLIENT_ID |
ID de cliente para GitHub OAuth |
OIDC_GITHUB_CLIENT_SECRET |
Secreto de cliente para GitHub OAuth |
Mapeo de Roles OIDC¶
Estas configuraciones te permiten mapear grupos/roles OIDC de tu proveedor de identidad a roles de usuario de Gramps Web:
| Clave | Descripción |
|---|---|
OIDC_ROLE_CLAIM |
El nombre de la reclamación en el token OIDC que contiene los grupos/roles del usuario. Por defecto es "groups" |
OIDC_GROUP_ADMIN |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Admin" de Gramps |
OIDC_GROUP_OWNER |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Owner" de Gramps |
OIDC_GROUP_EDITOR |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Editor" de Gramps |
OIDC_GROUP_CONTRIBUTOR |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Contributor" de Gramps |
OIDC_GROUP_MEMBER |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Member" de Gramps |
OIDC_GROUP_GUEST |
El nombre del grupo/rol de tu proveedor OIDC que se mapea al rol "Guest" de Gramps |
Configuraciones solo para funciones de IA¶
Estas configuraciones son necesarias si deseas usar funciones impulsadas por IA como chat o búsqueda semántica.
| Clave | Descripción |
|---|---|
LLM_BASE_URL |
URL base para la API de chat compatible con OpenAI. Por defecto es None, lo que utiliza la API de OpenAI. |
LLM_MODEL |
El modelo a usar para la API de chat compatible con OpenAI. Si no se establece (el valor por defecto), el chat está deshabilitado. A partir de la v3.6.0, el asistente de IA utiliza Pydantic AI con capacidades de llamada a herramientas. |
VECTOR_EMBEDDING_MODEL |
El modelo de Sentence Transformers a utilizar para embeddings de vectores de búsqueda semántica. Si no se establece (el valor por defecto), la búsqueda semántica y el chat están deshabilitados. |
LLM_MAX_CONTEXT_LENGTH |
Límite de caracteres para el contexto del árbol genealógico proporcionado al LLM. Por defecto es 50000. |
LLM_SYSTEM_PROMPT |
Prompt del sistema personalizado para el asistente de chat LLM (v3.6.0+). Si no se establece, utiliza el prompt optimizado para genealogía por defecto. |
Ejemplo de archivo de configuración¶
Un archivo de configuración mínimo para producción podría verse así: ```python TREE="Mi Árbol Genealógico" BASE_URL="https://mitree.ejemplo.com" SECRET_KEY="..." # tu clave secreta USER_DB_URI="sqlite:////ruta/a/usuarios.sqlite" EMAIL_HOST="mail.ejemplo.com" EMAIL_PORT=465 EMAIL_USE_SSL=True # Usar SSL implícito para el puerto 465 EMAIL_HOST_USER="gramps@ejemplo.com" EMAIL_HOST_PASSWORD="..." # tu contraseña SMTP DEFAULT_FROM_EMAIL="gramps@ejemplo.com"