Puppet Class: chartmuseum

Defined in:
modules/chartmuseum/manifests/init.pp

Overview

SPDX-License-Identifier: Apache-2.0

Class: chartmuseum

This class installs and configures ChartMuseum, a Helm chart repository server.

Parameters:

listen_host

Listen on this interface only.

listen_port

TCP port to listen on.

repository_depth

Level of nested repositories for multitenancy. A value of 0 allows only one repository, whereas a level of 2 supports a structure like:

charts
├── org1
│   ├── repoa
│   │   └── nginx-ingress-0.9.3.tgz
├── org2
│   ├── repob
│   │   └── chartmuseum-0.4.0.tgz
disable_delete

Do not allow charts to be deleted via API.

disable_force_overwrite

Do not allow charts to be overwritten, even with “?force” querystring.

allow_anonymous_get

Allow anonymous HTTP GET operations even when basic auth is enabled.

cache_interval

Intervall in which to check the storage backend for changes/re-read index-cache.yaml from the backend. For valid values for this setting, please see: godoc.org/time#ParseDuration

swift_backend

Optional configuration of a Swift storage backend (URL, container name, username and password). If this parameter is not set, local storage in “/var/lib/chartmuseum” is used.

basic_auth

Optional username and password to enable HTTP basic auth.

debug

Show debug messages in log.

Parameters:

  • listen_host (Stdlib::Host) (defaults to: '0.0.0.0')
  • listen_port (Stdlib::Port::Unprivileged) (defaults to: 8080)
  • repository_depth (Integer[0]) (defaults to: 1)
  • disable_delete (Boolean) (defaults to: true)
  • disable_force_overwrite (Boolean) (defaults to: true)
  • allow_anonymous_get (Boolean) (defaults to: true)
  • cache_interval (String) (defaults to: '60s')
  • swift_backend (Optional[ChartMuseum::SwiftBackend]) (defaults to: undef)
  • basic_auth (Optional[ChartMuseum::BasicAuth]) (defaults to: undef)
  • debug (Optional[Boolean]) (defaults to: false)


43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'modules/chartmuseum/manifests/init.pp', line 43

class chartmuseum (
    Stdlib::Host                        $listen_host             = '0.0.0.0',
    Stdlib::Port::Unprivileged          $listen_port             = 8080,
    Integer[0]                          $repository_depth        = 1,
    Boolean                             $disable_delete          = true,
    Boolean                             $disable_force_overwrite = true,
    Boolean                             $allow_anonymous_get     = true,
    String                              $cache_interval          = '60s',
    Optional[ChartMuseum::SwiftBackend] $swift_backend           = undef,
    Optional[ChartMuseum::BasicAuth]    $basic_auth              = undef,
    Optional[Boolean]                   $debug                   = false,
) {
    package { 'chartmuseum':
        ensure => present,
    }

    profile::auto_restarts::service { 'chartmuseum': }

    file { '/etc/chartmuseum/chartmuseum.yaml':
        ensure  => file,
        mode    => '0440',
        owner   => 'root',
        group   => 'chartmuseum',
        content => template('chartmuseum/chartmuseum.yaml.erb'),
        notify  => Service[chartmuseum],
    }

    file { '/etc/default/chartmuseum':
        ensure  => file,
        mode    => '0440',
        owner   => 'root',
        group   => 'root',
        content => template('chartmuseum/chartmuseum.defaults.erb'),
        notify  => Service[chartmuseum],
    }

    service { 'chartmuseum':
        ensure  => running,
        require => Package['chartmuseum'],
    }
}