0
0
mirror of https://github.com/saltstack-formulas/salt-formula.git synced 2024-12-18 10:32:54 +01:00
Go to file
sticky-note bf52207a9b
Merge pull request #566 from sticky-note/feat/repos
feat(pkgrepo): impl new logic after migration to `packages.broadcom.com`
2024-12-04 08:54:43 +11:00
.github/workflows ci: update pre-commit configuration inc. for pre-commit.ci [skip ci] 2022-06-08 23:53:44 +01:00
bin chore(gemfile.lock): update to latest gem versions (2022-W28) [skip ci] 2022-07-17 19:48:06 +01:00
dev Vagrant Updates: 2019-12-11 19:03:35 +01:00
docs feat(pkgrepo): impl new logic after migration to packages.broadcom.com 2024-11-19 02:16:28 +00:00
salt feat(pkgrepo): impl new logic after migration to packages.broadcom.com 2024-11-19 02:16:28 +00:00
test Merge pull request #538 from llua/fbsd_pkg 2022-08-27 08:04:33 +11:00
.gitignore ci(kitchen+ci): update with latest CVE pre-salted images 2021-10-05 10:49:18 +01:00
.gitlab-ci.yml ci: update container images 2023-12-04 21:00:06 +00:00
.pre-commit-config.yaml test(pre-commit): switch to using pre-commit's built-in file filtering 2023-11-10 14:38:19 +00:00
.rstcheck.cfg chore(pre-commit): use info report level for rstcheck [skip ci] 2021-05-20 14:10:38 +01:00
.rubocop.yml ci: update linters to latest versions [skip ci] 2022-02-12 23:24:17 +00:00
.salt-lint ci(travis): update salt-lint config for v0.0.10 [skip ci] 2019-10-23 17:38:01 +01:00
.travis.yml ci: update pre-commit configuration inc. for pre-commit.ci [skip ci] 2022-06-08 23:53:44 +01:00
.yamllint test(pre-commit): switch to using pre-commit's built-in file filtering 2023-11-10 14:38:19 +00:00
AUTHORS.md chore(release): 1.12.0 [skip ci] 2022-08-26 21:13:26 +00:00
CHANGELOG.md chore(release): 1.12.0 [skip ci] 2022-08-26 21:13:26 +00:00
CODEOWNERS ci: use pillars_from_directories & test/salt/pillar/top.sls 2021-11-17 21:53:16 +00:00
commitlint.config.js chore(commitlint): add {body,footer,header}-max(-line)-length [skip ci] 2020-10-07 09:09:56 +01:00
FORMULA chore(release): 1.12.0 [skip ci] 2022-08-26 21:13:26 +00:00
Gemfile chore(gemfile.lock): update to latest gem versions for 2023-W43 2023-11-01 15:22:29 +00:00
Gemfile.lock chore(gemfile.lock): update to latest gem versions for 2023-W43 2023-11-01 15:22:29 +00:00
kitchen.macos.yml ci(macos): enable testing using GitHub Actions 2022-05-17 09:01:41 +01:00
kitchen.vagrant.yml test(windows): fix URL for winrepos salt-minion.sls` 2022-11-24 23:52:45 +00:00
kitchen.windows.yml test(windows): fix URL for winrepos salt-minion.sls` 2022-11-24 23:52:45 +00:00
kitchen.yml ci: update pre-commit configuration inc. for pre-commit.ci [skip ci] 2022-06-08 23:53:44 +01:00
LICENSE Update LICENSING year 2015-03-20 20:05:04 -04:00
pillar.example feat(pkgrepo): impl new logic after migration to packages.broadcom.com 2024-11-19 02:16:28 +00:00
pre-commit_semantic-release.sh chore(semantic-release): replace broken m2r with m2r2 [skip ci] 2022-01-17 08:16:16 +00:00
release-rules.js docs(semantic-release): implement an automated changelog 2019-05-14 19:21:00 +02:00
release.config.js ci(gitlab-ci): use GitLab CI as Travis CI replacement 2020-12-16 06:58:36 +00:00
Vagrantfile Vagrant Updates: 2019-12-11 19:03:35 +01:00

.. _readme:

salt-formula
============

|img_travis| |img_sr|

.. |img_travis| image:: https://travis-ci.com/saltstack-formulas/salt-formula.svg?branch=master
   :alt: Travis CI Build Status
   :scale: 100%
   :target: https://travis-ci.com/saltstack-formulas/salt-formula
.. |img_sr| image:: https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg
   :alt: Semantic Release
   :scale: 100%
   :target: https://github.com/semantic-release/semantic-release

Yes, Salt can Salt itself!

.. contents:: **Table of Contents**

General notes
-------------

See the full `SaltStack Formulas installation and usage instructions
<https://docs.saltstack.com/en/latest/topics/development/conventions/formulas.html>`_.

If you are interested in writing or contributing to formulas, please pay attention to the `Writing Formula Section
<https://docs.saltstack.com/en/latest/topics/development/conventions/formulas.html#writing-formulas>`_.

If you want to use this formula, please pay attention to the ``FORMULA`` file and/or ``git tag``,
which contains the currently released version. This formula is versioned according to `Semantic Versioning <http://semver.org/>`_.

See `Formula Versioning Section <https://docs.saltstack.com/en/latest/topics/development/conventions/formulas.html#versioning>`_ for more details.

Contributing to this repo
-------------------------

**Commit message formatting is significant!!**

Please see `How to contribute <https://github.com/saltstack-formulas/.github/blob/master/CONTRIBUTING.rst>`_ for more details.

Available states
----------------

.. contents::
   :local:

``salt``
^^^^^^^^

*Meta-state (This is a state that includes other states)*.

This calls all runable states based on configured pillar data.

``salt.minion``
^^^^^^^^^^^^^^^

Install a minion

``salt.master``
^^^^^^^^^^^^^^^

Install a master.

``salt.syndic``
^^^^^^^^^^^^^^^

Install a syndic.

``salt.cloud``
^^^^^^^^^^^^^^

Install salt cloud.

``salt.ssh``
^^^^^^^^^^^^

Install salt-ssh with roster file.
Configure pillar data under salt:ssh_roster to feed the template.

``salt.api``
^^^^^^^^^^^^

Install salt api
Requisite: Configure salt-master with rest_cherrypy or rest_tornado.

``salt.standalone``
^^^^^^^^^^^^^^^^^^^

Install a minion and configure it in `standalone mode
<http://docs.saltstack.com/en/latest/topics/tutorials/standalone_minion.html>`_.

``salt.gitfs.dulwich``
^^^^^^^^^^^^^^^^^^^^^^

Install gitfs backend dulwich dependencies. Set ``salt:master:gitfs_provider: dulwich`` in your pillar.

``salt.gitfs.gitpython``
^^^^^^^^^^^^^^^^^^^^^^^^

Install gitfs backend GitPython dependenciess. Set ``salt:master:gitfs_provider: gitpython`` in your pillar.

``salt.gitfs.keys``
^^^^^^^^^^^^^^^^^^^

Install ssh keys to be used by gitfs

``salt.gitfs.pygit2``
^^^^^^^^^^^^^^^^^^^^^

Install gitfs backend libgit2/pygit2 dependenciess. Set ``salt:master:gitfs_provider: pygit2`` in your pillar.
For EL distributions, pygit is installed from packages from `EPEL <https://github.com/saltstack-formulas/epel-formula>`_.

``salt.pkgrepo``
^^^^^^^^^^^^^^^^

It is recommended to use SaltStack repository for Debian, RedHat, and SuSE, to benefit from the latest stable salt release. Refer to official documentation at <http://docs.saltstack.com/en/latest/topics/installation/index.html#platform-specific-installation-instructions>`_.

``salt.pkgrepo.clean``
^^^^^^^^^^^^^^^^^^^^^^^

Undo the effects of ``salt.pkgrepo`` on Debian, RedHat, and SuSE.

``salt.formulas``
^^^^^^^^^^^^^^^^^

Clone selected `Salt formulas
<http://docs.saltstack.com/en/latest/topics/development/conventions/formulas.html>`_
Git repositories under ``/srv/formulas`` and makes them available in the relevant ``file_roots`` settings. Please note that in order for ``file_roots`` to be updated, ``salt.master`` must be called after ``salt.formulas``. For example:

::

    base:
      'saltmain':
        - salt.formulas
        - salt.master


Pillar data can be used to customize all paths, URLs, etc. Here's a minimal pillar sample installing two formulas in the base environment:

::

    salt_formulas:
      list:
        base:
          - salt-formula
          - openssh-formula

See pillar.example for an exhaustive list of settings available via pillar. Note
that by default this state:

- downloads the latest formulas from the `saltstack-formulas project
  <https://github.com/saltstack-formulas>`_ on GitHub.
- does not update the local repositories after the initial clone.
  This is a safety measure since you do not control how the official
  repositories evolve.

If you configure the state to download the formulas from repositories that
you control, then you can safely enable the
``salt_formulas:git_opts:default:update`` pillar setting to ``True``.


Configuration
-------------

Every option available in the templates can be set in pillar. Settings under 'salt' will be overridden by more specific settings under ``salt['master']``, ``salt['minion']`` or ``salt['cloud']``. Options specified in ``salt['minion']`` which are not present in the default configuration file will be added to the end of the configuration file.

::

    salt:
      ret_port: 4506
      master:
        user: saltuser
        ...
      minion:
        user: saltuser
        ...
      cloud:
        providers: ec2
        ...

Extending
---------

Additional templates can be added by the user under salt/files/minion.d and master.d. This might be useful if, for example, a recently-added configuration option is not yet provided by the default template.

Vagrant
-------

Executing the provided `Vagrantfile <http://www.vagrantup.com/>`_  will create a Ubuntu 14.04 VM, add the default Saltstack Repository and install the current stable version.

The folders inside the VM will be set up in a way that enables you to simply execute 'sudo salt "*" state.highstate' to apply the salt formula to the VM, using the pillar.example config. You can check /etc/salt/ for results.

Remember, you will have to run ``state.highstate`` or ``state.sls salt.(master|minion|cloud)`` manually.

MacOS Support
-------------

As MacOS has no native package management that pkg.installed can leverage appropriately, and brew does not count, the salt.minion state  manages salt minion package upgrades by way of .pkg file download which is then installed using the macpackage.installed state.

salt-minion packages on MacOS will not be upgraded by default. To enable package management you must set the following at a minimum,

::

    install_packages: True
    version: 3006.9
    salt_minion_pkg_source: https://packages.broadcom.com/artifactory/saltproject-generic/macos/3006.9/salt-3006.9-py3-x86_64.pkg

install_packages must indicate that the installation of a package is desired. If so, version will be used to compare the version of the installed .pkg against the downloaded one. If version is not set and a salt.pkg is already installed the .pkg will not be installed again.

A future update to the formula may include extraction of version from the downloaded .pkg itself; but for the time being you MUST set version to indicate what you believe it to be.

Refer to pillar.example for more information.

Testing
-------

Linux testing is done with ``kitchen-salt``.

Requirements
^^^^^^^^^^^^

* Ruby
* Docker

.. code-block:: bash

   $ gem install bundler
   $ bundle install
   $ bin/kitchen test [platform]

Where ``[platform]`` is the platform name defined in ``kitchen.yml``,
e.g. ``debian-9-2019-2-py3``.

``bin/kitchen converge``
^^^^^^^^^^^^^^^^^^^^^^^^

Creates the docker instance and runs the ``salt`` main states, ready for testing.

``bin/kitchen verify``
^^^^^^^^^^^^^^^^^^^^^^

Runs the ``inspec`` tests on the actual instance.

``bin/kitchen destroy``
^^^^^^^^^^^^^^^^^^^^^^^

Removes the docker instance.

``bin/kitchen test``
^^^^^^^^^^^^^^^^^^^^

Runs all of the stages above in one go: i.e. ``destroy`` + ``converge`` + ``verify`` + ``destroy``.

``bin/kitchen login``
^^^^^^^^^^^^^^^^^^^^^

Gives you SSH access to the instance for manual testing.

Testing with Vagrant
--------------------

Windows/FreeBSD/OpenBSD testing is done with ``kitchen-salt``.

Requirements
^^^^^^^^^^^^

* Ruby
* Virtualbox
* Vagrant

Setup
^^^^^

.. code-block:: bash

   $ gem install bundler
   $ bundle install --with=vagrant
   $ bin/kitchen test [platform]

Where ``[platform]`` is the platform name defined in ``kitchen.vagrant.yml``,
e.g. ``windows-81-latest-py3``.

Note
^^^^

When testing using Vagrant you must set the environment variable ``KITCHEN_LOCAL_YAML`` to ``kitchen.vagrant.yml``.  For example:

.. code-block:: bash

   $ KITCHEN_LOCAL_YAML=kitchen.vagrant.yml bin/kitchen test      # Alternatively,
   $ export KITCHEN_LOCAL_YAML=kitchen.vagrant.yml
   $ bin/kitchen test

Then run the following commands as needed.

``bin/kitchen converge``
^^^^^^^^^^^^^^^^^^^^^^^^

Creates the Vagrant instance and runs the ``salt`` main states, ready for testing.

``bin/kitchen verify``
^^^^^^^^^^^^^^^^^^^^^^

Runs the ``inspec`` tests on the actual instance.

``bin/kitchen destroy``
^^^^^^^^^^^^^^^^^^^^^^^

Removes the Vagrant instance.

``bin/kitchen test``
^^^^^^^^^^^^^^^^^^^^

Runs all of the stages above in one go: i.e. ``destroy`` + ``converge`` + ``verify`` + ``destroy``.

``bin/kitchen login``
^^^^^^^^^^^^^^^^^^^^^

Gives you RDP/SSH access to the instance for manual testing.