Add a new site for the CSET workflow
====================================

While the localhost site can be used for basic running on a single computer,
sites with a compute cluster will want to setup the CSET cylc workflow to take
advantage of it. This will involve the following steps:

1. Add site file at cset-workflow/site/<site>.cylc
2. Add entry to cset-workflow/meta/rose-meta.conf.jinja2
3. Select site in rose edit.

In this example we will add the site configuration for the fictional ACME
Corporation.

Add site file
-------------

First thing we need to add is a cylc include file to set the default compute
platform for tasks within the CSET workflow. For ACME Corp. we are going to
create a new file at ``cset-workflow/site/acme.cylc`` with the following
content:

.. code-block:: ini

    # Site file for ACME Corporation.
    [runtime]
        [[root]]
        platform = acme-cluster
            [[[directives]]]
            --mem = 2000
            --ntasks = 2

This file is a snippet of cylc code that sets up the basic environment upon
which tasks will run. It sets the ``root`` runtime environment, which all other
tasks will inherit from.

The most important line is ``platform = acme-cluster``, which sets the job
platform that intensive tasks will be submitted to. This will be a site-specific
value that comes from your global cylc configuration. You can list your site's
available platforms with:

.. code-block:: bash

    cylc config --platform-names

The directives control the default resource allocation for the tasks. Most
intensive tasks in CSET will override these, so the default specified here can
remain as a fairly modest allocation with a couple gigabytes of memory.

If required you can also define additional workflow changes in this file, that
will overwrite CSET's flow.cylc file. If you need to make additional changes
please `open an issue on the CSET GitHub repository`_, so we can ensure your use
case is supported directly in CSET.

Add rose edit metadata entry for site
-------------------------------------

With the site file created we now need to add our site to the rose
configuration. This requires editing the metadata at
``cset-workflow/meta/rose-meta.conf.jinja2``. Within that file find the
definition for the SITE variable, and add your site to it. This requires adding
a value that matches the filename (without the ``.cylc`` extension) of your site
file, as well as a value title that is the display name of your site. For ACME
we will adjust it as follows:

.. code-block:: diff

     [template variables=SITE]
     ns=Setup
     title=Site
     description=Which institution to load the site-specific configuration for.
     help=The site-specific configuration should live in a file under site/
         For example the Met Office configuration lives under "site/metoffice.cylc".

         Localhost does not use any site-specific settings, and should work on any
         cylc installation. It will however run on the scheduler server.
    -values="localhost", "metoffice", "niwa"
    +values="localhost", "metoffice", "niwa", "acme"
    -value-titles=Localhost, Met Office, NIWA
    +value-titles=Localhost, Met Office, NIWA, "ACME Corp."
     compulsory=true
     sort-key=aaa

This file is a template, so after changing and saving it we will need to
regenerate the actual rose metadata file. There is a pre-commit hook installed
for this, so it can be done with:

.. code-block:: bash

    pre-commit run --all-files

Select site in rose edit
------------------------

The final step is to select our site to use. This can be done in rose edit, at
the top of the Setup tab. Alternatively the rose-suite.conf can be modified
directly with your site's value:

.. code-block:: text

    SITE="acme"

With that saved you are now ready to run the CSET workflow for your site.

Upstreaming configuration
-------------------------

Once you are happy with your site-specific configuration you may want to save it
to a central location for easy reuse by others using CSET at your site. There
are three options of where to store it, from most preferred:

1. The `main CSET GitHub repository`_.
2. The Momentum Partnership restricted `CSET site-specific config repository`_.
3. Locally at your site.

If you don't mind your site-specific configuration being public the preferred
location is the `main CSET GitHub repository`_. This ensures your configuration will be
distributed with all future versions of CSET, and requires no special access.
Simply follow the :doc:`Developer's Guide </contributing/getting-started>` to
add your site file.

If you would prefer to keep your site-specific configuration non-public, and are
a Momentum Partnership member, we have a designated `CSET site-specific config
repository`_ that contains these configurations for various Momentum Partners.
It is this repository that is installed via the ``install_restricted_files.sh``
script. Even when your file remains restricted like this you should still
contribute your rose metadata changes to the `main CSET GitHub repository`_ so
your site shows up as an option to users.

Finally if neither of the above locations are suitable you can simply
redistribute your site-specific configuration file within your organisation, and
have users manually copy it into the workflow's site directory.

.. _main CSET GitHub repository: https://github.com/MetOffice/CSET
.. _CSET site-specific config repository: https://github.com/MetOffice/CSET-workflow
.. _open an issue on the CSET GitHub repository: https://github.com/MetOffice/CSET/issues