Skip to content

Latest commit

 

History

History
2147 lines (1164 loc) · 42.4 KB

REFERENCE.md

File metadata and controls

2147 lines (1164 loc) · 42.4 KB

Reference

Table of Contents

Classes

Public Classes

Private Classes

  • openondemand::apache: Manage Open OnDemand Apache
  • openondemand::config: Manage Open OnDemand configs
  • openondemand::install: Manage Open OnDemand install
  • openondemand::repo::apt: Manage Open OnDemand APT repos
  • openondemand::repo::rpm: Manage Open OnDemand RPM repos
  • openondemand::service: Manage Open OnDemand service

Defined types

Data types

Tasks

Classes

openondemand

Manage Open OnDemand

Parameters

The following parameters are available in the openondemand class:

repo_release

Data type: String

The release of OnDemand repo

Default value: '3.0'

repo_baseurl_prefix

Data type: Variant[Stdlib::HTTPSUrl, Stdlib::HTTPUrl]

The baseurl prefix for OnDemand repo

Default value: 'https://yum.osc.edu/ondemand'

repo_proxy

Data type: String

Sets proxy for OnDemand Repo

Default value: '_none_'

repo_gpgkey

Data type: Variant[Stdlib::HTTPSUrl, Stdlib::HTTPUrl, Stdlib::Absolutepath]

The URL for OnDemand repo GPG key

Default value: 'https://yum.osc.edu/ondemand/RPM-GPG-KEY-ondemand-SHA512'

repo_priority

Data type: Integer[1,99]

The priority of the OnDemand repo

Default value: 99

repo_exclude

Data type: String

Exclusion for OnDemand repo

Default value: 'absent'

manage_dependency_repos

Data type: Boolean

Boolean that determines if managing repos for package dependencies

Default value: true

manage_epel

Data type: Boolean

Boolean that determines if managing EPEL repo

Default value: true

repo_nightly

Data type: Boolean

Add the OnDemand nightly repo

Default value: false

selinux

Data type: Boolean

Boolean that determines if adding SELinux support

Default value: false

ondemand_package_ensure

Data type: String

ondemand package ensure

Default value: 'present'

ondemand_dex_package_ensure

Data type: String

ondemand-dex package ensure

Default value: 'present'

mod_auth_openidc_ensure

Data type: String

mod_auth_openidc package ensure

Default value: 'present'

install_apps

Data type: Hash

Hash of apps to install, passed to ondemand::install::app

Default value: {}

declare_apache

Data type: Boolean

Boolean that determines if apache is declared or included

Default value: true

apache_scls

Data type: String

SCLs to load when starting Apache service

Default value: 'httpd24'

generator_insecure

Data type: Boolean

Run ood-portal-generator with --insecure flag This is needed if you wish to use default ood@localhost user or other local users

Default value: false

listen_addr_port

Data type: Variant[Array, String, Undef]

ood_portal.yml listen_addr_port

Default value: undef

servername

Data type: Optional[String]

ood_portal.yml servername

Default value: undef

server_aliases

Data type: Optional[Array]

ood_porta.yml server_aliases

Default value: undef

ssl

Data type: Optional[Array]

ood_portal.yml ssl

Default value: undef

logroot

Data type: String

ood_portal.yml logroot

Default value: 'logs'

use_rewrites

Data type: Boolean

ood_portal.yml use_rewrites

Default value: true

use_maintenance

Data type: Boolean

ood_portal.yml use_maintenance

Default value: true

maintenance_ip_allowlist

Data type: Array

ood_portal.yml maintenance_ip_allowlist

Default value: []

maintenance_source

Data type: Optional[String]

Source for maintenance index.html

Default value: undef

maintenance_content

Data type: Optional[String]

Content for maintenance index.html

Default value: undef

security_csp_frame_ancestors

Data type: Optional[Variant[String, Boolean]]

ood_portal.yml security_csp_frame_ancestors

Default value: undef

security_strict_transport

Data type: Boolean

ood_portal.yml security_strict_transport

Default value: true

lua_root

Data type: String

ood_portal.yml lua_root

Default value: '/opt/ood/mod_ood_proxy/lib'

lua_log_level

Data type: Optional[String]

ood_portal.yml lua_log_level

Default value: undef

user_map_match

Data type: String

ood_portal.yml user_map_match

Default value: '.*'

user_map_cmd

Data type: Optional[String]

ood_portal.yml user_map_cmd

Default value: undef

user_env

Data type: Optional[String]

ood_portal.yml user_env

Default value: undef

map_fail_uri

Data type: Optional[String]

ood_portal.yml map_fail_uri

Default value: undef

auth_type

Data type: Variant[Enum['CAS', 'openid-connect', 'shibboleth', 'dex'], String[1]]

ood_portal.yml auth_type

Default value: 'dex'

auth_configs

Data type: Optional[Array]

ood_portal.yml auth_configs

Default value: undef

root_uri

Data type: String

ood_portal.yml root_uri

Default value: '/pun/sys/dashboard'

analytics

Data type: Optional[Struct[{ url => String, id => String }]]

ood_portal.yml analytics

Default value: undef

public_uri

Data type: String

ood_portal.yml public_uri

Default value: '/public'

public_root

Data type: String

ood_portal.yml public_root

Default value: '/var/www/ood/public'

logout_uri

Data type: String

ood_portal.yml logout_uri

Default value: '/logout'

logout_redirect

Data type: String

ood_portal.yml logout_redirect

Default value: '/pun/sys/dashboard/logout'

host_regex

Data type: String

ood_portal.yml host_regex

Default value: '[^/]+'

node_uri

Data type: Optional[String]

ood_portal.yml node_uri

Default value: undef

rnode_uri

Data type: Optional[String]

ood_portal.yml rnode_uri

Default value: undef

nginx_uri

Data type: String

ood_portal.yml nginx_uri

Default value: '/nginx'

pun_uri

Data type: String

ood_portal.yml pun_uri

Default value: '/pun'

pun_socket_root

Data type: String

ood_portal.yml pun_socket_root

Default value: '/var/run/ondemand-nginx'

pun_max_retries

Data type: Integer

ood_portal.yml pun_max_retries

Default value: 5

pun_pre_hook_root_cmd

Data type: Optional[Stdlib::Absolutepath]

ood_portal.yml pun_pre_hook_root_cmd

Default value: undef

pun_pre_hook_exports

Data type: Optional[String]

ood_porta.yml pun_pre_hook_exports

Default value: undef

oidc_uri

Data type: Optional[String]

ood_portal.yml oidc_uri

Default value: undef

oidc_discover_uri

Data type: Optional[String]

ood_portal.yml oidc_discover_uri

Default value: undef

oidc_discover_root

Data type: Optional[String]

ood_portal.yml oidc_discover_root

Default value: undef

register_uri

Data type: Optional[String]

ood_portal.yml register_uri

Default value: undef

register_root

Data type: Optional[String]

ood_portal.yml register_root

Default value: undef

oidc_provider_metadata_url

Data type: Optional[String]

OIDC metadata URL

Default value: undef

oidc_client_id

Data type: Optional[String]

OIDC client ID

Default value: undef

oidc_client_secret

Data type: Optional[String]

OIDC client secret

Default value: undef

oidc_remote_user_claim

Data type: String

OIDC REMOTE_USER claim

Default value: 'preferred_username'

oidc_scope

Data type: String

OIDC scopes

Default value: 'openid profile email'

oidc_session_inactivity_timeout

Data type: Integer

OIDC session inactivity timeout, see OIDCSessionInactivityTimeout

Default value: 28800

oidc_session_max_duration

Data type: Integer

OIDC session max duration, see OIDCSessionMaxDuration

Default value: 28800

oidc_state_max_number_of_cookies

Data type: String

OIDC setting that determines how to clean up cookies

Default value: '10 true'

oidc_settings

Data type: Hash

Hash of OIDC settings passsed directly to Apache config

Default value: {}

dex_uri

Data type: Variant[String[1],Boolean]

Dex URI if put behind Apache reverse proxy

Default value: '/dex'

dex_config

Data type: Openondemand::Dex_config

Dex configuration Hash

Default value: {}

web_directory

Data type: Stdlib::Absolutepath

Path to main web directory for OnDemand

Default value: '/var/www/ood'

nginx_log_group

Data type: String

Group to set for /var/log/ondemand-nginx

Default value: 'ondemand-nginx'

nginx_stage_clean_cron_schedule

Data type: String

Configure how often you want to run nginx_clean Defaults to '0 */2 * * *' (every other hour)

Default value: '0 */2 * * *'

nginx_stage_ondemand_portal

Data type: String

nginx_stage.yml ondemand_portal

Default value: 'ondemand'

nginx_stage_ondemand_title

Data type: String

nginx_stage.yml ondemand_title

Default value: 'Open OnDemand'

nginx_stage_pun_custom_env

Data type: Hash

nginx_stage.yml pun_custom_env

Default value: {}

nginx_stage_app_root

Data type: Openondemand::Nginx_stage_namespace_config

nginx_stage.yml app_root

Default value: {}

nginx_stage_scl_env

Data type: String

nginx_stage.yml scl_env

Default value: 'ondemand'

nginx_stage_app_request_regex

Data type: Optional[Openondemand::Nginx_stage_namespace_config]

nginx_stage.yml app_request_regex

Default value: undef

nginx_stage_min_uid

Data type: Integer

nginx_stage.yml min_uid

Default value: 1000

nginx_stage_passenger_pool_idle_time

Data type: Integer

nginx_stage.yml passenger_pool_idle_time

Default value: 300

nginx_stage_passenger_options

Data type: Hash[Pattern[/^passenger_.+/], Variant[String, Integer]]

nginx_stage.yml passenger_options

Default value: {}

nginx_stage_nginx_file_upload_max

Data type: Optional[Integer]

nginx_stage.yml nginx_file_upload_max

Default value: undef

nginx_stage_configs

Data type: Hash

nginx_stage.yml extra configuration options

Default value: {}

config_dir_purge

Data type: Boolean

Boolean that sets if ondemand.d should be purged of unmanaged files

Default value: true

config_source

Data type: Optional[String]

The source for /etc/ood/config/ondemand.d/ondemand.yml Overrides config_content as well as pinned apps and dashboard layout parameters

Default value: undef

config_content

Data type: Optional[String]

The content for /etc/ood/config/ondemand.d/ondemand.yml Overrides pinned apps and dashboard layout parameters

Default value: undef

confs

Data type: Hash

Hash to define openondemand::conf resources

Default value: {}

pinned_apps

Data type: Optional[Array[Variant[String[1], Hash]]]

Defines the OnDemand configuration for pinned_apps

Default value: undef

pinned_apps_menu_length

Data type: Optional[Integer]

Defines the OnDemand configuration for pinned_apps_menu_length

Default value: undef

pinned_apps_group_by

Data type: Optional[String[1]]

Defines the OnDemand configuration for pinned_apps_group_by

Default value: undef

dashboard_layout

Data type: Optional[Openondemand::Dashboard_layout]

Defines the OnDemand configuration for dashboard_layout

Default value: undef

hook_env

Data type: Boolean

Boolean that sets of hook.env configuration should be managed

Default value: true

hook_env_path

Data type: Stdlib::Absolutepath

Path to hook.env

Default value: '/etc/ood/config/hook.env'

hook_env_config

Data type: Hash

Configuration hash to pass into hook.env

Default value: {}

kubectl_path

Data type: Stdlib::Absolutepath

Path to kubectl

Default value: '/bin/kubectl'

clusters

Data type: Hash

Hash of resources to apss to openondemand::cluster

Default value: {}

clusters_hiera_merge

Data type: Boolean

Boolean that determines if clusters should be merged via lookup function

Default value: true

usr_apps

Data type: Variant[Array, Hash]

Resources passed to openondemand::app::usr

Default value: {}

usr_app_defaults

Data type: Hash

Defaults for usr_apps resources

Default value: {}

dev_apps

Data type: Hash

Resources passed to openondemand::app::dev

Default value: {}

dev_app_users

Data type: Array

Users to define as having dev apps, passed to openondemand::app::dev

Default value: []

dev_app_defaults

Data type: Hash

Defaults for dev_apps and dev_app_users

Default value: {}

apps_config_repo

Data type: Optional[String]

Git repo URL for apps config

Default value: undef

apps_config_revision

Data type: Optional[String]

Revision for apps config Git repo

Default value: undef

apps_config_repo_path

Data type: String

Path in apps config Git repo for app configs

Default value: ''

locales_config_repo_path

Data type: Optional[String]

Path in apps config Git repo for locales configs

Default value: undef

announcements_config_repo_path

Data type: Optional[String]

Path in apps config Git repo for announcements

Default value: undef

apps_config_source

Data type: Optional[String]

Source for apps config, not used if apps_config_repo is defined

Default value: undef

locales_config_source

Data type: Optional[String]

Source for locales config, not used if apps_config_repo is defined

Default value: undef

announcements_config_source

Data type: Optional[String]

Source for aouncements config, not used if apps_config_repo is defined

Default value: undef

public_files_repo_paths

Data type: Array

Path to public files in apps config Git repo

Default value: []

manage_logrotate

Data type: Boolean

Boolean that allows disabling management of logrotate

Default value: true

Defined types

openondemand::app::dev

Manage Open OnDemand dev app

Examples

openondemand::app::dev { 'user1': }

Parameters

The following parameters are available in the openondemand::app::dev defined type:

ensure

Data type: Enum['present','absent']

Default value: 'present'

mode

Data type: Stdlib::Filemode

File mode of dev app

Default value: '0755'

owner

Data type: String

Owner of dev app

Default value: 'root'

group

Data type: String

Group owning dev app

Default value: 'root'

home_subdir

Data type: String

The subdirectory under user's home for dev app Not used if gateway_src is defined

Default value: 'ondemand/dev'

gateway_src

Data type: Optional[Stdlib::Absolutepath]

The path to dev app, overrides home_subdir

Default value: undef

openondemand::app::usr

Manage Open OnDemand user app

Examples

openondemand::app::usr { 'user1':
  gateway_src => '/home/user1/ondemand/usr',
}

Parameters

The following parameters are available in the openondemand::app::usr defined type:

gateway_src

Data type: Stdlib::Absolutepath

Path to source of user's apps

ensure

Data type: Enum['present','absent']

Default value: 'present'

mode

Data type: Stdlib::Filemode

The file mode for shared apps

Default value: '0750'

owner

Data type: String

The file owner of shared apps

Default value: 'root'

group

Data type: String

The file group owner of shared apps

Default value: 'root'

openondemand::cluster

Manage Open OnDemand cluster definition

Parameters

The following parameters are available in the openondemand::cluster defined type:

cluster_title

Data type: String

Default value: $name

owner

Data type: String

Owner of the cluster YAML file

Default value: 'root'

group

Data type: String

Group of the cluster YAML file

Default value: 'root'

mode

Data type: Stdlib::Filemode

Ownership mode of the cluster YAML file

Default value: '0644'

url

Data type: Optional[Variant[Stdlib::HTTPSUrl, Stdlib::HTTPUrl]]

Default value: undef

hidden

Data type: Boolean

Default value: false

acls

Data type: Array[Openondemand::Acl]

Default value: []

login_host

Data type: Optional[Stdlib::Host]

Default value: undef

job_adapter

Data type: Optional[Enum['torque','slurm','lsf','pbspro','sge','linux_host','kubernetes']]

Default value: undef

job_cluster

Data type: Optional[String]

Default value: undef

job_host

Data type: Optional[Stdlib::Host]

Default value: undef

job_lib

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_libdir

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_bin

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_bindir

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_conf

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_envdir

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_serverdir

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_exec

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

sge_root

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

libdrmaa_path

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_version

Data type: Optional[String]

Default value: undef

job_bin_overrides

Data type: Hash[String, Stdlib::Absolutepath]

Default value: {}

job_submit_host

Data type: Optional[Stdlib::Host]

Default value: undef

job_ssh_hosts

Data type: Array[Stdlib::Host]

Default value: []

job_site_timeout

Data type: Optional[Integer]

Default value: undef

job_debug

Data type: Optional[Boolean]

Default value: undef

job_singularity_bin

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_singularity_bindpath

Data type: Optional[Variant[Array[Stdlib::Absolutepath], String]]

Default value: undef

job_singularity_image

Data type: Optional[String]

Default value: undef

job_strict_host_checking

Data type: Optional[Boolean]

Default value: undef

job_tmux_bin

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

job_config_file

Data type: Optional[String[1]]

Default value: undef

job_username_prefix

Data type: Optional[String]

Default value: undef

job_namespace_prefix

Data type: Optional[String]

Default value: undef

job_all_namespaces

Data type: Boolean

Default value: false

job_auto_supplemental_groups

Data type: Boolean

Default value: false

job_server

Data type: Optional[Openondemand::K8_server]

Default value: undef

job_mounts

Data type: Array[Openondemand::K8_mount]

Default value: []

job_auth

Data type: Optional[Openondemand::K8_auth]

Default value: undef

scheduler_type

Data type: Optional[Enum['moab']]

Default value: undef

scheduler_host

Data type: Optional[Stdlib::Host]

Default value: undef

scheduler_bin

Data type: Optional[Stdlib::Absolutepath]

Default value: undef

scheduler_version

Data type: Optional[String]

Default value: undef

scheduler_params

Data type: Hash

Default value: {}

rsv_query_acls

Data type: Array[Openondemand::Acl]

Default value: []

ganglia_host

Data type: Optional[Stdlib::Host]

Default value: undef

ganglia_scheme

Data type: String

Default value: 'https://'

ganglia_segments

Data type: Array

Default value: ['gweb', 'graph.php']

ganglia_req_query

Data type: Hash

Default value: { 'c' => $name }

ganglia_opt_query

Data type: Hash

Default value: { 'h' => "%{h}.${facts['networking']['domain']}" }

ganglia_version

Data type: String

Default value: '3'

grafana_host

Data type: Optional[Variant[Stdlib::HTTPSUrl,Stdlib::HTTPUrl]]

Default value: undef

grafana_org_id

Data type: Integer

Default value: 1

grafana_theme

Data type: Optional[String]

Default value: undef

grafana_dashboard_name

Data type: Optional[String]

Default value: undef

grafana_dashboard_uid

Data type: Optional[String]

Default value: undef

grafana_dashboard_panels

Data type: Optional[Struct[{ 'cpu' => Integer, 'memory' => Integer, }]]

Default value: undef

grafana_labels

Data type: Optional[Struct[{ 'cluster' => String, 'host' => String, 'jobid' => Optional[String], }]]

Default value: undef

grafana_cluster_override

Data type: Optional[String]

Default value: undef

xdmod_resource_id

Data type: Optional[Integer]

Default value: undef

custom_config

Data type: Hash

Custom Hash passed to v2.custom in cluster YAML

Default value: {}

batch_connect

Data type: Openondemand::Batch_connect

Default value: {}

openondemand::conf

Manage Open OnDemand configuration file in /etc/ood/config/ondemand.d

Parameters

The following parameters are available in the openondemand::conf defined type:

source

Data type: Optional[String]

The source of the configuration file

Default value: undef

content

Data type: Optional[String]

The content template of the configuration file

Default value: undef

content_template

Data type: Optional[String]

The template to define content

Default value: undef

data

Data type: Optional[Hash]

A hash of data to convert to YAML that defines the configuration file contents

Default value: undef

template

Data type: Boolean

If true, the file will have .yml.erb extension, otherwise the extension is .yml

Default value: false

filename

Data type: Optional[String]

Override the default filename for the configuration file

Default value: undef

openondemand::install::app

Manage Open OnDemand app

Examples

openondemand::install::app { 'bc_osc_foo':
  ensure => '0.1.0-1.el7',
}

Parameters

The following parameters are available in the openondemand::install::app defined type:

ensure

Data type: String

Package ensure property if installing from a package

Default value: 'present'

package

Data type: String

Package name for the app

Default value: "ondemand-${name}"

manage_package

Data type: Boolean

Should package be managed

Default value: true

git_repo

Data type: Optional[String]

The git repo to use to install the app If defined, no package will be installed

Default value: undef

git_revision

Data type: Optional[String]

The git revision to checkout

Default value: undef

path

Data type: Optional[Stdlib::Absolutepath]

Path to app, defaults to /var/www/ood/apps/sys/$name

Default value: undef

owner

Data type: String

File owner of app

Default value: 'root'

group

Data type: String

File group owner of app

Default value: 'root'

mode

Data type: String

File mode for app

Default value: '0755'

Data types

Openondemand::Acl

OnDemand cluster ACL

Alias of

Struct[{ 'adapter' => Enum['group'],
                                  'groups'  => Optional[Array],
                                  'type'    => Enum['whitelist', 'blacklist']
                                  }]

Openondemand::Batch_connect

Defines cluster config batch_connect values

Alias of

Struct[{
  Optional['basic']     => Struct[{
        Optional['script_wrapper'] => String,
        Optional['set_host'] => String
    }],
  Optional['vnc']       => Struct[{
        Optional['script_wrapper'] => String,
        Optional['set_host'] => String
    }],
  Optional['ssh_allow'] => Boolean,
}]

Openondemand::Dashboard_layout

Dashboard layout

Alias of

Struct[{
  'rows' => Array[Struct[{'columns' => Array[Openondemand::Dashboard_layout_column]}]]
}]

Openondemand::Dashboard_layout_column

Dashboard layout column

Alias of

Struct[{
  'width' => Integer,
  'widgets' => Array[String[1]],
}]

Openondemand::Dex_config

ondemand-dex config

Alias of

Struct[{
  'ssl' => Optional[Boolean],
  'http_port' => Optional[Variant[String, Integer]],
  'https_port' => Optional[Variant[String, Integer]],
  'tls_cert' => Optional[Stdlib::Absolutepath],
  'tls_key' => Optional[Stdlib::Absolutepath],
  'storage_file' => Optional[Stdlib::Absolutepath],
  'grpc' => Optional[Hash],
  'expiry' => Optional[Hash],
  'client_id' => Optional[String],
  'client_redirect_uris' => Optional[Array],
  'client_name' => Optional[String],
  'client_secret' => Optional[String],
  'static_clients' => Optional[Array[Hash]],
  'connectors' => Optional[Array[Hash]],
  'frontend' => Optional[Hash],
  }]

Openondemand::K8_auth

OnDemand cluster Kubernetes auth

Alias of

Struct[{
    'type' => String[1],
  }]

Openondemand::K8_mount

OnDemand cluster Kubernetes mount

Alias of

Struct[{ 'type' => String[1],
    'name'  => String[1],
    'host_type' => Optional[String[1]],
    'host' => Optional[String[1]],
    'destination_path' => Stdlib::Absolutepath,
    'path' => Stdlib::Absolutepath,
  }]

Openondemand::K8_server

OnDemand cluster Kubernetes mount

Alias of

Struct[{ 'endpoint' => Stdlib::HTTPSUrl,
    'cert_authority_file'  => Stdlib::Absolutepath,
  }]

Openondemand::Nginx_stage_namespace_config

nginx_stage.yml namespace_config

Alias of

Struct[{
  'dev' => Optional[String],
  'usr' => Optional[String],
  'sys' => Optional[String]
  }]

Tasks

announce

Install Open OnDemand announcement file

Supports noop? false

Parameters

source

Data type: String[1]

Path to file to install (or purge)

maintenance

Put OnDemand into maintenance mode

Supports noop? false

Parameters

ensure

Data type: Enum['present','absent']

Set state of maintenance mode

nginx_stage

Run nginx_stage commands

Supports noop? false

Parameters

command

Data type: Enum[nginx_clean,nginx_list]

nginx_stage command to execute

user

Data type: Optional[String[1]]

Operate on specific user

skip_nginx

Data type: Optional[Boolean]

Skip execution of the per-user nginx process

force

Data type: Optional[Boolean]

Force clean ALL per-user nginx processes