mirror of
https://github.com/saltstack-formulas/postgres-formula.git
synced 2025-04-10 23:01:45 +00:00
Enhance remove S/W support
This commit is contained in:
parent
332fe7b2b5
commit
9d2f69a865
10 changed files with 242 additions and 39 deletions
31
README.rst
31
README.rst
|
@ -31,7 +31,7 @@ Creates such DB objects as: users, tablespaces, databases, schemas and extension
|
|||
See ``pillar.example`` file for details.
|
||||
|
||||
``postgres.python``
|
||||
-------------------
|
||||
----------------------
|
||||
|
||||
Installs the PostgreSQL adapter for Python on Linux.
|
||||
|
||||
|
@ -83,11 +83,36 @@ The state relies on the ``postgres:use_upstream_repo`` Pillar value which could
|
|||
The ``postgres:version`` Pillar controls which version of the PostgreSQL packages should be
|
||||
installed from the upstream Linux repository. Defaults to ``9.5``.
|
||||
|
||||
|
||||
Removal states
|
||||
===============
|
||||
|
||||
``postgres.dropped``
|
||||
--------------------
|
||||
|
||||
Meta state to remove Postgres software. By default the release specified, or installed by, the formula is targeted only. To target multiple releases, set pillar ``postgres.removal.multiple_releases: True``.
|
||||
|
||||
``postgres.server.remove``
|
||||
------------------------
|
||||
|
||||
Remove server, lib, and contrib packages. The ``postgres.server.remove`` will retain data by default (no data loss) - set pillar ``postgres.remove.data: True`` to remove data and configuration directories also.
|
||||
|
||||
``postgres.client.remove``
|
||||
------------------------
|
||||
|
||||
Remove client package.
|
||||
|
||||
``postgres.dev.remove``
|
||||
----------------------
|
||||
|
||||
Remove development and python packages.
|
||||
|
||||
|
||||
Testing
|
||||
=======
|
||||
The postgres state was tested on MacOS (El Capitan 10.11.6)
|
||||
The ``postgres`` state was tested on MacOS (El Capitan 10.11.6), and ``remove`` states on Ubuntu, Centos, and Fedora.
|
||||
|
||||
Testing is done with the ``kitchen-salt``.
|
||||
Linux testing is done with the ``kitchen-salt``.
|
||||
|
||||
``kitchen converge``
|
||||
--------------------
|
||||
|
|
|
@ -184,4 +184,9 @@ postgres:
|
|||
maintenance_db: db1
|
||||
#postgis: {}
|
||||
|
||||
remove:
|
||||
data: True
|
||||
multiple_releases: True
|
||||
releases: ['9.6', '10',]
|
||||
|
||||
# vim: ft=yaml ts=2 sts=2 sw=2 et
|
||||
|
|
47
postgres/client/remove.sls
Normal file
47
postgres/client/remove.sls
Normal file
|
@ -0,0 +1,47 @@
|
|||
{%- from "postgres/map.jinja" import postgres with context -%}
|
||||
|
||||
#remove release installed by formula
|
||||
postgresql-client-removed:
|
||||
pkg.removed:
|
||||
- pkgs:
|
||||
{% if postgres.pkg_client %}
|
||||
- {{ postgres.pkg_client }}
|
||||
{% endif %}
|
||||
|
||||
{%- if postgres.remove.multiple_releases %}
|
||||
#search for and cleandown multiple releases
|
||||
|
||||
{% for release in postgres.remove.releases %}
|
||||
{% if 'bin_dir' in postgres %}
|
||||
{%- for bin in postgres.client_bins %}
|
||||
{% set path = '/usr/pgsql-' + release|string + '/bin/' + bin %}
|
||||
|
||||
postgresql{{ release }}-client-{{ bin }}-alternative-remove:
|
||||
alternatives.remove:
|
||||
- name: {{ bin }}
|
||||
- path: {{ path }}
|
||||
{% if grains.os in ('Fedora', 'CentOS',) %}
|
||||
{# bypass bug #}
|
||||
- onlyif: alternatives --display {{ bin }}
|
||||
{% else %}
|
||||
- onlyif: test -f {{ path }}
|
||||
{% endif %}
|
||||
- require_in:
|
||||
- pkg: postgresql{{ release }}-client-pkgs-removed
|
||||
{%- endfor %}
|
||||
{%- endif %}
|
||||
|
||||
postgresql{{ release }}-client-pkgs-removed:
|
||||
pkg.purged:
|
||||
- pkgs:
|
||||
- postgresql
|
||||
- postgresql-{{ release }}
|
||||
- postgresql-{{ release|replace('.', '') }}
|
||||
- postgresql{{ release }}-common
|
||||
- postgresql{{ release }}-jdbc
|
||||
- postgresql{{ release }}
|
||||
- postgresql{{ release|replace('.', '') }}
|
||||
|
||||
{% endfor %}
|
||||
|
||||
{%- endif %}
|
|
@ -80,3 +80,8 @@ postgres:
|
|||
linux:
|
||||
#Alternatives system are disabled by a 'altpriority=0' pillar.
|
||||
altpriority: 0
|
||||
|
||||
remove:
|
||||
data: False
|
||||
multiple_releases: False
|
||||
releases: ['9.2', '9.3', '9.4', '9.5', '9.6', '10',]
|
||||
|
|
|
@ -23,7 +23,11 @@ postgresql-{{ bin }}-altinstall:
|
|||
- link: {{ salt['file.join']('/usr/bin', bin) }}
|
||||
- path: {{ path }}
|
||||
- priority: {{ postgres.linux.altpriority }}
|
||||
{% if grains.os in ('Fedora', 'CentOS',) %} {# bypass bug #}
|
||||
- onlyif: alternatives --display {{ bin }}
|
||||
{% else %}
|
||||
- onlyif: test -f {{ path }}
|
||||
{% endif %}
|
||||
|
||||
{%- endfor %}
|
||||
{%- endif %}
|
||||
|
|
55
postgres/dev/remove.sls
Normal file
55
postgres/dev/remove.sls
Normal file
|
@ -0,0 +1,55 @@
|
|||
{%- from "postgres/map.jinja" import postgres with context -%}
|
||||
|
||||
# remove release installed by formula
|
||||
postgresql-devel-removed:
|
||||
pkg.removed:
|
||||
- pkgs:
|
||||
{% if postgres.pkg_dev %}
|
||||
- {{ postgres.pkg_dev }}
|
||||
{% endif %}
|
||||
{% if postgres.pkg_libpq_dev %}
|
||||
- {{ postgres.pkg_libpq_dev }}
|
||||
{% endif %}
|
||||
{% if postgres.pkg_python %}
|
||||
- {{ postgres.pkg_python }}
|
||||
{% endif %}
|
||||
|
||||
{%- if postgres.remove.multiple_releases %}
|
||||
#search for and cleandown multiple releases
|
||||
|
||||
{% for release in postgres.remove.releases %}
|
||||
{% if 'bin_dir' in postgres %}
|
||||
{%- for bin in postgres.dev_bins %}
|
||||
{% set path = '/usr/pgsql-' + release|string + '/bin/' + bin %}
|
||||
|
||||
postgresql{{ release }}-devel-{{ bin }}-alternative-remove:
|
||||
alternatives.remove:
|
||||
- name: {{ bin }}
|
||||
- path: {{ path }}
|
||||
{% if grains.os in ('Fedora', 'CentOS',) %}
|
||||
{# bypass bug #}
|
||||
- onlyif: alternatives --display {{ bin }}
|
||||
{% else %}
|
||||
- onlyif: test -f {{ path }}
|
||||
{% endif %}
|
||||
- require_in:
|
||||
- pkg: postgresql{{ release }}-devel-pkgs-removed
|
||||
{%- endfor %}
|
||||
{%- endif %}
|
||||
|
||||
postgresql{{ release }}-devel-pkgs-removed:
|
||||
pkg.purged:
|
||||
- pkgs:
|
||||
- postgresql-dev
|
||||
- postgresql-dev-{{ release|replace('.', '') }}
|
||||
- postgresql-server-dev
|
||||
- postgresql-server-dev-{{ release|replace('.', '') }}
|
||||
- postgresql{{ release }}-jdbc
|
||||
- postgresql{{ release|replace('.', '') }}-jdbc
|
||||
- postgresql-{{ release }}
|
||||
- postgresql-{{ release|replace('.', '') }}
|
||||
- {{ postgres.pkg_python or "postgresql-python" }}
|
||||
|
||||
{% endfor %}
|
||||
|
||||
{%- endif %}
|
|
@ -1,32 +1,5 @@
|
|||
{% from tpldir + "/map.jinja" import postgres with context %}
|
||||
|
||||
postgresql-dead:
|
||||
service.dead:
|
||||
- name: {{ postgres.service }}
|
||||
|
||||
postgresql-removed:
|
||||
pkg.removed:
|
||||
- pkgs:
|
||||
{% if postgres.pkg %}
|
||||
- {{ postgres.pkg }}
|
||||
{% endif %}
|
||||
{% if postgres.pkg_client %}
|
||||
- {{ postgres.pkg_client }}
|
||||
{% endif %}
|
||||
{% if postgres.pkg_dev %}
|
||||
- {{ postgres.pkg_dev }}
|
||||
{% endif %}
|
||||
{% if postgres.pkg_libpq_dev %}
|
||||
- {{ postgres.pkg_libpq_dev }}
|
||||
{% endif %}
|
||||
{% if postgres.pkgs_extra %}
|
||||
{% for pkg in postgres.pkgs_extra %}
|
||||
- {{ pkg }}
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
postgres-dir-absent:
|
||||
file.absent:
|
||||
- names:
|
||||
- {{ postgres.conf_dir }}
|
||||
- {{ postgres.data_dir }}
|
||||
include:
|
||||
- postgres.server.remove
|
||||
- postgres.client.remove
|
||||
- postgres.dev.remove
|
||||
|
|
|
@ -3,5 +3,7 @@
|
|||
Fedora:
|
||||
pkg_repo:
|
||||
baseurl: 'https://download.postgresql.org/pub/repos/yum/{{ repo.version }}/fedora/fedora-$releasever-$basearch'
|
||||
remove:
|
||||
releases: ['9.4', '9.5', '9.6', '10',]
|
||||
|
||||
# vim: ft=sls
|
||||
|
|
|
@ -36,10 +36,10 @@ postgresql-server:
|
|||
- group: wheel
|
||||
- require_in:
|
||||
- service: postgresql-running
|
||||
{%- else %}
|
||||
|
||||
|
||||
# Alternatives system. Make server binaries available in $PATH
|
||||
{%- if 'bin_dir' in postgres and postgres.linux.altpriority %}
|
||||
{%- elif 'bin_dir' in postgres and postgres.linux.altpriority %}
|
||||
{%- for bin in postgres.server_bins %}
|
||||
{%- set path = salt['file.join'](postgres.bin_dir, bin) %}
|
||||
|
||||
|
@ -56,9 +56,7 @@ postgresql-{{ bin }}-altinstall:
|
|||
- cmd: postgresql-cluster-prepared
|
||||
|
||||
{%- endfor %}
|
||||
{%- endif %}
|
||||
|
||||
{%- endif %}
|
||||
{%- endif %}
|
||||
|
||||
postgresql-cluster-prepared:
|
||||
file.directory:
|
||||
|
|
89
postgres/server/remove.sls
Normal file
89
postgres/server/remove.sls
Normal file
|
@ -0,0 +1,89 @@
|
|||
{%- from "postgres/map.jinja" import postgres with context %}
|
||||
|
||||
postgresql-dead:
|
||||
service.dead:
|
||||
- name: {{ postgres.service }}
|
||||
- enable: False
|
||||
|
||||
postgresql-repo-removed:
|
||||
pkgrepo.absent:
|
||||
- name: {{ postgres.pkg_repo.name }}
|
||||
{%- if 'pkg_repo_keyid' in postgres %}
|
||||
- keyid: {{ postgres.pkg_repo_keyid }}
|
||||
{%- endif %}
|
||||
|
||||
#remove release installed by formula
|
||||
postgresql-server-removed:
|
||||
pkg.removed:
|
||||
- pkgs:
|
||||
{% if postgres.pkg %}
|
||||
- {{ postgres.pkg }}
|
||||
{% endif %}
|
||||
{% if postgres.pkgs_extra %}
|
||||
{% for pkg in postgres.pkgs_extra %}
|
||||
- {{ pkg }}
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
{%- if postgres.remove.multiple_releases %}
|
||||
#search for and cleandown multiple releases
|
||||
|
||||
{% for release in postgres.remove.releases %}
|
||||
postgresql{{ release }}-server-pkgs-removed:
|
||||
pkg.purged:
|
||||
- pkgs:
|
||||
- {{ postgres.pkg if postgres.pkg else "postgresql" }}
|
||||
- postgresql-server
|
||||
- postgresql-libs
|
||||
- postgresql-contrib
|
||||
- postgresql-server-{{ release }}
|
||||
- postgresql-libs-{{ release }}
|
||||
- postgresql-contrib-{{ release }}
|
||||
- postgresql{{ release }}-contrib
|
||||
- postgresql{{ release }}-server
|
||||
- postgresql{{ release }}-libs
|
||||
- postgresql{{ release }}-contrib
|
||||
- postgresql{{ release|replace('.', '') }}-contrib
|
||||
- postgresql{{ release|replace('.', '') }}-server
|
||||
- postgresql{{ release|replace('.', '') }}-libs
|
||||
- postgresql{{ release|replace('.', '') }}-contrib
|
||||
|
||||
{% if 'bin_dir' in postgres %}
|
||||
{% for bin in postgres.server_bins %}
|
||||
{% set path = '/usr/pgsql-' + release|string + '/bin/' + bin %}
|
||||
|
||||
postgresql{{ release }}-server-{{ bin }}-alternative-remove:
|
||||
alternatives.remove:
|
||||
- name: {{ bin }}
|
||||
- path: {{ path }}
|
||||
{% if grains.os in ('Fedora', 'CentOS',) %}
|
||||
{# bypass bug #}
|
||||
- onlyif: alternatives --display {{ bin }}
|
||||
{% else %}
|
||||
- onlyif: test -f {{ path }}
|
||||
{% endif %}
|
||||
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
{%- if postgres.remove.data %}
|
||||
#allow data loss? default is no
|
||||
postgresql{{ release }}-dataconf-removed:
|
||||
file.absent:
|
||||
- names:
|
||||
- {{ postgres.conf_dir }}
|
||||
- {{ postgres.data_dir }}
|
||||
- /var/lib/postgresql
|
||||
- /var/lib/pgsql
|
||||
|
||||
{% for name, tblspace in postgres.tablespaces|dictsort() %}
|
||||
postgresql{{ release }}-tablespace-dir-{{ name }}-removed:
|
||||
file.absent:
|
||||
- name: {{ tblspace.directory }}
|
||||
- require:
|
||||
- file: postgresql{{ release }}-dataconf-removed
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
|
||||
{% endfor %}
|
||||
{%- endif %}
|
Loading…
Add table
Reference in a new issue