From a706dcf6a9b91ef2c3d1e1d28449b9b8e0e8187d Mon Sep 17 00:00:00 2001 From: IwanIDev Date: Thu, 19 Mar 2026 20:16:23 +0000 Subject: Add support for headless Drupal integration with environment variables and Docker setup - Create .env.example for environment variable configuration - Update Dockerfile to accept Drupal-related build arguments - Enhance docker_build.yml to pass environment variables during Docker build - Add drupalClient and env configuration for API interaction - Implement local development instructions and Docker deployment steps in README - Add drupal and mariadb services to docker-stack.yml for complete setup - Update package.json and bun.lock to include axios and drupal-jsonapi-params dependencies - Add TypeScript definitions for new environment variables --- src/config/env.ts | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 src/config/env.ts (limited to 'src/config/env.ts') diff --git a/src/config/env.ts b/src/config/env.ts new file mode 100644 index 0000000..c530b3a --- /dev/null +++ b/src/config/env.ts @@ -0,0 +1,23 @@ +const trimTrailingSlashes = (value: string): string => value.replace(/\/+$/, '') + +const normalizePathPrefix = (value: string): string => { + if (!value) { + return '/jsonapi' + } + + return value.startsWith('/') ? value : `/${value}` +} + +export const drupalEnv = { + baseUrl: trimTrailingSlashes(import.meta.env.VITE_DRUPAL_BASE_URL ?? ''), + apiPrefix: normalizePathPrefix(import.meta.env.VITE_DRUPAL_API_PREFIX ?? '/jsonapi'), + authToken: import.meta.env.VITE_DRUPAL_AUTH_TOKEN ?? '', +} + +export const getDrupalApiBaseUrl = (): string => { + if (!drupalEnv.baseUrl) { + throw new Error('Missing VITE_DRUPAL_BASE_URL. Set it in your environment before using the Drupal client.') + } + + return `${drupalEnv.baseUrl}${drupalEnv.apiPrefix}` +} -- cgit