Edit documentation Edit document
SSR/SSG

Config

Every website should have config.mjs in its root folder. This file will help you to configure your website properly.

There is a set of properties that allow you to customize the configuration exactly as you need it. Some of them are mandatory, some are used as needed. In total, there are 6 such properties:


Content


The template config file contains only these three: Auth key, Build folder, Chapters.

Note: All properties from the config file will be passed to the server.
This allows you to securely transfer data to the server and then use it in development. All those properties will be stored in window.constants on the server.


Config structure

Config structure in divided in two types:

  • Server config : store confidential data that is available only in server scope.
  • Client config : store data that used for client render or logic (will be passed to client side, available through window.getConfig()).

But access to server config or client config works in the same way:

window.getConfig()

Let`s see config examples.

./config.mjs file content:

    export { chapters } from './config/chapters.mjs';
    export { routes } from './config/routes.mjs';
    export { components_list } from './config/components-list.mjs';
    export { blog_config } from './config/blog-config.mjs';

    export const build_folder = 'dist';
    export const auth_key = "hVwVL/lcfeDRZcqGkfTapGx9X6QpVbQ/szyK/JWydkekVFmF0gZBQy7KhjtLRnz5bZ";
    export const index_sitemap = true;

    // ClientConfig
    export * as clientConfig from './client-config.mjs';

./client-config.mjs file content:

    export { chapters } from './config/chapters.mjs';

    import { blog_config } from './config/blog-config.mjs';
    import { formConfig } from './config/form-config.mjs';
    import { generalInfo } from './config/general-info.mjs';
    import { menuConfig } from './config/menu-config.mjs';
    import { breadcrumbsConfig } from './config/breadcrumbs-config.mjs';

    export const componentsConfigs = {
        blog_config,
        formConfig,
        generalInfo,
        menuConfig,
        breadcrumbsConfig
    };

    export const multiLanguage = true;
    export const languageList = [
        'uk'
    ];
    export const defaultLanguage = 'uk';

Client-config is imported to main file ./config.mjs ().

This code will destructure clientConfig into serverConfig (so you have access to clientConfig in server environment) :

    const serverConfig = {
        ...config,
        ...config.clientConfig
    }

Server config VS client config

Text


Config properties

This section provides detailed information about all available configuration properties that can be used for a GudHub DXP-based project.


Routes

The first property in this list allows you to configure routes for your website:

export const routes = [
    {
        route: '/example/',
        index: '/example/example.htm'
    },
    {
        route: '/blog/:category/',
        index: '/blog/category.html'
    },
    ...
]

This must be an array of objects, each of which contain route and index properties.

More detailed information can be found in the chapter Routing.


Auth Key

This is a property that is mostly used to securely transmit the authentication key to the server:

export const auth_key = 'kjjjHKSKDJSIOUIO-kJSCNKSJIU';

This auth key will be used while accessing applications and their data on the server side while rendering.

It also sometimes can be used in the sitemap.


Build Folder

This property is used to set the folder for your build:

export const build_folder = 'dist';

If you have a website with a bundler (e.g., webpack), you need to pass your build folder name here. That is, the built files of the site will be stored in this folder.

If you have a simple website, just remove this variable or leave it empty.


Configuration Object for GudHub Initialization

This object is used as a configuration for initializing GudHub.

export const gudhub_db_settings_config = {
    server_url : 'https://example.com/GudHub', 
    wss_url : 'wss://example.com/GudHub/ws/app/', 
    initWebsocket : false
};

If it is not provided, the default configuration will be applied.


Query Params Cache Whitelist

The array stores the keys for query parameters whose corresponding pages will be cached on the server.

export const query_params_cache_whitelist = ['example-type', 'example-status', 'example-color', 'example-price-level'];

This whitelist is a security feature used to control which query parameters are allowed for caching. Only the specified query parameters will be stored in the cache, ensuring efficient retrieval and reducing load times for repeated queries.

If this configuration is not provided, query parameters will not be cached by default. Only parameters listed in this array will be cached, so adding or removing parameters allows you to control what pages are stored on the server for improved performance and data control.


Index Sitemap

The current property allows you to determine whether a sitemap index will be created or not:

export const index_sitemap = true;

If index_sitemap is set to true, the server will generate an index sitemap and child sitemaps based on the chapter sitemap configuration.

If this property is false, the server will generate a single sitemap with all pages.


Website Name

This property is designed to set the name of the website:

export const website_name = 'Atlasiko';

This value will be used as the title in feeds (RSS, Atom, JSON). To learn more about feeds, see chapters configuration.


Website Description

This is the property that allows you to use descriptions:

export const website_description = 'Example of website description.'

When you set a specific description, it can be used as a title in feeds (RSS, Atom, JSON). For more information about channels, see Chapters.


Chapters

The current property contains all chapters of the site with their properties.

It is one of the mandatory properties.

Here you can add new chapters or delete existing ones:

export const chapters = {
    pages: {
        app_id: 00000,
        slug_field_id: 000000,
        element_id: 000000,
        title_field_id: 000000,
        description_field_id: 000000,
        thumbnail_field_id: 000000,
        created_at_field_id: 000000,
        author_reference_field_id: 000000,
        sitemap: {
            frequency: 'weekly',
            priority: 0.8,
            sitemapName: 'pages',
            cases: [
                {
                    case: '/',
                    priority: 1,
                    frequency: 'daily'
                },
                {
                    case: /example/g,
                    priority: 0.2,
                    frequency: 'weekly',
                    sitemapName: 'examples'
                }
            ],
            filter: (items) => {
                return items.filter(item => {
                    const field = item.fields.find(field => field.field_id == 699138);
                    if(field) {
                        return field.field_value == 1;
                    }
                    return false;
                });
            }
        },
        feed: {
            google_news: {
                filter: (items) => {
                    let filteredItems = items.filter(item => {
                        const field = item.fields.find(field => field.field_id == 697704);
                        if(field) {
                            return field.field_value == 1;
                        }
                        return false;
                    });

                    filteredItems = filteredItems.filter(item => {
                        const field = item.fields.find(field => field.field_id == 698599);
                        if(field) {
                            return field.field_value == 3;
                        }
                        return true;
                    });

                    return filteredItems;
                }
            }
        }
    }
}

A Chapter is an object that stores chapters as properties. Each chapter has its own set of properties, which are stored in the object as well. There are only two mandatory properties:

Property Name Type Description
app_id number app id of application for this chapter
slug_field_id number field id of field with slug (url) of page

All other properties are optional:

Property Name Type Description
json_field_id number field id of field with data (json editor data type)
title_field_id number field id of field with page title (text). Will be used in feed generation
description_field_id number field id of field with page description (text editor). Will be used in feed generation
thumbnail_field_id number field id of field with thumbnail path (text). Will be used in feed generation
created_at_field_id number field id of field with created at date (date). Will be used in feed generation
author_reference-field_id number field id with reference to page author. Author item should be in the same application as pages. Will be used in feed generation
sitemap object configuration object for sitemap
feed object if you want to generate feed (rss, atom, json), you should add this property to chapter, you want to generate feed for. Currently, we support only one feed for one chapter per website

If you want some sort of CMS, you need to create GudHub application for your website.

It will be better, to create separate application for every logical part of website (simple pages, blog, products, etc.). Every item in these applications will be page in future. For every application you need to create object in chapters object like above.

Sitemap

The sitemap is a list of information about pages, video, and other file on your site. In the config file, this sitemap is specified as a property of chapters. But it also has its own properties:

export const chapters = {
    pages: {
        app_id: 00000,
        slug_field_id: 000000,
        sitemap: {
            frequency: 'weekly',
            priority: 0.8,
            sitemapName: 'pages',
            cases: [
                {
                    case: '/',
                    priority: 1,
                    frequency: 'daily'
                },
                {
                    case: /example/g,
                    priorite: 0.2,
                    frequency: 'weekly',
                    sitemapName: 'examples'
                }
            ],
            filter: (items) => {
                return items.filter(item => {
                    const field = item.fields.find(field => field.field_id == 699138);
                    if(field) {
                        return field.field_value == 1;
                    }
                    return false;
                });
            }
        }
    }
}
Property Name Type Description
frequency string default frequency for all pages
priority number default priority for all pages
sitemapName string if you set index_sitemap to true, this property will generate separate sitemap for pages from this chapter and adds link to it in index sitemap
cases array array of special cases. If some pages must have different properties in sitemap from other in this chapter, you should create cases for this pages. In example above we change priority and frequency for homepage and example page
filter function if you want to filter some pages, to not add them to sitemap, you can create filter. Filter property receive javascript function and run it. In example above, we are filtering all pages, that have status property equal to 'draft' in gudhub

As mentioned above, an object called cases has its own set of properties:

Property Name Type Description
case string for which page this case should work. Cat receive string with slug or regular expression
priority number value of priority for this case
frequency string value of frequency for this case
sitemapName string if you want to create separate sitemap for this case(s), you can pass it's name here. Then, separate sitemap with given name will be generated, and all pages that meet the condition will be added in it. Also, this pages will be removed from parent sitemap, to avoid the duplicates

Feed

This property allows you to create RSS for the specific chapter.

It can be used for only one chapter within an array.

To create a feed you need the google_news inside the feed object, chapter properties:

  • app_id
  • slug_field_id
  • element_id
  • title_field_id
  • description_field_id
  • thumbnail_field_id

And two config properties: Website Name and Website Description. The feed object has its own properties:

export const chapters = {
    pages: {
        app_id: 00000,
        slug_field_id: 000000,
        element_id: 000000,
        title_field_id: 000000,
        description_field_id: 000000,
        thumbnail_field_id: 000000,
        created_at_field_id: 000000,
        feed: {
            google_news: {
                filter: (items) => {
                    let filteredItems = items.filter(item => {
                        const field = item.fields.find(field => field.field_id == 697704);
                        if(field) {
                            return field.field_value == 1;
                        }
                        return false;
                    });

                    filteredItems = filteredItems.filter(item => {
                        const field = item.fields.find(field => field.field_id == 698599);
                        if(field) {
                            return field.field_value == 3;
                        }
                        return true;
                    });

                    return filteredItems;
                }
            }
        }
    }
}
Property Name Type Description
google_news object name of service to generate feed for. Currently, only google news is supported, so if you want to generate feed, you should add this property
filter function if you want to filter some pages, to not add them to feed, you can create filter. Filter property receive javascript function and run it. In example above, we are filtering all pages, that have status property equal to 'draft' and in next step filtering all pages, that have status not equal no "News" in gudhub app

Usually, you only need to create a google_news. The filter only further filters the pages. When you create a feed, you create three types of feeds at the same time: RSS, Atom, and JSON.

Redirects

The last property allows you to create redirects to any page:

export const redirects = [
    {
        from: '/example/',
        to: '/example-2/'
    }
]
Property Name Type Description
from string the route from which redirects will be made
to string the route to which redirects will be made

Here you can create redirects for your website. Redirects property is an array of objects. Each object should has from and to properties. All redirects will have 300 status (moved permanently).