..
      Copyright 2015 Spanish National Research Council

      Licensed under the Apache License, Version 2.0 (the "License"); you may
      not use this file except in compliance with the License. You may obtain
      a copy of the License at

          http://www.apache.org/licenses/LICENSE-2.0

      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
      WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
      License for the specific language governing permissions and limitations
      under the License.

Configuration
*************

OpenStack Configuration
=======================

Publishing benchmark information
--------------------------------

Starting with the V0.4 of the accounting record it is possible to publish
benchmark information. In order to do so, you need to add this information to
the flavor properties and configure caso to retrieve this information. There
are two different values that need to be added to the flavor:

* The benchmark name, indicated with the ``benchmark_name`` flavor property.
* The benchmark value, indicated with the ``benchmark_value`` flavor property.

So, if you are using HEPSPEC06 and the benchmark value is ``99`` for the flavor
``m1.foo`` you should set this as follows::

    openstack flavor set --property benchmark_name="HEPSPEC06" --property benchkark_value=99 m1.foo

Using different keys
~~~~~~~~~~~~~~~~~~~~

If you do not want to use the default flavor properties ``benchmark_name`` and
``benchkark_value`` (for example because you are using different benchmark types
and values) you can specify which properties ``cASO`` should look for by using
the ``benchmark_name_key`` ``benchkark_value_key`` in the configuration file.

User credentials
----------------

The user configured in the previous section has to be a member of each of the
tenants (another option is to convert that user in an administrator, but the
former option is a safer approach) for which it is extracting the accounting.
Otherwise, ``cASO`` will not be able to get the usages and will fail::

    openstack role create accounting
    openstack user create --password <password> accounting
    # For each of the tenants, add the user with the accounting role
    openstack role add --user accounting --project <project> accounting

Also, this user needs access to Keystone so as to extract the users
information.

* If you are using the V2 identity API, you have to give admin rights to the
  ``accounting`` user, editing the ``/etc/keystone/policy.json`` file and
  replacing the line::

      "admin_required": "role:admin or is_admin:1 or",

  with::

      "admin_required": "role:admin or is_admin:1 or role:accounting",

* If you are using the V3 identity API you can grant the user just the rights
  for listing the users adding the appropriate rules in the
  ``/etc/keystone/policy.json``.

cASO configuration
==================

``cASO`` uses a config file (default at ``/etc/caso/caso.conf``) with several
sections. A sample file is available at ``etc/caso/caso.conf.sample``.

``[DEFAULT]`` section
---------------------

The ``[DEFAULT]`` section configures the basic behavior of ``cASO``. The sample
config file (``/etc/caso/caso.conf.sample``) includes a description
of every option. You should check at least the following options:

* ``extractor`` (default value: ``nova``), specifies which extractor to use for
  getting the data. The following APIs are supported: ``ceilomenter`` and
  ``nova``. Both should generate equivalent information.
* ``site_name`` (default value: ``<None>``). Name of the site as defined in
  GOCDB.
* ``service_name`` (default value: ``$site_name``). Name of the service within
  a site. This is used if you have several endpoints within your site.
* ``tenants`` (list value, default empty). List of the tenants to extract
  records from.
* ``messengers`` (list, default: ``caso.messenger.noop.NoopMessenger``). List
  of the messengers to publish data to. Valid messenges are:
    * ``caso.messenger.ssm.SSMMessengerV02`` for publishing APEL V0.2 records.
    * ``caso.messenger.ssm.SSMMessengerV04`` for publishing APEL V0.4 records.
    * ``caso.messenger.logstash.LogstashMessenger`` for publishing to Logstash.
* ``mapping_file`` (default: ``/etc/caso/voms.json``). File containing the
  mapping from VOs to local tenants as configured in Keystone-VOMS, in the
  form::
    {
        "VO": {
            "tenants": ["foo", "bar"],
        }
    }
* ``benchmark_name_key`` and ``benchmark_value_key``. These two configuration
  options are used by ``cASO`` to retrieve the benchmark information form the
  OpenStack flavors.

``[keystone_auth]`` section
---------------------------

This section is used to specify the authentication credentials to be used to
connect to the OpenStack APIs. cASO leverages the `OpenStack keystoneauth
<https://docs.openstack.org/developer/keystoneauth/>`_ library for
authentication, so that it is possible to use any authentication plugin that is
available there (so starting on version 1.0 of cASO it is possible to use the
Keystone V3 API).


.. important::
   You need to specify the ``auth_type`` that you want to use (normally
   ``v3password`` is a good choice.

   For an exhaustive list of available plugins please refer to the
   `keystoneauth <http://docs.openstack.org/developer/keystoneauth/plugin-options.html#available-plugins>`_
   documentation.

``[ssm]`` section
-----------------

Options defined here configure the SSM messenger. There is only one option
at the moment:

* ``output_path`` (default: ``/var/spool/apel/outgoing/openstack``), directory
  to put the generated SSM records. APEL/SSM should be configured to take
  records from that directory.

``[logstash]`` section
----------------------

Options defined here configure the `logstash <https://www.elastic.co/products/logstash>`_
messenger. Available options:

* ``host`` (default: ``localhost``), host of Logstash server.
* ``port`` (default: ``5000``), Logstash server port.
