diff --git a/.github/workflows/chart-doc.yaml b/.github/workflows/chart-doc.yaml index 249220fe..6da6c9c4 100644 --- a/.github/workflows/chart-doc.yaml +++ b/.github/workflows/chart-doc.yaml @@ -9,7 +9,7 @@ jobs: name: helm-docs steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - uses: r-lib/actions/pr-fetch@v2 with: @@ -20,19 +20,22 @@ jobs: with: version: v3.6.3 + - name: install Just + uses: extractions/setup-just@v2 + - name: Install helm-docs env: - version: 1.5.0 + HELM_DOCS_VERSION: 1.13.1 run: | - echo "Installing helm-docs version $version" - curl -L -o helm-docs.tar.gz https://github.com/norwoodj/helm-docs/releases/download/v${version}/helm-docs_${version}_Linux_x86_64.tar.gz - tar -xzvf helm-docs.tar.gz helm-docs - rm -rf helm-docs.tar.gz + just setup + + - name: Install Quarto + uses: quarto-dev/quarto-actions/setup@v2 + with: + version: pre-release - - name: Run helm-docs - run: | - ./helm-docs --chart-search-root=charts --template-files=README.md.gotmpl --template-files=./_templates.gotmpl - ./helm-docs --chart-search-root=other-charts --template-files=README.md.gotmpl --template-files=./_templates.gotmpl + - name: Render Quarto Project + uses: quarto-dev/quarto-actions/render@v2 - name: Commit results run: | @@ -62,13 +65,12 @@ jobs: with: version: v3.6.3 + - name: install Just + uses: extractions/setup-just@v2 + - name: Compute and update dependent files run: | - set -xe - cd ./charts/rstudio-launcher-rbac && helm dependency build && cd - - helm template -n rstudio rstudio-launcher-rbac ./charts/rstudio-launcher-rbac --set removeNamespaceReferences=true > examples/rbac/rstudio-launcher-rbac.yaml - CHART_VERSION=$(helm show chart ./charts/rstudio-launcher-rbac | grep '^version' | cut -d ' ' -f 2) - cp examples/rbac/rstudio-launcher-rbac.yaml examples/rbac/rstudio-launcher-rbac-${CHART_VERSION}.yaml + just rbac - name: Commit results run: | diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml new file mode 100644 index 00000000..6e51b8e5 --- /dev/null +++ b/.github/workflows/publish.yml @@ -0,0 +1,38 @@ +name: Quarto Publish to docs.posit.co + +on: + workflow_dispatch: + push: + branches: main + +permissions: + id-token: write + contents: read + +jobs: + build-deploy: + runs-on: ubuntu-latest + steps: + - name: Configure AWS credentials + id: creds + uses: aws-actions/configure-aws-credentials@master + with: + role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }} + aws-region: ${{ secrets.AWS_REGION }} + + - name: Check out repository + uses: actions/checkout@v4 + + - name: install Just + uses: extractions/setup-just@v2 + + - name: Set up Quarto + uses: quarto-dev/quarto-actions/setup@v2 + with: + version: pre-release + + - name: Render Quarto Project + uses: quarto-dev/quarto-actions/render@v2 + + - run: just push-docs + diff --git a/Justfile b/Justfile index 9afbf6f2..f8a0268f 100644 --- a/Justfile +++ b/Justfile @@ -1,13 +1,16 @@ DIFF := "diff" +HELM_DOCS_VERSION := env_var_or_default("HELM_DOCS_VERSION", "1.13.1") +OS := if os() == "macos" {"Darwin"} else if os() == "linux" {"Linux"} else if os() == "windows" {"Windows"} else {""} +ARCH := if arch() == "aarch64" {"arm64"} else if arch() == "x86_64" {"x86_64"} else {""} setup: #!/bin/bash - # TODO: idempotency - - # TODO: check for macos - mkdir -p ./bin/helm-docs-1.5.0/ - curl -L https://github.com/norwoodj/helm-docs/releases/download/v1.5.0/helm-docs_1.5.0_Darwin_x86_64.tar.gz | tar -xzvf - -C ./bin/helm-docs-1.5.0/ - ln -s $PWD/bin/helm-docs-1.5.0/helm-docs $PWD/bin/helm-docs + set -xe + echo "Installing helm-docs version {{HELM_DOCS_VERSION}}" + mkdir -p bin + curl -L -s https://github.com/norwoodj/helm-docs/releases/download/v{{HELM_DOCS_VERSION}}/helm-docs_{{HELM_DOCS_VERSION}}_{{OS}}_{{ARCH}}.tar.gz -o bin/helm-docs.tar.gz + tar -C ./bin -xz -f bin/helm-docs.tar.gz helm-docs + rm -rf bin/helm-docs.tar.gz update-lock: #!/bin/bash @@ -98,3 +101,17 @@ test-connect-interpreter-versions: docker run --rm $image /bin/bash -c "command -v $ex" done done + +push-docs: + #!/usr/bin/env bash + set -euxo pipefail + + s3_args=(--dryrun) + if [[ "${GITHUB_REF:-}" == "refs/heads/main" ]] || [[ "${GITHUB_REF:-}" =~ ^refs/tags/v[0-9]{4}\.[0-9]{2}\.[0-9]+$ ]]; then + s3_args=("") + fi + + # The s3 bucket is s3://docs.rstudio.com/, which is available as https://docs.posit.co/ + aws s3 sync ${s3_args[*]:-} \ + _site \ + "s3://docs.rstudio.com/helm/" \ No newline at end of file diff --git a/_environment b/_environment new file mode 100644 index 00000000..0521a9f7 --- /dev/null +++ b/_environment @@ -0,0 +1 @@ +CURRENT_YEAR=2024 diff --git a/_extensions/posit-dev/posit-docs/_extension.yml b/_extensions/posit-dev/posit-docs/_extension.yml index 4b25a124..9f03f0f2 100644 --- a/_extensions/posit-dev/posit-docs/_extension.yml +++ b/_extensions/posit-dev/posit-docs/_extension.yml @@ -1,42 +1,36 @@ title: posit-docs -author: Ashley Henry -version: 0.2.0 -quarto-requred: ">=1.3.340" +author: Ashley Henry, David Aja, Aron Atkins +version: 4.0.1 +quarto-required: ">=1.3.340" contributes: project: project: type: website website: - title: favicon: "assets/images/favicon.svg" bread-crumbs: true navbar: pinned: true logo: "assets/images/posit-icon-fullcolor.svg" - logo-alt: "Posit Documentation" - sidebar: - style: "floating" - collapse-level: 1 - search: true - pinned: false - page-footer: - left: - - text: © 2024 Posit Software, PBC - url: "https://posit.co" - center: | - Posit Product 12345 - + logo-alt: "Posit Documentation" right: - - icon: book - href: https://docs.posit.co - - icon: question-circle-fill - href: https://support.posit.co/hc/en-us - - icon: lightbulb-fill - href: https://solutions.posit.co - formats: - html: - theme: [theme.scss] - link-external-icon: true - link-external-newwindow: true - toc: true - toc-expand: true + - icon: "list" + aria-label: 'Drop-down menu for additional Posit resources' + menu: + - text: "docs.posit.co" + href: "https://docs.posit.co" + - text: "Posit Support" + href: "https://support.posit.co/hc/en-us/" + search: + copy-button: true + show-item-context: true + format: + html: + theme: + light: [theme.scss] + dark: [theme-dark.scss] + link-external-icon: true + link-external-newwindow: true + toc: true + toc-expand: true + include-in-header: "assets/_analytics.html" diff --git a/_extensions/posit-dev/posit-docs/_posit-colors.scss b/_extensions/posit-dev/posit-docs/_posit-colors.scss new file mode 100644 index 00000000..e4bf13a3 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/_posit-colors.scss @@ -0,0 +1,37 @@ +/* Posit Color definitions */ +$posit-blue: #447099; +$posit-light-blue-1: #d1dbe5; +$posit-light-blue-2: #a2b8cb; +$posit-light-blue-3: #7494b1; +$posit-dark-blue-1: #305775; +$posit-dark-blue-2: #213d4f; + +$posit-orange: #ee6331; +$posit-light-orange-1: #edccbf; +$posit-light-orange-2: #eba38c; +$posit-dark-orange-1: #ab4d26; +$posit-dark-orange-2: #80361c; +$posit-dark-orange-3: #451f12; + +$posit-gray: #404041; +$posit-light-gray-1: #c2c2c4; +$posit-light-gray-2: #949494; +$posit-dark-gray-1: #333333; + +$posit-teal: #419599; +$posit-light-teal-1: #c2d9d9; +$posit-light-teal-2: #94bdbf; +$posit-light-teal-3: #70a3a6; +$posit-dark-teal-1: #297075; +$posit-dark-teal-2: #1f4f4f; +$posit-dark-teal-3: #122b2b; + +$posit-green: #72994e; + +$posit-burgundy: #9a4665; +$posit-light-burgundy-1: #d9c4cc; +$posit-light-burgundy-2: #bf96a3; +$posit-light-burgundy-3: #a67380; +$posit-dark-burgundy-1: #78384f; +$posit-dark-burgundy-2: #542938; +$posit-dark-burgundy-3: #2e171f; diff --git a/_extensions/posit-dev/posit-docs/assets/_analytics.html b/_extensions/posit-dev/posit-docs/assets/_analytics.html new file mode 100644 index 00000000..6ba70366 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/_analytics.html @@ -0,0 +1,40 @@ + + diff --git a/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle-dm.svg b/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle-dm.svg new file mode 100644 index 00000000..fbdfd203 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle-dm.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle.svg b/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle.svg new file mode 100644 index 00000000..6098c8b2 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/exclamation-circle.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle-dm.svg b/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle-dm.svg new file mode 100644 index 00000000..63db9932 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle-dm.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle.svg b/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle.svg new file mode 100644 index 00000000..65d947c9 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/exclamation-triangle.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/info-circle-dm.svg b/_extensions/posit-dev/posit-docs/assets/images/info-circle-dm.svg new file mode 100644 index 00000000..6a5c164d --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/info-circle-dm.svg @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/info-circle.svg b/_extensions/posit-dev/posit-docs/assets/images/info-circle.svg new file mode 100644 index 00000000..f4f803ad --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/info-circle.svg @@ -0,0 +1,4 @@ + + + + diff --git a/_extensions/posit-dev/posit-docs/assets/images/posit-guide-dm.svg b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-dm.svg new file mode 100644 index 00000000..b0c67d11 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-dm.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/posit-guide-ltmd.svg b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-ltmd.svg new file mode 100644 index 00000000..f2c33c23 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-ltmd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-dm.svg b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-dm.svg new file mode 100644 index 00000000..d6b0e2b2 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-dm.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-ltmd.svg b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-ltmd.svg new file mode 100644 index 00000000..77464c09 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/assets/images/posit-guide-open-ltmd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/_extensions/posit-dev/posit-docs/assets/images/posit-logo-black-TM.svg b/_extensions/posit-dev/posit-docs/assets/images/posit-logo-black-TM.svg index b85676de..90331515 100644 --- a/_extensions/posit-dev/posit-docs/assets/images/posit-logo-black-TM.svg +++ b/_extensions/posit-dev/posit-docs/assets/images/posit-logo-black-TM.svg @@ -1 +1 @@ - \ No newline at end of file + diff --git a/_extensions/posit-dev/posit-docs/theme-dark.scss b/_extensions/posit-dev/posit-docs/theme-dark.scss new file mode 100644 index 00000000..ec1e26d4 --- /dev/null +++ b/_extensions/posit-dev/posit-docs/theme-dark.scss @@ -0,0 +1,342 @@ +/*-- scss:defaults --*/ + +// import font +@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap"); + +// import shared colors +@import '_posit-colors'; + +/*-- scss:variables --*/ +$primary: $posit-teal; +$dark-md-body: $posit-light-gray-1; +$dark-md-background: #0c1721; + +// Feature preview heading colors +$preview-header: $posit-orange; /* posit orange, contrast: 8.45 */ +$preview-header-border: darken($preview-header, 5%); + +// scss-docs-end color-variables + +// Typography +// Font, line-height, and color for body text, headings, and more. + +//scss-font-start font-variables +$font-family-sans-serif: "Open Sans", "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, + sans-serif, system-ui; +$font-family-monospace: "Source Code Pro", monospace; +$font-family-emoji: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; +$font-size-base: 1rem; +// scss-docs-end font-variables + +//font and body color + +$body-color: $dark-md-body; +$popover-bg: $posit-green !default; + +// scss-docs-start font-sizes - seems that I have to keep these in the style sheet? +$h1-font-size: 44px; +$h2-font-size: 28px; +x h1 { + size: $h1-font-size; +} +h2 { + size: $h2-font-size; +} +// scss-docs-end font-sizes + +// Headings +// scss-docs-start headings-variables +$headings-color: #ffffff; +// scss-docs-end headings-variables + +// Customize the navbar +$navbar-bg: lighten($dark-md-background, 5%); +$navbar-fg: #ffffff; + +// CSS overrides + +// Body +// +// Settings for the `` element. + +//$body-color: $posit-green !default; +$body-bg: $dark-md-background !default; // dark mode change + +// Nav and footer + +/* Nav bar */ + +.navbar-title { + color: #ffffff; // dark theme change +} + +.nav-link { + font-family: $font-family-monospace; + text-transform: uppercase; + letter-spacing: 0.03em; + font-size: 14px !important; + font-weight: 500 !important; + color: #fff !important; +} + +.navbar-nav .nav-link.active, +.navbar-nav .nav-link.show { + color: $posit-teal !important; + font-weight: 700 !important; +} + +/* Nav bar right hamburger menu */ + +.dropdown-item:hover, +.dropdown-item:focus { + color: var(--bs-dropdown-link-hover-color); + background-color: #0f1c29 !important; +} + +/* Footer */ + +.nav-footer { + color: #ffffff !important; + border-top: solid $posit-gray 1px; +} + +/* Footer icons */ +.nav-footer a { + color: #ffffff !important; +} + +// Footnotes + +.footnote-back { + color: $posit-light-teal-2; +} + +// Breadcrumbs + +.quarto-title-breadcrumbs .breadcrumb li:last-of-type a { + color: $posit-light-gray-1 !important; +} + +// Page navigation + +.nav-page .nav-page-text { + color: $posit-light-gray-1; +} + +/* Inline code */ +p code:not(.sourceCode), +li code:not(.sourceCode), +td code:not(.sourceCode) { + background-color: #6e768166 !important; + color: #ffffff; +} + +// Code blocks + +/* Code block title*/ + +.quarto-dark .code-with-filename .code-with-filename-file { + background-color: #000000 !important; + border: none; +} + +.code-with-filename strong { + color: #6e9ac3; +} + +/* Code block background */ +$code-block-bg: lighten($dark-md-background, 10%); + +/* Copy button */ + +$btn-code-copy-color: $posit-light-blue-2; +$btn-code-copy-color-active: #ffffff; +$callout-icon-scale: 70%; + +// Tabs and pills + +/* Tabs */ + +.nav-tabs .nav-link.active { + color: $posit-teal !important; +} + +.nav-tabs .nav-link { + text-transform: none !important; + font-family: $font-family-sans-serif; + color: #ffffff !important; +} + +.nav-tabs .nav-link:hover, +.nav-link:focus { + color: $posit-teal !important; +} + +/* Pills */ + +.nav-pills .nav-link.active, +.nav-pills .show > .nav-link { + background-color: $posit-dark-teal-1 !important; +} + +.nav-pills .nav-link:hover, +.nav-link:focus { + isolation: isolate; + // color: $posit-teal !important; + border: none !important; +} + +.nav-pills .nav-link.active, +.nav-link:hover { + color: #ffffff !important; +} + +// Sidebar and toc + +/* Left nav - letter spacing */ +.sidebar-navigation li a { + color: #ffffff; +} + +.sidebar-navigation li a:hover { + color: inherit; +} + +.sidebar-item-container .active, +div.sidebar-item-container .show > .nav-link, +div.sidebar-item-container .sidebar-link > code { + color: $posit-teal !important; +} + +// Lists + +/* List disc colors */ +li::marker { + color: $posit-teal; +} + +// Callouts + +.callout.callout-style-default:not(.no-icon) div.callout-title-container { + color: #ffffff !important; +} + +div.callout.callout-style-default > div.callout-header { + opacity: none; +} + +/* Note */ + +div.callout-note.callout { + border-left-color: $posit-dark-blue-2 !important; + border-right: 1px solid $posit-dark-blue-2 !important; + border-top: 1px solid $posit-dark-blue-2 !important; + border-bottom: 1px solid $posit-dark-blue-2 !important; +} + +div.callout-note .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/info-circle-dm.svg + background-image: url("") !important; +} + +div.callout-note.callout-style-default > .callout-header { + background-color: $posit-blue !important; +} + +/* Warning */ + +div.callout-warning.callout { + border-left-color: $posit-dark-orange-2 !important; + border-right: 1px solid $posit-dark-orange-2 !important; + border-top: 1px solid $posit-dark-orange-2 !important; + border-bottom: 1px solid $posit-dark-orange-2 !important; +} + +div.callout-warning .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/exclamation-triangle-dm.svg + background-image: url("") !important; +} + +div.callout-warning.callout-style-default > .callout-header { + background-color: $posit-dark-orange-1 !important; +} + +/* Important */ + +div.callout-important.callout { + border-left-color: $posit-dark-burgundy-2 !important; + border-right: 1px solid $posit-dark-burgundy-2 !important; + border-top: 1px solid $posit-dark-burgundy-2 !important; + border-bottom: 1px solid $posit-dark-burgundy-2 !important; +} + +div.callout-important .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/exclamation-circle-dm.svg + background-image: url("") !important; +} + +div.callout-important.callout-style-default > .callout-header { + background-color: $posit-burgundy !important; +} + +// Tables + +.table > :not(caption) > * > * { + border-top: 2px solid #101e2b; +} + +/* Striped table styles */ + +.table-striped > tbody > tr:nth-of-type(odd) > * { + //--bs-table-bg-type: #001C2B !important; + --bs-table-bg-type: #101e2b !important; +} + +/* Striped table hover */ + +.table-hover > tbody > tr:hover > * { + //--bs-table-color-state: var(--bs-table-hover-color); + --bs-table-bg-state: #001c2b !important; +} + +// Table caption + +.panel-caption, +.figure-caption, +.subfigure-caption, +.table-caption, +figcaption, +caption { + font-size: 1rem; + color: $body-color !important; +} + +// Specialty headers + +/* the feature PREVIEW header */ +.preview-header > h1:after, +.preview-header > h2:after, +.preview-header > h3:after, +.preview-header > h4:after, +header h1 .preview-header, +div span.preview-feature { + background-color: $preview-header; + color: #ffffff; + border: 1px solid $preview-header-border; + font-weight: 600; + font-size: 9pt !important; + padding: 0rem 0.4rem; +} + +div span.preview-feature { + margin-left: 1em; + text-transform: uppercase; +} + +// Specialty lists +// Groovy list - dark mode change + +ol.groovyAlpha li > p:before { + content: counter(list-counter, lower-alpha); + font-weight: 600; +} diff --git a/_extensions/posit-dev/posit-docs/theme.scss b/_extensions/posit-dev/posit-docs/theme.scss index bad2b7b1..0a4e222a 100644 --- a/_extensions/posit-dev/posit-docs/theme.scss +++ b/_extensions/posit-dev/posit-docs/theme.scss @@ -1,40 +1,37 @@ /*-- scss:defaults --*/ // import font -@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap'); +@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap"); + +// import shared colors +@import '_posit-colors'; /*-- scss:variables --*/ +$primary: $posit-blue; -// scss-docs-start color-variables -$posit-blue: #447099; -$posit-dark-blue-1: #305775; -$posit-dark-blue-2: #213D4F; -$posit-orange: #EE6331; -$posit-gray: #404041; -$posit-teal: #419599; -$posit-green: #72994E; -$posit-burgundy:#9A4665; -$posit-burgundy-1:#78384F; -$posit-burgundy-2:#542938; +// Feature preview heading colors +$preview-header: #ee6331; /* posit orange, contrast: 8.45 */ +$preview-header-border: darken($preview-header, 5%); -$primary: $posit-blue; // scss-docs-end color-variables // Typography // Font, line-height, and color for body text, headings, and more. //scss-font-start font-variables -$font-family-sans-serif: "Open Sans", "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, system-ui; +$font-family-sans-serif: "Open Sans", "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, + sans-serif, system-ui; $font-family-monospace: "Source Code Pro", monospace; $font-family-emoji: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; $font-size-base: 1rem; // scss-docs-end font-variables +//font and body color $body-color: $posit-gray; // scss-docs-start font-sizes -$h1-font-size:44px; -$h2-font-size:28px; +$h1-font-size: 44px; +$h2-font-size: 28px; h1 { size: $h1-font-size; @@ -44,7 +41,6 @@ h2 { } // scss-docs-end font-sizes - // Headings // scss-docs-start headings-variables $headings-font-weight: 300 !important; @@ -64,68 +60,354 @@ $list-group-color: $primary !default; // CSS overrides +// Body +// +// Settings for the `` element. + +/* Body font */ +body { + letter-spacing: -0.2px !important; +} + +// Nav and footer + +/* Navbar */ + .navbar { - box-shadow: 0 0 0.2rem #0000001a, 0 0.1rem 0.4rem #0003; - transition: transform .25s cubic-bezier(.1,.7,.1,1),box-shadow .25s; + box-shadow: + 0 0 0.2rem #0000001a, + 0 0.1rem 0.4rem #0003; + transition: + transform 0.25s cubic-bezier(0.1, 0.7, 0.1, 1), + box-shadow 0.25s; } .navbar-title { - font-family: $font-family-sans-serif; - font-size: $font-size-base; - font-weight: 500; + font-family: $font-family-sans-serif; + font-size: $font-size-base; + font-weight: 500; +} + +/* Style for the version included in the website title */ +.navbar-title small { + font-size: 14px; + display: block; + padding-left: 1em; +} + +/* Style for the version included in the website title */ +.navbar-title small { + font-size: 14px; + display: block; + padding-left: 1em; +} + +/* Posit logo - navbar or footer */ +#footer-right-posit-logo { + width: 70px; + min-width: 70px; +} + +#footer-right-logo { + width: 20px; + min-width: 20px; + margin-left: -3px !important; + margin-right: -3px !important; } .nav-link { - font-family: $font-family-monospace; - text-transform: uppercase; - letter-spacing: .03em; - font-size: 14px !important; - font-weight: 500 !important; + font-family: $font-family-monospace; + text-transform: uppercase; + letter-spacing: 0.03em; + font-size: 14px !important; + font-weight: 500 !important; + color: $posit-gray !important; } +.navbar-nav .nav-link.active, +.navbar-nav .nav-link.show { + color: #000000 !important; + font-weight: 700 !important; +} + +/* Footer */ + .nav-footer { - font-family: $font-family-monospace; - text-transform: uppercase; - font-size: 14px; - border-top: solid #0000001a .01em; - align-items: center !important; + font-family: $font-family-monospace; + text-transform: uppercase; + font-size: 14px; + border-top: solid #0000001a 0.01em; + align-items: center !important; +} + +.nav-footer .nav-footer-center { + min-height: min-content; +} + +/* Footer icons */ + +/* Full Posit logo - currently, unused */ +#footer-right-full-posit-logo { + width: 70px; + min-width: 70px; +} + +/* Posit guide book */ +#footer-right-logo { + width: 24px; + min-width: 24px; + margin-left: -3px !important; + margin-right: -3px !important; + padding-top: 1px; +} + +/* Posit icon fullcolor */ +#footer-right-posit-logo { + width: 18px; + min-width: 18px; + margin-left: -3px !important; + margin-right: -3px !important; + padding-top: 1px; +} + +/* Posit logo - footer +#footer-logo { + width: 70px; + min-width: 70px; +} +*/ + +.bi-question-circle-fill { + font-size: 18px !important; +} + +.bi-lightbulb-fill { + font-size: 18px !important; +} + +// Footnotes + +.footnote-back { + font-size: 16px !important; + font-weight: 900px !important; + color: $posit-dark-blue-1; } -/* Tabs */ +// Tabs and pills + +/* Tabs */ .nav-tabs .nav-link { - text-transform: none !important; - font-family: $font-family-sans-serif; + text-transform: none !important; + font-family: $font-family-sans-serif; + color: $posit-gray !important; } -/* Mini TOC */ -.sidebar nav[role=doc-toc]>ul li a { - text-transform: none !important; - font-family: $font-family-sans-serif; - font-size: 16px; - font-weight: 300 !important; - letter-spacing: .05em !important; +.nav-tabs .nav-link.active, +.nav-tabs .nav-item.show .nav-link { + color: #000000 !important; +} + +.nav-tabs .nav-link:hover, +.nav-link:focus { + color: $posit-blue !important; +} + +/* Pills */ + +.nav-pills { + border: none !important; +} + +.nav-pills, +.panel-underline { + > .nav { + display: flex; + border: none !important; + flex-direction: row; + justify-content: center; + .nav-link { + cursor: pointer; + } + } +} + +.nav-pills > .nav .nav-link { + border: none !important; +} + +.nav-pills, +.panel-underline { + .tab-content { + padding-left: 0; + padding-right: 0; + border: none; + } +} + +.nav-pills .nav-link.active, +.nav-pills .nav-item.show .nav-link { + color: #ffffff !important; +} + +.nav-pills .nav-link:hover, +.nav-link:focus { + isolation: isolate; + color: $posit-blue !important; + border: none !important; +} + +.nav-pills .nav-link.active, +.nav-pills .show > .nav-link { + color: #ffffff !important; +} + +// Sidebar and toc + +/* Left nav */ +.sidebar-item-container .active { + font-weight: 500; } /* Left nav - letter spacing */ .sidebar-navigation li a { - letter-spacing: .03em; - font-size: 16px; + letter-spacing: 0.03em; + font-size: 16px; } +/* Left nav - letter spacing */ +.sidebar-navigation li a { + letter-spacing: -0.2px; + line-height: normal; +} -/* Posit logo - footer */ -#footer-logo { - width: 70px; - min-width: 70px; +/* Mini TOC */ +.sidebar nav[role="doc-toc"] > ul li a { + text-transform: none !important; + font-family: $font-family-sans-serif; + font-weight: 400 !important; + letter-spacing: -0.2px !important; } -/* Footer */ -.nav-footer .nav-footer-center { - min-height: min-content; +.sidebar nav[role="doc-toc"] ul > li > a.active, +.sidebar nav[role="doc-toc"] ul > li > ul > li > a.active { + font-weight: 700 !important; } +// Lists + /* List disc colors */ li::marker { - color: $primary; + color: $primary; +} + +// Callouts + +.callout.callout-style-default:not(.no-icon) div.callout-title-container { + color: $posit-dark-gray-1 !important; +} + +/* Note */ + +div.callout-note.callout { + border-left-color: $posit-blue !important; +} + +div.callout-note .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/info-circle.svg + background-image: url("") !important; +} + +div.callout-note.callout-style-default > .callout-header { + background-color: #dce7f2 !important; +} + +/* Warning */ +div.callout-warning.callout { + border-left-color: $posit-orange !important; +} + +div.callout-warning .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/exclamation-triangle.svg + background-image: url("") !important; +} + +div.callout-warning.callout-style-default > .callout-header { + background-color: #fad8ca !important; +} + +/* Important */ + +div.callout-important.callout { + border-left-color: $posit-burgundy !important; +} + +div.callout-important .callout-icon::before { + // base64 -i _extensions/posit-docs/assets/images/exclamation-circle.svg + background-image: url("") !important; +} + +div.callout-important.callout-style-default > .callout-header { + background-color: #f2dae3 !important; +} + +// Specialty headers + +/* the feature PREVIEW header */ +.preview-header > h1:after, +.preview-header > h2:after, +.preview-header > h3:after, +.preview-header > h4:after, +header h1 .preview-header { + content: "Preview feature"; + margin-left: 1em; + position: relative; + border-radius: 50rem !important; + top: -0.5em; +} + +.preview-header > h1:after, +.preview-header > h2:after, +.preview-header > h3:after, +.preview-header > h4:after, +header h1 .preview-header, +div span.preview-feature { + color: $preview-header; + border: 1px solid $preview-header-border; + font-weight: 400; + font-size: 9pt !important; + padding: 0rem 0.4rem; +} + +div span.preview-feature { + margin-left: 1em; + text-transform: uppercase; +} + +// Specialty lists + +/* Callout steps for images with multiple items/steps shown in single image */ + +ol.groovyAlpha { + list-style: none; + counter-reset: list-counter; +} + +ol.groovyAlpha li { + counter-increment: list-counter; +} + +ol.groovyAlpha li > p:before { + content: counter(list-counter, lower-alpha); + width: 20px; + height: 20px; + text-align: center; + margin-right: 10px; + color: #fff; + background-color: #fc403b; + display: inline-block; + border-radius: 10px; + font-size: 14px; + line-height: 16px; + vertical-align: middle; } diff --git a/_quarto.yml b/_quarto.yml index 3f2c9fa6..bcd59106 100644 --- a/_quarto.yml +++ b/_quarto.yml @@ -1,5 +1,6 @@ project: type: posit-docs + pre-render: just docs render: - charts/rstudio-workbench/README.md - charts/rstudio-workbench/NEWS.md @@ -19,17 +20,28 @@ project: filters: - include-code-files -format: - posit-docs-html: - toc: true - website: title: Posit Helm Charts + site-url: https://docs.posit.co/helm bread-crumbs: true repo-url: https://github.com/rstudio/helm repo-actions: [edit, issue] - page-footer: - center: Posit Helm Charts + page-footer: + left: | + Copyright © {{< env CURRENT_YEAR >}} Posit Software, PBC. All Rights Reserved. + center: | + Posit Helm Charts + right: + - icon: question-circle-fill + aria-label: 'Link to Posit Support' + href: "https://support.posit.co/hc/en-us" + - icon: lightbulb-fill + aria-label: 'Link to Posit Solutions' + href: "https://solutions.posit.co/" + - text: "" + href: "https://docs.posit.co/" + - text: "" + href: "https://posit.co/" sidebar: style: "floating" collapse-level: 1 diff --git a/charts/_templates.gotmpl b/charts/_templates.gotmpl index bce09a9a..476b8082 100644 --- a/charts/_templates.gotmpl +++ b/charts/_templates.gotmpl @@ -40,49 +40,55 @@ Workbench. {{- define "rstudio.disclaimer" }} -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. {{- end }} {{- define "rstudio.best-practices" }} -## Best Practices +## Best practices Helm charts are very useful tools for deploying resources into Kubernetes, however, they do require some familiarity with kubernetes and `helm` itself. Please ensure you have adequate training and IT support before deploying these charts into production environments. Reach out to your account representative -if you need help deciding whether helm is a good choice for your deployment. +if you need help deciding whether Helm is a good choice for your deployment. To ensure reproducibility in your environment and insulate yourself from future changes, please: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use the `helm-diff` plugin and `helm diff upgrade` to check - for breaking changes -* Read [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do + this using the: + * `helm dependency` command and the associated "Chart.lock" files _or_ + * the `--version` flag. + + :::{.callout-important} + This protects you from breaking changes** + ::: + +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. {{- end }} {{- define "rstudio.install" }} {{- $isDev := (regexMatch "[0-9]+\\.[0-9]+\\.[0-9]+-[a-zA-Z\\.0-9]+" .Version) }} -## Installing the Chart +## Installing the chart To install the chart with the release name `my-release` at version {{ template "chart.version" . }}: -```bash +```{.bash} helm repo add rstudio https://helm.rstudio.com {{- if not $isDev }} helm upgrade --install my-release rstudio/{{ template "chart.name" . }} --version={{ template "chart.version" . }} @@ -95,8 +101,9 @@ helm upgrade --install --devel my-release rstudio/{{ template "chart.name" . }} {{- end }} ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo {{ if $isDev }}--devel {{ end }}rstudio/{{ template "chart.name" . }} -l ``` @@ -106,15 +113,15 @@ helm search repo {{ if $isDev }}--devel {{ end }}rstudio/{{ template "chart.name ## Licensing -This chart supports activating the product using a license file, license key, or license server. In the case of a license file or key, we recommend against placing it in your values file directly. - -### License File +This chart supports activating the product using a *license file*. We recommend storing a license file as a `Secret` and setting the `license.file.secret` and `license.file.secretKey` values accordingly. First, create the secret declaratively with YAML or imperatively using the following command: -`kubectl create secret generic {{ .Name }}-license --from-file=licenses/{{ .Name }}.lic` +```{.bash} +kubectl create secret generic {{ .Name }}-license --from-file=licenses/{{ .Name }}.lic +``` Second, specify the following values: @@ -127,15 +134,9 @@ license: Alternatively, license files can be set during `helm install` with the following argument: -`--set-file license.file.contents=licenses/{{ .Name }}.lic` - -### License Key - -Set a license key directly in your values file (`license.key`) or during `helm install` with the argument `--set license.key=XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX`. - -### License Server - -Set a license server directly in your values file (`license.server`) or during `helm install` with the argument `--set license.server=`. +```{.bash} +--set-file license.file.contents=licenses/{{ .Name }}.lic +``` {{- end }} diff --git a/charts/posit-chronicle/Chart.yaml b/charts/posit-chronicle/Chart.yaml index d3075872..a1719d0e 100644 --- a/charts/posit-chronicle/Chart.yaml +++ b/charts/posit-chronicle/Chart.yaml @@ -1,7 +1,7 @@ apiVersion: v2 name: posit-chronicle description: Official Helm chart for Posit Chronicle Server -version: 0.3.0 +version: 0.3.1 appVersion: 2024.03.0 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png home: https://www.posit.co diff --git a/charts/posit-chronicle/NEWS.md b/charts/posit-chronicle/NEWS.md index b810a951..dd6b6472 100644 --- a/charts/posit-chronicle/NEWS.md +++ b/charts/posit-chronicle/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.3.1 + +- Documentation site updates + ## 0.3.0 - Bump Chronicle to version 2024.03.0 diff --git a/charts/posit-chronicle/README.md b/charts/posit-chronicle/README.md index fd9522a1..ea3b103e 100644 --- a/charts/posit-chronicle/README.md +++ b/charts/posit-chronicle/README.md @@ -1,6 +1,6 @@ # Posit Chronicle -![Version: 0.3.0](https://img.shields.io/badge/Version-0.3.0-informational?style=flat-square) ![AppVersion: 2024.03.0](https://img.shields.io/badge/AppVersion-2024.03.0-informational?style=flat-square) +![Version: 0.3.1](https://img.shields.io/badge/Version-0.3.1-informational?style=flat-square) ![AppVersion: 2024.03.0](https://img.shields.io/badge/AppVersion-2024.03.0-informational?style=flat-square) #### _Official Helm chart for Posit Chronicle Server_ @@ -8,29 +8,33 @@ Chronicle helps data science managers and other stakeholders understand their organization's use of other Posit products, primarily Posit Connect and Workbench. -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: -## Installing the Chart +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. -To install the chart with the release name `my-release` at version 0.3.0: +## Installing the chart -```bash +To install the chart with the release name `my-release` at version 0.3.1: + +```{.bash} helm repo add rstudio https://helm.rstudio.com -helm upgrade --install my-release rstudio/posit-chronicle --version=0.3.0 +helm upgrade --install my-release rstudio/posit-chronicle --version=0.3.1 ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo rstudio/posit-chronicle -l ``` @@ -199,5 +203,5 @@ The credentials Chronicle uses for S3 storage must have the following permission | storage.persistentVolumeSize | string | `"1Gi"` | | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-connect/Chart.lock b/charts/rstudio-connect/Chart.lock index 9ebc104b..0a3e8bb9 100644 --- a/charts/rstudio-connect/Chart.lock +++ b/charts/rstudio-connect/Chart.lock @@ -1,6 +1,6 @@ dependencies: - name: rstudio-library repository: file://../rstudio-library - version: 0.1.29 -digest: sha256:ccca30d883d295668402d63328b1d603911ef717b41207f9b3a2e4d1dd3af1a3 -generated: "2024-04-01T12:17:53.025791-04:00" + version: 0.1.30 +digest: sha256:dcf9d679b18cf99da3781b22797d639a2cbeb47b746dff7e7532b3e55261e938 +generated: "2024-05-15T19:57:52.620702-04:00" diff --git a/charts/rstudio-connect/Chart.yaml b/charts/rstudio-connect/Chart.yaml index 225d2322..a08b0773 100644 --- a/charts/rstudio-connect/Chart.yaml +++ b/charts/rstudio-connect/Chart.yaml @@ -1,6 +1,6 @@ name: rstudio-connect -description: Official Helm chart for RStudio Connect -version: 0.6.6 +description: Official Helm chart for Posit Connect +version: 0.6.7 apiVersion: v2 appVersion: 2024.04.1 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png @@ -13,7 +13,7 @@ maintainers: url: https://github.com/sol-eng dependencies: - name: rstudio-library - version: 0.1.29 + version: 0.1.30 repository: file://../rstudio-library annotations: artifacthub.io/images: | diff --git a/charts/rstudio-connect/NEWS.md b/charts/rstudio-connect/NEWS.md index 36f8c37d..682e36f8 100644 --- a/charts/rstudio-connect/NEWS.md +++ b/charts/rstudio-connect/NEWS.md @@ -1,6 +1,10 @@ # Changelog -# 0.6.6 +## 0.6.7 + +- Documentation site updates + +## 0.6.6 - Bump Connect version to 2024.04.1 diff --git a/charts/rstudio-connect/README.md b/charts/rstudio-connect/README.md index a44de207..efaf5ee7 100644 --- a/charts/rstudio-connect/README.md +++ b/charts/rstudio-connect/README.md @@ -1,67 +1,73 @@ # Posit Connect -![Version: 0.6.6](https://img.shields.io/badge/Version-0.6.6-informational?style=flat-square) ![AppVersion: 2024.04.1](https://img.shields.io/badge/AppVersion-2024.04.1-informational?style=flat-square) +![Version: 0.6.7](https://img.shields.io/badge/Version-0.6.7-informational?style=flat-square) ![AppVersion: 2024.04.1](https://img.shields.io/badge/AppVersion-2024.04.1-informational?style=flat-square) -#### _Official Helm chart for RStudio Connect_ +#### _Official Helm chart for Posit Connect_ Business Users and Collaborators use R and Python data products on [Posit Connect](https://posit.co/products/enterprise/connect/) that are published by Data Scientists. -## Best Practices +## Best practices Helm charts are very useful tools for deploying resources into Kubernetes, however, they do require some familiarity with kubernetes and `helm` itself. Please ensure you have adequate training and IT support before deploying these charts into production environments. Reach out to your account representative -if you need help deciding whether helm is a good choice for your deployment. +if you need help deciding whether Helm is a good choice for your deployment. To ensure reproducibility in your environment and insulate yourself from future changes, please: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use the `helm-diff` plugin and `helm diff upgrade` to check - for breaking changes -* Read [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do + this using the: + * `helm dependency` command and the associated "Chart.lock" files _or_ + * the `--version` flag. -## Installing the Chart + :::{.callout-important} + This protects you from breaking changes** + ::: -To install the chart with the release name `my-release` at version 0.6.6: +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. -```bash +## Installing the chart + +To install the chart with the release name `my-release` at version 0.6.7: + +```{.bash} helm repo add rstudio https://helm.rstudio.com -helm upgrade --install my-release rstudio/rstudio-connect --version=0.6.6 +helm upgrade --install my-release rstudio/rstudio-connect --version=0.6.7 ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo rstudio/rstudio-connect -l ``` -## Required Configuration +## Required configuration -This chart requires the following in order to function: +To function, this chart requires the following: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. +* A license file. See the [Licensing](#licensing) section below for more details. * A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for Connect. - * If `sharedStorage.create` is set, a PVC that relies on the default storage class will be created to generate the PersistentVolume. + * If `sharedStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the + PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `sharedStorage.create` and create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `sharedStorage.name` and `sharedStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your data directory, you'll need to mount your data in the container + * If you cannot use a `PersistentVolume` to properly mount your data directory, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes), specified in `pod.volumes` and `pod.volumeMounts`. ## Licensing -This chart supports activating the product using a license file, license key, or license server. In the case of a license file or key, we recommend against placing it in your values file directly. - -### License File +This chart supports activating the product using a *license file*. We recommend storing a license file as a `Secret` and setting the `license.file.secret` and `license.file.secretKey` values accordingly. First, create the secret declaratively with YAML or imperatively using the following command: -`kubectl create secret generic rstudio-connect-license --from-file=licenses/rstudio-connect.lic` +```{.bash} +kubectl create secret generic rstudio-connect-license --from-file=licenses/rstudio-connect.lic +``` Second, specify the following values: @@ -74,29 +80,23 @@ license: Alternatively, license files can be set during `helm install` with the following argument: -`--set-file license.file.contents=licenses/rstudio-connect.lic` - -### License Key - -Set a license key directly in your values file (`license.key`) or during `helm install` with the argument `--set license.key=XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX`. - -### License Server - -Set a license server directly in your values file (`license.server`) or during `helm install` with the argument `--set license.server=`. +```{.bash} +--set-file license.file.contents=licenses/rstudio-connect.lic +``` -## General Principles +## General principles -- In most places, we opt to pass helm values over configmaps. We translate these into the valid `.gcfg` file format +- In most places, we opt to pass Helm values over configmaps. We translate these into the valid `.gcfg` file format required by rstudio-connect. - rstudio-connect does not export many prometheus metrics on its own. Instead, we run a sidecar graphite exporter [as described here](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) -## Configuration File +## Configuration file -The configuration values all take the form of usual helm values +The configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.Postgres.Password=mypassword ... ``` @@ -145,7 +145,7 @@ The Helm `config` values are converted into the `rstudio-connect.gcfg` service c | license.file | object | `{"contents":false,"mountPath":"/etc/rstudio-licensing","mountSubPath":false,"secret":false,"secretKey":"license.lic"}` | the file section is used for licensing with a license file | | license.file.contents | bool | `false` | contents is an in-line license file | | license.file.mountPath | string | `"/etc/rstudio-licensing"` | mountPath is the place the license file will be mounted into the container | -| license.file.mountSubPath | bool | `false` | mountSubPath is whether to mount the subPath for the file secret. -- It can be preferable _not_ to enable this, because then updates propagate automatically | +| license.file.mountSubPath | bool | `false` | It can be preferable _not_ to enable this, because then updates propagate automatically | | license.file.secret | bool | `false` | secret is an existing secret with a license file in it | | license.file.secretKey | string | `"license.lic"` | secretKey is the key for the secret to use for the license file | | license.key | string | `nil` | key is the license to use | @@ -210,5 +210,5 @@ The Helm `config` values are converted into the `rstudio-connect.gcfg` service c | versionOverride | string | `""` | A Connect version to override the "tag" for the Posit Connect image and the Content Init image. Necessary until https://github.com/helm/helm/issues/8194 | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-connect/README.md.gotmpl b/charts/rstudio-connect/README.md.gotmpl index 3906063a..f39b4671 100644 --- a/charts/rstudio-connect/README.md.gotmpl +++ b/charts/rstudio-connect/README.md.gotmpl @@ -8,34 +8,35 @@ {{ template "rstudio.install" . }} -## Required Configuration +## Required configuration -This chart requires the following in order to function: +To function, this chart requires the following: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. +* A license file. See the [Licensing](#licensing) section below for more details. * A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for Connect. - * If `sharedStorage.create` is set, a PVC that relies on the default storage class will be created to generate the PersistentVolume. + * If `sharedStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the + PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `sharedStorage.create` and create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `sharedStorage.name` and `sharedStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your data directory, you'll need to mount your data in the container + * If you cannot use a `PersistentVolume` to properly mount your data directory, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes), specified in `pod.volumes` and `pod.volumeMounts`. {{ template "rstudio.licensing" . }} -## General Principles +## General principles -- In most places, we opt to pass helm values over configmaps. We translate these into the valid `.gcfg` file format +- In most places, we opt to pass Helm values over configmaps. We translate these into the valid `.gcfg` file format required by {{ template "chart.name" . }}. - {{ template "chart.name" . }} does not export many prometheus metrics on its own. Instead, we run a sidecar graphite exporter [as described here](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) -## Configuration File +## Configuration file -The configuration values all take the form of usual helm values +The configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.Postgres.Password=mypassword ... ``` diff --git a/charts/rstudio-launcher-rbac/Chart.lock b/charts/rstudio-launcher-rbac/Chart.lock index 996a35e0..134100c0 100644 --- a/charts/rstudio-launcher-rbac/Chart.lock +++ b/charts/rstudio-launcher-rbac/Chart.lock @@ -1,6 +1,6 @@ dependencies: - name: rstudio-library repository: file://../rstudio-library - version: 0.1.29 -digest: sha256:ccca30d883d295668402d63328b1d603911ef717b41207f9b3a2e4d1dd3af1a3 -generated: "2024-04-01T12:17:21.579972-04:00" + version: 0.1.30 +digest: sha256:dcf9d679b18cf99da3781b22797d639a2cbeb47b746dff7e7532b3e55261e938 +generated: "2024-05-15T19:57:55.735705-04:00" diff --git a/charts/rstudio-launcher-rbac/Chart.yaml b/charts/rstudio-launcher-rbac/Chart.yaml index d83849eb..4d7dbdb7 100644 --- a/charts/rstudio-launcher-rbac/Chart.yaml +++ b/charts/rstudio-launcher-rbac/Chart.yaml @@ -2,8 +2,8 @@ apiVersion: v2 name: rstudio-launcher-rbac description: RBAC definition for the RStudio Job Launcher type: application -version: 0.2.20 -appVersion: 0.2.20 +version: 0.2.21 +appVersion: 0.2.21 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png sources: - https://github.com/rstudio/helm @@ -13,7 +13,7 @@ maintainers: url: https://github.com/sol-eng dependencies: - name: rstudio-library - version: 0.1.29 + version: 0.1.30 repository: file://../rstudio-library keywords: - "data science" diff --git a/charts/rstudio-launcher-rbac/NEWS.md b/charts/rstudio-launcher-rbac/NEWS.md index 03e29eb4..e3834ea0 100644 --- a/charts/rstudio-launcher-rbac/NEWS.md +++ b/charts/rstudio-launcher-rbac/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.2.21 + +- Documentation site updates + ## 0.2.20 - Updates to support standalone documentation site diff --git a/charts/rstudio-launcher-rbac/README.md b/charts/rstudio-launcher-rbac/README.md index 313d989f..abe0df9c 100644 --- a/charts/rstudio-launcher-rbac/README.md +++ b/charts/rstudio-launcher-rbac/README.md @@ -1,32 +1,36 @@ # rstudio-launcher-rbac -![Version: 0.2.20](https://img.shields.io/badge/Version-0.2.20-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.2.20](https://img.shields.io/badge/AppVersion-0.2.20-informational?style=flat-square) +![Version: 0.2.21](https://img.shields.io/badge/Version-0.2.21-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.2.21](https://img.shields.io/badge/AppVersion-0.2.21-informational?style=flat-square) #### _RBAC definition for the RStudio Job Launcher_ -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: -## Installing the Chart +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. -To install the chart with the release name `my-release` at version 0.2.20: +## Installing the chart -```bash +To install the chart with the release name `my-release` at version 0.2.21: + +```{.bash} helm repo add rstudio https://helm.rstudio.com -helm upgrade --install my-release rstudio/rstudio-launcher-rbac --version=0.2.20 +helm upgrade --install my-release rstudio/rstudio-launcher-rbac --version=0.2.21 ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo rstudio/rstudio-launcher-rbac -l ``` @@ -58,5 +62,5 @@ helm template -n rstudio rstudio-launcher-rbac rstudio/rstudio-launcher-rbac | targetNamespaces | list | `[]` | The targetNamespaces that the launcher will be able to launch sessions into | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-library/Chart.yaml b/charts/rstudio-library/Chart.yaml index 3ca284ce..5be0c871 100644 --- a/charts/rstudio-library/Chart.yaml +++ b/charts/rstudio-library/Chart.yaml @@ -2,8 +2,8 @@ apiVersion: v2 name: rstudio-library description: Helm library helpers for use by official RStudio charts type: library -version: 0.1.29 -appVersion: 0.1.29 +version: 0.1.30 +appVersion: 0.1.30 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png home: https://www.rstudio.com diff --git a/charts/rstudio-library/NEWS.md b/charts/rstudio-library/NEWS.md index 9ac54457..0e68647c 100644 --- a/charts/rstudio-library/NEWS.md +++ b/charts/rstudio-library/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.1.30 + +- Documentation site updates + ## 0.1.29 - Updates to support standalone documentation site diff --git a/charts/rstudio-library/README.md b/charts/rstudio-library/README.md index 86e0ab9d..142c0114 100644 --- a/charts/rstudio-library/README.md +++ b/charts/rstudio-library/README.md @@ -1,20 +1,23 @@ # rstudio-library -![Version: 0.1.29](https://img.shields.io/badge/Version-0.1.29-informational?style=flat-square) ![Type: library](https://img.shields.io/badge/Type-library-informational?style=flat-square) ![AppVersion: 0.1.29](https://img.shields.io/badge/AppVersion-0.1.29-informational?style=flat-square) +![Version: 0.1.30](https://img.shields.io/badge/Version-0.1.30-informational?style=flat-square) ![Type: library](https://img.shields.io/badge/Type-library-informational?style=flat-square) ![AppVersion: 0.1.30](https://img.shields.io/badge/AppVersion-0.1.30-informational?style=flat-square) #### _Helm library helpers for use by official RStudio charts_ -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: + +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. # Usage @@ -31,5 +34,5 @@ If you are curious about its usage, take a look at the other charts (i.e. `rstud for `rstudio-library` in the `templates/` directory. ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-pm/Chart.lock b/charts/rstudio-pm/Chart.lock index 56bdeeeb..82f8ef24 100644 --- a/charts/rstudio-pm/Chart.lock +++ b/charts/rstudio-pm/Chart.lock @@ -1,6 +1,6 @@ dependencies: - name: rstudio-library repository: file://../rstudio-library - version: 0.1.29 -digest: sha256:ccca30d883d295668402d63328b1d603911ef717b41207f9b3a2e4d1dd3af1a3 -generated: "2024-04-01T12:17:57.728915-04:00" + version: 0.1.30 +digest: sha256:dcf9d679b18cf99da3781b22797d639a2cbeb47b746dff7e7532b3e55261e938 +generated: "2024-05-15T19:57:58.863614-04:00" diff --git a/charts/rstudio-pm/Chart.yaml b/charts/rstudio-pm/Chart.yaml index 76a4357d..e2747d72 100644 --- a/charts/rstudio-pm/Chart.yaml +++ b/charts/rstudio-pm/Chart.yaml @@ -1,6 +1,6 @@ name: rstudio-pm -description: Official Helm chart for RStudio Package Manager -version: 0.5.25 +description: Official Helm chart for Posit Package Manager +version: 0.5.26 apiVersion: v2 appVersion: 2024.04.0 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png @@ -14,7 +14,7 @@ maintainers: url: https://github.com/rstudio/helm dependencies: - name: rstudio-library - version: 0.1.29 + version: 0.1.30 repository: file://../rstudio-library annotations: artifacthub.io/images: | diff --git a/charts/rstudio-pm/NEWS.md b/charts/rstudio-pm/NEWS.md index 491bdc2b..2d6c985f 100644 --- a/charts/rstudio-pm/NEWS.md +++ b/charts/rstudio-pm/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.5.26 + +- Documentation site updates + ## 0.5.25 - Update default Posit Package Manager version to 2024.04.0-20 diff --git a/charts/rstudio-pm/README.md b/charts/rstudio-pm/README.md index b6f9d265..abc3f0b3 100644 --- a/charts/rstudio-pm/README.md +++ b/charts/rstudio-pm/README.md @@ -1,71 +1,76 @@ # Posit Package Manager -![Version: 0.5.25](https://img.shields.io/badge/Version-0.5.25-informational?style=flat-square) ![AppVersion: 2024.04.0](https://img.shields.io/badge/AppVersion-2024.04.0-informational?style=flat-square) +![Version: 0.5.26](https://img.shields.io/badge/Version-0.5.26-informational?style=flat-square) ![AppVersion: 2024.04.0](https://img.shields.io/badge/AppVersion-2024.04.0-informational?style=flat-square) -#### _Official Helm chart for RStudio Package Manager_ +#### _Official Helm chart for Posit Package Manager_ IT Administrators use [Posit Package Manager](https://posit.co/products/enterprise/package-manager/) to control and manage R and Python packages that Data Scientists need to create and share data products. -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: -## Installing the Chart +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. -To install the chart with the release name `my-release` at version 0.5.25: +## Installing the chart -```bash +To install the chart with the release name `my-release` at version 0.5.26: + +```{.bash} helm repo add rstudio https://helm.rstudio.com -helm upgrade --install my-release rstudio/rstudio-pm --version=0.5.25 +helm upgrade --install my-release rstudio/rstudio-pm --version=0.5.26 ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo rstudio/rstudio-pm -l ``` -## Upgrade Guidance +## Upgrade guidance ### 0.4.0 - When upgrading to version 0.4.0 or later, the Package Manager service moves from running as `root` to running as - the `rstudio-pm` user (with `uid:gid` `999:999`). A `chown` of persistent storage may be required. We will try to - fix this up automatically. Set `enableMigrations=false` to disable the automatic fixup / hook. + the `rstudio-pm` user (with `uid:gid` `999:999`). +- A `chown` of persistent storage may be required. The team is working to implement an automatic fix. To disable the automatic fix/hook, set `enableMigrations=false`. -## Required Configuration +## Required configuration This chart requires the following in order to function: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. -* A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for RSPM. - * If `sharedStorage.create` is set, a PVC that relies on the default storage class will be created to generate the PersistentVolume. +* A license file. See the [Licensing](#licensing) section below for more details. +* A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for Package Manager. + * If `sharedStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the + PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `sharedStorage.create` and create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `sharedStorage.name` and `sharedStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your data directory, you'll need to mount your data in the container + * If you cannot use a `PersistentVolume` to properly mount your data directory, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes), specified in `pod.volumes` and `pod.volumeMounts`. * Alternatively, S3 storage can be used. See the [S3 Configuration](#s3-configuration) section for details. ## Licensing -This chart supports activating the product using a license file, license key, or license server. In the case of a license file or key, we recommend against placing it in your values file directly. - -### License File +This chart supports activating the product using a *license file*. We recommend storing a license file as a `Secret` and setting the `license.file.secret` and `license.file.secretKey` values accordingly. First, create the secret declaratively with YAML or imperatively using the following command: -`kubectl create secret generic rstudio-pm-license --from-file=licenses/rstudio-pm.lic` +```{.bash} +kubectl create secret generic rstudio-pm-license --from-file=licenses/rstudio-pm.lic +``` Second, specify the following values: @@ -78,20 +83,14 @@ license: Alternatively, license files can be set during `helm install` with the following argument: -`--set-file license.file.contents=licenses/rstudio-pm.lic` - -### License Key - -Set a license key directly in your values file (`license.key`) or during `helm install` with the argument `--set license.key=XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX`. - -### License Server - -Set a license server directly in your values file (`license.server`) or during `helm install` with the argument `--set license.server=`. +```{.bash} +--set-file license.file.contents=licenses/rstudio-pm.lic +``` -## S3 Configuration +## S3 configuration Package Manager [can be configured to store its data in S3 -buckets](https://docs.rstudio.com/rspm/admin/files-directories/#data-destinations), +buckets](https://docs.posit.co/rspm/admin/file-storage/file-storage/#data-destinations), which eliminates the need to provision shared storage for multiple replicas. A `values.yaml` file using S3 might contain something like the following: @@ -129,17 +128,17 @@ awsSecretAccessKey: your-secret-access-key Bear in mind that static, long-lived credentials are the least secure option and should be avoided if at all possible. -## General Principles +## General principles -- In most places, we opt to pass helm values over configmaps. We translate these into the valid `.gcfg` file format +- In most places, we opt to pass Helm values over configmaps. We translate these into the valid `.gcfg` file format required by rstudio-pm. -## Configuration File +## Configuration file -The configuration values all take the form of usual helm values +The configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.Postgres.Password=mypassword ... ``` @@ -174,7 +173,7 @@ The Helm `config` values are converted into the `rstudio-pm.gcfg` service config | license.file | object | `{"contents":false,"mountPath":"/etc/rstudio-licensing","mountSubPath":false,"secret":false,"secretKey":"license.lic"}` | the file section is used for licensing with a license file | | license.file.contents | bool | `false` | contents is an in-line license file | | license.file.mountPath | string | `"/etc/rstudio-licensing"` | mountPath is the place the license file will be mounted into the container | -| license.file.mountSubPath | bool | `false` | mountSubPath is whether to mount the subPath for the file secret. -- It can be preferable _not_ to enable this, because then updates propagate automatically | +| license.file.mountSubPath | bool | `false` | It can be preferable _not_ to enable this, because then updates propagate automatically | | license.file.secret | bool | `false` | secret is an existing secret with a license file in it | | license.file.secretKey | string | `"license.lic"` | secretKey is the key for the secret to use for the license file | | license.key | string | `nil` | key is the license to use | @@ -207,7 +206,7 @@ The Helm `config` values are converted into the `rstudio-pm.gcfg` service config | service.type | string | `"ClusterIP"` | The service type, usually ClusterIP (in-cluster only) or LoadBalancer (to expose the service using your cloud provider's load balancer) | | serviceAccount.annotations | object | `{}` | Annotations for the ServiceAccount, if any | | serviceAccount.create | bool | `true` | Whether to create a [Service Account](https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/) | -| serviceAccount.labels | object | `{}` | | +| serviceAccount.labels | object | `{}` | Labels for the ServiceAccount, if any | | serviceAccount.name | string | When `serviceAccount.create` is `true` this defaults to the full name of the release | ServiceAccount to use, if any, or an explicit name for the one we create | | serviceMonitor.additionalLabels | object | `{}` | additionalLabels normally includes the release name of the Prometheus Operator | | serviceMonitor.enabled | bool | `false` | Whether to create a ServiceMonitor CRD for use with a Prometheus Operator | @@ -230,5 +229,5 @@ The Helm `config` values are converted into the `rstudio-pm.gcfg` service config | versionOverride | string | `""` | A Package Manager version to override the "tag" for the RStudio Package Manager image. Necessary until https://github.com/helm/helm/issues/8194 | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-pm/README.md.gotmpl b/charts/rstudio-pm/README.md.gotmpl index d0d4cc81..99c3aa41 100644 --- a/charts/rstudio-pm/README.md.gotmpl +++ b/charts/rstudio-pm/README.md.gotmpl @@ -8,34 +8,35 @@ {{ template "rstudio.install" . }} -## Upgrade Guidance +## Upgrade guidance ### 0.4.0 - When upgrading to version 0.4.0 or later, the Package Manager service moves from running as `root` to running as - the `rstudio-pm` user (with `uid:gid` `999:999`). A `chown` of persistent storage may be required. We will try to - fix this up automatically. Set `enableMigrations=false` to disable the automatic fixup / hook. + the `rstudio-pm` user (with `uid:gid` `999:999`). +- A `chown` of persistent storage may be required. The team is working to implement an automatic fix. To disable the automatic fix/hook, set `enableMigrations=false`. -## Required Configuration +## Required configuration This chart requires the following in order to function: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. -* A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for RSPM. - * If `sharedStorage.create` is set, a PVC that relies on the default storage class will be created to generate the PersistentVolume. +* A license file. See the [Licensing](#licensing) section below for more details. +* A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the data directory for Package Manager. + * If `sharedStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the + PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `sharedStorage.create` and create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `sharedStorage.name` and `sharedStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your data directory, you'll need to mount your data in the container + * If you cannot use a `PersistentVolume` to properly mount your data directory, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes), specified in `pod.volumes` and `pod.volumeMounts`. * Alternatively, S3 storage can be used. See the [S3 Configuration](#s3-configuration) section for details. {{ template "rstudio.licensing" . }} -## S3 Configuration +## S3 configuration Package Manager [can be configured to store its data in S3 -buckets](https://docs.rstudio.com/rspm/admin/files-directories/#data-destinations), +buckets](https://docs.posit.co/rspm/admin/file-storage/file-storage/#data-destinations), which eliminates the need to provision shared storage for multiple replicas. A `values.yaml` file using S3 might contain something like the following: @@ -73,17 +74,17 @@ awsSecretAccessKey: your-secret-access-key Bear in mind that static, long-lived credentials are the least secure option and should be avoided if at all possible. -## General Principles +## General principles -- In most places, we opt to pass helm values over configmaps. We translate these into the valid `.gcfg` file format +- In most places, we opt to pass Helm values over configmaps. We translate these into the valid `.gcfg` file format required by {{ template "chart.name" . }}. -## Configuration File +## Configuration file -The configuration values all take the form of usual helm values +The configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.Postgres.Password=mypassword ... ``` diff --git a/charts/rstudio-workbench/Chart.lock b/charts/rstudio-workbench/Chart.lock index 0c73882b..f139bc12 100644 --- a/charts/rstudio-workbench/Chart.lock +++ b/charts/rstudio-workbench/Chart.lock @@ -1,6 +1,6 @@ dependencies: - name: rstudio-library repository: file://../rstudio-library - version: 0.1.29 -digest: sha256:ccca30d883d295668402d63328b1d603911ef717b41207f9b3a2e4d1dd3af1a3 -generated: "2024-04-01T12:18:00.109138-04:00" + version: 0.1.30 +digest: sha256:dcf9d679b18cf99da3781b22797d639a2cbeb47b746dff7e7532b3e55261e938 +generated: "2024-05-15T19:58:02.13077-04:00" diff --git a/charts/rstudio-workbench/Chart.yaml b/charts/rstudio-workbench/Chart.yaml index b44fb106..56b31234 100644 --- a/charts/rstudio-workbench/Chart.yaml +++ b/charts/rstudio-workbench/Chart.yaml @@ -1,6 +1,6 @@ name: rstudio-workbench -description: Official Helm chart for RStudio Workbench -version: 0.7.3 +description: Official Helm chart for Posit Workbench +version: 0.7.4 apiVersion: v2 appVersion: 2024.04.0 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png @@ -13,7 +13,7 @@ maintainers: url: https://github.com/sol-eng dependencies: - name: rstudio-library - version: 0.1.29 + version: 0.1.30 repository: file://../rstudio-library annotations: artifacthub.io/images: | diff --git a/charts/rstudio-workbench/NEWS.md b/charts/rstudio-workbench/NEWS.md index 1f0e7e46..f5efbca9 100644 --- a/charts/rstudio-workbench/NEWS.md +++ b/charts/rstudio-workbench/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.7.4 + +- Documentation site updates + ## 0.7.3 - Bump Workbench version to 2024.04.0 diff --git a/charts/rstudio-workbench/README.md b/charts/rstudio-workbench/README.md index 9cda63d7..85bef800 100644 --- a/charts/rstudio-workbench/README.md +++ b/charts/rstudio-workbench/README.md @@ -1,87 +1,94 @@ # Posit Workbench -![Version: 0.7.3](https://img.shields.io/badge/Version-0.7.3-informational?style=flat-square) ![AppVersion: 2024.04.0](https://img.shields.io/badge/AppVersion-2024.04.0-informational?style=flat-square) +![Version: 0.7.4](https://img.shields.io/badge/Version-0.7.4-informational?style=flat-square) ![AppVersion: 2024.04.0](https://img.shields.io/badge/AppVersion-2024.04.0-informational?style=flat-square) -#### _Official Helm chart for RStudio Workbench_ +#### _Official Helm chart for Posit Workbench_ Data Scientists use [Posit Workbench](https://posit.co/products/enterprise/workbench/) to analyze data and create data products using R and Python. -## For Production +## For production -To ensure a stable production deployment, please: +To ensure a stable production deployment: -* Ensure you "pin" the version of the Helm chart that you are using. You can do - this using the `helm dependency` command and the associated "Chart.lock" files - or the `--version` flag. **IMPORTANT: This protects you from breaking changes** -* Before upgrading, to avoid breaking changes, use `helm diff upgrade` to check - for breaking changes -* Pay close attention to [`NEWS.md`](./NEWS.md) for updates on breaking - changes, as well as documentation below on how to use the chart +* "Pin" the version of the Helm chart that you are using. You can do this using the: + * `helm dependency` command *and* the associated "Chart.lock" files *or* + * the `--version` flag. + + ::: {.callout-important} + This protects you from breaking changes. + ::: -## Installing the Chart +* Before upgrading check for breaking changes using `helm-diff` plugin and `helm diff upgrade`. +* Read [`NEWS.md`](./NEWS.md) for updates on breaking changes and the documentation below on how to use the chart. -To install the chart with the release name `my-release` at version 0.7.3: +## Installing the chart -```bash +To install the chart with the release name `my-release` at version 0.7.4: + +```{.bash} helm repo add rstudio https://helm.rstudio.com -helm upgrade --install my-release rstudio/rstudio-workbench --version=0.7.3 +helm upgrade --install my-release rstudio/rstudio-workbench --version=0.7.4 ``` -To explore other chart versions, take a look at: -``` +To explore other chart versions, look at: + +```{.bash} helm search repo rstudio/rstudio-workbench -l ``` -## Required Configuration +## Required configuration -This chart requires the following in order to function: +To function, this chart requires the following: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. +* A license file. See the [Licensing](#licensing) section below for more details. * A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the home directory for users. - * If `homeStorage.create` is set, a PVC that relies on the default storage class will be created to generate the + * If `homeStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use - with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `homeStorage.create` and - create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying + with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend that you: + * Disable `homeStorage.create` and + create your own `PersistentVolume` and `PersistentVolumeClaim`, then + * Mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `homeStorage.name` and `homeStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your users' home directories, you'll need to mount your + * If you cannot use a `PersistentVolume` to properly mount your users' home directories, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes/#nfs), specified in `pod.volumes` and `pod.volumeMounts`. - * If you cannot use a `Volume` to mount the directories, you'll need to manually mount them during container startup + * If you cannot use a `Volume` to mount the directories, manually mount them during container startup with a mechanism similar to what is described below for joining to auth domains. - * If not using `homeStorage.create`, you'll need to configure `config.serverDcf.launcher-mounts` to ensure that the correct mounts are used when users create new sessions. -* If using load balancing (by setting `replicas > 1`), you will need similar storage defined for `sharedStorage` to + * If not using `homeStorage.create`, configure `config.serverDcf.launcher-mounts` to ensure that the correct mounts are used when users create new sessions. +* If using load balancing (by setting `replicas > 1`), you need similar storage defined for `sharedStorage` to store shared project configuration. However, you can also configure the product to store its shared data underneath `/home` by setting `config.server.rserver\.conf.server-shared-storage-path=/home/some-shared-dir`. * A method to join the deployed `rstudio-workbench` container to your auth domain. The default `rstudio/rstudio-workbench` image has `sssd` installed and started by default. You can include `sssd` configuration in `config.userProvisioning` like so: -```yaml -config: - userProvisioning: - mysssd.conf: - sssd: - config_file_version: 2 - services: nss, pam - domains: rstudio.com - domain/rstudio.com: - id_provider: ldap - auth_provider: ldap -``` -## Licensing + ```yaml + config: + userProvisioning: + mysssd.conf: + sssd: + config_file_version: 2 + services: nss, pam + domains: rstudio.com + domain/rstudio.com: + id_provider: ldap + auth_provider: ldap + ``` -This chart supports activating the product using a license file, license key, or license server. In the case of a license file or key, we recommend against placing it in your values file directly. +## Licensing -### License File +This chart supports activating the product using a *license file*. We recommend storing a license file as a `Secret` and setting the `license.file.secret` and `license.file.secretKey` values accordingly. First, create the secret declaratively with YAML or imperatively using the following command: -`kubectl create secret generic rstudio-workbench-license --from-file=licenses/rstudio-workbench.lic` +```{.bash} +kubectl create secret generic rstudio-workbench-license --from-file=licenses/rstudio-workbench.lic +``` Second, specify the following values: @@ -94,35 +101,28 @@ license: Alternatively, license files can be set during `helm install` with the following argument: -`--set-file license.file.contents=licenses/rstudio-workbench.lic` - -### License Key - -Set a license key directly in your values file (`license.key`) or during `helm install` with the argument `--set license.key=XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX`. - -### License Server - -Set a license server directly in your values file (`license.server`) or during `helm install` with the argument `--set license.server=`. +```{.bash} +--set-file license.file.contents=licenses/rstudio-workbench.lic +``` -## General Principles +## General principles - In most places, we opt to pass Helm values directly into ConfigMaps. We automatically translate these into the - valid `.ini` or `.dcf` file formats required by RStudio Workbench. Those config files and their mount locations are - below. -- If you need to modify the jobs launched by RStudio Workbench, you want to use `job-json-overrides`. There is a section on this below - and [a support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes) - on the topic in general. -- The prestart scripts for RStudio Workbench and RStudio Launcher are highly customized to: - - Get the service account information off of the RStudio Workbench pod for use in launching jobs -- RStudio Workbench does not export prometheus metrics on its own. Instead, we run a sidecar graphite exporter - [as described here](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) + valid `.ini` or `.dcf` file formats required by Workbench. + - Those configuration files and their mount locations are covered in the [Configuration files](#configuration-files) section below. +- If you need to modify the jobs launched by Workbench, use `job-json-overrides`. + - Review the [Job Json overrides](#job-json-overrides) section on this below. For general information, see [a support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes). +- The prestart scripts for Workbench and Posit Job Launcher are highly customized to get the service account information off of the Workbench pod for use in launching jobs. +- Workbench does not export prometheus metrics on its own. Instead, we run a sidecar graphite exporter. + - This is described in the + [Monitoring Posit Team Using Prometheus and Graphite](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) support article. ## Configuration files -These configuration values all take the form of usual helm values +These configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.secret.database\.conf.password=mypassword ... ``` @@ -136,130 +136,133 @@ config: ``` The names of files are dynamically used, so you can add new files as needed. Beware that some files have default values, -so moving them can have adverse effects. Also, if you use a different mounting paradigm, you will need to change -the `XDG_CONFIG_DIRS` environment variable +so moving them can have adverse effects. Also, if you use a different mounting paradigm, you need to change +the `XDG_CONFIG_DIRS` environment variable. - Session Configuration - These configuration files are mounted into the server and - are mounted into the session pods as well. + are mounted into the session pods. - `repos.conf`, `rsession.conf`, `notifications.conf` - - located in the `config.session.<< name of file >>` helm values - - mounted at `/mnt/session-configmap/rstudio/` -- Session Secret Configuration - - These configuration files are mounted into the server and session pods as well - - `odbc.ini` and other similar shared secrets - - located in `config.sessionSecret.<< name of file>>` helm values - - mounted at `/mnt/session-secret/` -- Secret Configuration - - These configuration files are mounted into the server with more restrictive permissions (0600) + - Located in:
`config.session.<< name of file >>` Helm values + - Mounted at:
`/mnt/session-configmap/rstudio/` +- Session Secret Configuration: + - These configuration files are mounted into the server and session pods. + - `odbc.ini` and other similar shared secrets. + - Located in:
`config.sessionSecret.<< name of file>>` Helm values + - Mounted at:
`/mnt/session-secret/` +- Secret Configuration: + - These configuration files are mounted into the server with more restrictive permissions (0600). - `database.conf`, `openid-client-secret`, `databricks.conf` - - They are located in the `config.secret.<< name of file >>` helm values - - mounted at `/mnt/secret-configmap/rstudio/` -- Server Configuration - - These configuration files are mounted into the server (.ini file format) + - Located in:
`config.secret.<< name of file >>` Helm values + - Mounted at:
`/mnt/secret-configmap/rstudio/` +- Server Configuration: + - These configuration files are mounted into the server (.ini file format). - `rserver.conf`, `launcher.conf`, `jupyter.conf`, `logging.conf` - - They are located at `config.server.<< name of file >>` helm values - - mounted at `/mnt/configmap/rstudio/` -- Server DCF Configuration - - These configuration files are mounted into the server (.dcf file format) + - Located at:
`config.server.<< name of file >>` Helm values + - Mounted at:
`/mnt/configmap/rstudio/` +- Server DCF Configuration: + - These configuration files are mounted into the server (.dcf file format). - `launcher-mounts`, `launcher-env` - - They are located at `config.serverDcf.<< name of file >>` helm values - - included at `/mnt/configmap/rstudio/` -- Profiles Configuration - - These configuration files are mounted into the server (.ini file format) + - Located at:
`config.serverDcf.<< name of file >>` Helm values + - Included at:
`/mnt/configmap/rstudio/` +- Profiles Configuration: + - These configuration files are mounted into the server (.ini file format). - `launcher.kubernetes.profiles.conf` - - They are located at `config.profiles.<< name of file >>` helm values - - included at `/mnt/configmap/rstudio/` - - See the `Profiles` section below for more information -- Prestart - - This is provided by the helm chart in a configmap - - It is mounted into the pod at `/scripts/` - - `prestart-workbench.bash` is used to start workbench - - `prestart-launcher.bash` is used to start launcher -- User Provisioning Configuration - - These configuration files are used for configuring user provisioning (i.e. `sssd`) - - Located at `config.userProvisioning.<< name of file >>` helm values - - Mounted onto `/etc/sssd/conf.d/` with `0600` permissions by default -- Custom Startup Configuration - - `supervisord` service / unit definition `.conf` files - - Located at `config.startupCustom.<< name of file >>` helm values - - Will use the `.ini` file format, by default - - Mounted at `/startup/custom` - - As with all config files above, can override with a verbatim string if desired, like so: -```yaml -config: - startupCustom: - myfile.conf: | - file-used-verbatim -``` -- PAM configuration - - `pam` configuration files - - Located at `config.pam.<< name of file >>` helm values - - Will be mounted verbatim as individual files (using `subPath` mounts) at `/etc/pam.d/<< name of file >>` + - They are located at `config.profiles.<< name of file >>` Helm values + - Included at:
`/mnt/configmap/rstudio/` + - See the [Profiles](#rstudio-profiles) section below for more information. +- Prestart: + - This is provided by the Helm chart in a configmap. + - It is mounted into the pod at `/scripts/`. + - `prestart-workbench.bash` is used to start workbench. + - `prestart-launcher.bash` is used to start launcher. +- User Provisioning Configuration: + - These configuration files are used for configuring user provisioning (i.e., `sssd`). + - Located at:
`config.userProvisioning.<< name of file >>` Helm values + - Mounted onto:
`/etc/sssd/conf.d/` with `0600` permissions by default. +- Custom Startup Configuration: + - `supervisord` service / unit definition `.conf` files. + - Use the `.ini` file format by default. + - Mounted at:
`/startup/custom` + - As with all configuration files above, you can override with a verbatim string if desired: + - Located at:
`config.startupCustom.<< name of file >>` Helm values: + ```yaml + config: + startupCustom: + myfile.conf: | + file-used-verbatim + ``` +- PAM configuration: + - `pam` configuration files. + - Located at:
`config.pam.<< name of file >>` Helm values + - Mounted verbatim as individual files (using `subPath` mounts) at:
`/etc/pam.d/<< name of file >>` -### Configuring R and Python repositories - -#### R repositories +#### Python repositories -R package repositories can be configured with `config.session.repos.conf`. +pip can be configured with `config.session.pip.conf`. To ensure `pip.conf` is mounted into the session pods, it is important that: -``` -config: - session: - repos.conf: - CRAN: https://packagemanager.posit.co/cran/__linux__/jammy/latest -``` +- `launcher.useTemplates: true` is set +- `pip.conf` settings are listed under `config.session` as shown in the following example for adding Posit Public Package Manager's PyPI: -For more information about configuring CRAN repositories in Workbench refer to the [Admin Guide](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/package_installation.html#cran-repositories). + ```yaml + launcher: + useTemplates: true -#### Python repositories + config: + session: + pip.conf: + "global": + index-url: https://packagemanager.posit.co/pypi/latest/simple + trusted-host: packagemanager.posit.co + ``` -pip can be configured with `config.session.pip.conf`. To ensure `pip.conf` is mounted into the session pods it is important that `launcher.useTemplates: true` is set and `pip.conf` settings are listed under `config.session` like in the example below for adding Posit Public Package Manager's PyPI. +#### R repositories -``` -launcher: - useTemplates: true +R package repositories can be configured with `config.session.repos.conf`: +```yaml config: session: - pip.conf: - "global": - index-url: https://packagemanager.posit.co/pypi/latest/simple - trusted-host: packagemanager.posit.co + repos.conf: + CRAN: https://packagemanager.posit.co/cran/__linux__/jammy/latest ``` -## User Provisioning +For more information about configuring CRAN repositories in Workbench, see the [Posit Workbench Administrator Guide's - Package Installation > CRAN repositories](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/package_installation.html#cran-repositories) section. -Provisioning users in RStudio Workbench containers is challenging. Session images have users created automatically (with -consistent UIDs / GIDs), but creating users in the Workbench containers is a responsibility that falls to the -administrator today. +## User provisioning + +Provisioning users in Workbench containers is challenging. Session images create users automatically (with +consistent UIDs / GIDs). However, creating users in the Workbench containers is a responsibility that falls to the +administrator. The most common way to provision users is via `sssd`. -The [latest RStudio Workbench container](https://github.com/rstudio/rstudio-docker-products/tree/main/workbench#user-provisioning) +The [latest Workbench container](https://github.com/rstudio/rstudio-docker-products/tree/main/workbench#user-provisioning) has `sssd` included and running by default (see `userProvisioning` configuration files above). -The other way that this can be managed is via a lightweight "startup service" (runs once at startup and then sleeps forever) +The other way that this can be managed is via a lightweight startup service (runs once at startup and then sleeps forever) or a polling service (checks at regular intervals). Either can be written easily in `bash` or another programming language. -However, it is important to be careful of a few points: -- UID / GID consistency: linux usernames and their matching to UID/GID must be consistent across all nodes and across - time. Failing this can cause security issues and access by some users to files they should not be allowed to see -- usernames cannot have `@`. The `@` sign (often used in emails with SSO) is a problem for RStudio Workbench because - some operating systems disallow `@` signs in linux usernames -- `supervisord` is configured by default to exit if any of its child processes exit. If you use `config.startupCustom` - to configure a user management service, be careful that it does not exit unnecessarily +However, it is important to use caution for the following: + +- UID / GID consistency: + - Linux usernames and their matching to UID/GID must be consistent across all nodes and across time. + - Failing can cause security issues and access by some users to access view they should not be allowed to see. +- Usernames cannot have `@`. + - The `@` sign (often used in emails with SSO) is a problem for Workbench because some operating systems disallow `@` signs in linux usernames. +- `supervisord` is configured by default to exit if any of its child processes exit. + - If you use `config.startupCustom` to configure a user management service, be careful that it does not exit unnecessarily. -We do not provide such a service out of the box because we intend for RStudio Workbench to solve this problem in a -future release. Please get in touch with your account representative if you have feedback or questions about this +We do not provide such a service out-of-the box because we intend for Workbench to solve this problem in a +future release. Please contact your account representative if you have feedback or questions about this workflow. ### PAM -When starting sessions on RStudio Workbench, PAM configuration is often very important, even if PAM is not being used as -an authentication mechanism. The RStudio Workbench helm chart allows creating custom PAM files via the `config.pam` +When starting sessions on Workbench, PAM configuration is often very important, even if PAM is not being used as +an authentication mechanism. The Workbench Helm chart allows creating custom PAM files via the `config.pam` values section. -Each key under `config.pam` will become a PAM config file, and will be mounted into `/etc/pam.d/` in the container. For +Each key under `config.pam` becomes a PAM configuration file, and is mounted into `/etc/pam.d/` in the container. For example: ```yaml @@ -273,23 +276,23 @@ config: # will be used verbatim ``` -## RStudio Profiles +## RStudio profiles Profiles are used to define product behavior (in `.ini` file format) based on user and group membership. Sections define whether a set of configurations is applied to a user's jobs based on the following criteria: -- if section header is `[*]`, it applies to all users -- if a user's username is `myusername`, the section `[myusername]` will apply to them -- if a user is in the `allusers` group, then the section `[@allusers]` will apply to them +- If section header is `[*]`, it applies to all users. +- If a user's username is `myusername`, the section `[myusername]` applies to them. +- If a user is in the `allusers` group, then the section `[@allusers]` applies to them The product reads configuration from top to bottom and "last-in-wins" for a given configuration value. ### `/etc/rstudio/profiles` -The `/etc/rstudio/profiles` file enables you to tailor the behavior of sessions on a per-user or per-group basis. See the Workbench Admin Guide [User and Group Profiles](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/user_and_group_profiles.html) page for more details. +The `/etc/rstudio/profiles` file enables you to tailor the behavior of sessions on a per-user or per-group basis. See the [Posit Workbench Administrator Guide - User and Group Profiles](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/user_and_group_profiles.html) page for more information. -In the `values.yaml`, the content of `/etc/rstudio/profiles` should be defined in `config.server.profiles`. For example: +In the `values.yaml`, define the content of `/etc/rstudio/profiles` in `config.server.profiles`. For example: ```yaml config: @@ -312,17 +315,17 @@ session-timeout-minutes=60 ### `/etc/rstudio/launcher.kubernetes.profiles.conf` -The `/etc/rstudio/launcher.kubernetes.profiles.conf` contains the configuration of resource limits by user and group when using the Kubernetes Launcher Plugin. In the `values.yaml`, the content of `/etc/rstudio/launcher.kubernetes.profiles.conf ` should be defined in `config.profiles.launcher.kubernetes.profiles.conf`. The `config.profiles` section has a couple of niceties that are added in by default. +The `/etc/rstudio/launcher.kubernetes.profiles.conf` contains the configuration of resource limits by user and group when using the Kubernetes Launcher Plugin. In the `values.yaml`, define the content of `/etc/rstudio/launcher.kubernetes.profiles.conf ` in the `config.profiles.launcher.kubernetes.profiles.conf` file. The `config.profiles` section has a couple of niceties that are added in by default. -- YAML arrays like the following will be "comma-joined." For instance, the following will become: `some-key=value1,value2` +- YAML arrays like the following becomes "comma-joined." For instance, the following becomes: `some-key=value1,value2` -```yaml -some-key: - - value1 - - value2 -``` + ```yaml + some-key: + - value1 + - value2 + ``` -- The `[*]` section will have arrays "appended" to user and group sections, along with "defaults" defined by the chart. +- The `[*]` section has arrays "appended" to user and group sections, along with "defaults" defined by the chart. For example: @@ -339,6 +342,7 @@ config: - value4 - value5 ``` + Becomes: _/etc/rstudio/launcher.kubernetes.profiles.conf_ @@ -350,23 +354,24 @@ some-key: value1,value2 some-key: value1,value2,value3,value4 ``` -> NOTE: this appending/concatenation/array translation behavior only works with the helm chart +:::{.callout-note} +This appending/concatenation/array translation behavior only works with the helm chart. +::: -### Job Json Overrides +### Job Json overrides -If you want to customize the job launch process (i.e. how sessions are defined), you will need to edit the following -configuration: - - modify `config.profiles.launcher\.kubernetes\.profiles\.conf.<< some selector >>.job-json-overrides` - - create an array of maps with the following keys: - - `target`: the "target" part of the job spec to replace - - `name`: a unique identifier (ideally with no spaces) that will become a config filename on disk - - `json`: a YAML value that will be translated directly to JSON and injected into the job spec at `target` +If you want to customize the job launch process (i.e., how sessions are defined), edit the following configuration: -Note that several examples are provided -in [this support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes) -(however, examples do not use the helm chart syntax there). +- Modify: + ```yaml + config.profiles.launcher\.kubernetes\.profiles\.conf.<< some selector >>.job-json-overrides` + ``` +- Create an array of maps with the following keys: + - `target`: The "target" part of the job spec to replace. + - `name`: A unique identifier (ideally with no spaces) becomes a configuration filename on disk. + - `json`: A YAML value that is translated directly to JSON and injected into the job spec at `target`. -Alternatively, you can explore the docs in the [helm repository](https://github.com/rstudio/helm/blob/main/docs/customize.md) +Explore the docs in the [Helm repository](https://github.com/rstudio/helm/blob/main/docs/customize.md) for additional information. ```yaml config: @@ -386,10 +391,11 @@ config: - "two-image:tag ``` -## Sealed Secrets -This chart supports the use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) to allow for storing secrets in SCM and to ensure secrets are never leaked via helm. The target cluster must include a `SealedSecret` controller as the controller is responsible for converting a `SealedSecret` to a `Secret`. +## Sealed secrets + +This chart supports the use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) to allow for storing secrets in SCM and to ensure secrets are never leaked via Helm. The target cluster must include a `SealedSecret` controller as the controller is responsible for converting a `SealedSecret` to a `Secret`. -To activate the use of `SealedSecret` templates instead of `Secret` templates in the chart, set `sealedSecret.enabled=true` and ensure the following values are all encrypted. The chart does not support mixing encrypted values with unencrypted values. +To activate the use of `SealedSecret` templates instead of `Secret` templates in the chart, set `sealedSecret.enabled=true` and ensure the following values are all encrypted (the chart does not support mixing encrypted values with unencrypted values): - `config.secret` - `config.sessionSecret` @@ -397,7 +403,7 @@ To activate the use of `SealedSecret` templates instead of `Secret` templates in - `launcherPem` - `secureCookieKey` (or `global.secureCookieKey`) -Use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) disables the chart's auto-generation and reuse capabilities for `launcherPem` and `secureCookieKey`. `launcherPem` is an RSA private key which can be generated via an RSA tool such as helm's [`genPrivateKey`](https://helm.sh/docs/chart_template_guide/function_list/#genprivatekey) function. `secureCookieKey` is typically a UUID which can be generated via a UUID generator such as helm's [`uuidv4`](https://helm.sh/docs/chart_template_guide/function_list/#uuid-functions) function. +Use of [Sealed secrets](https://github.com/bitnami-labs/sealed-secrets) disables the chart's auto-generation and reuse capabilities for `launcherPem` and `secureCookieKey`. `launcherPem` is an RSA private key, which can be generated via an RSA tool such as Helm's [`genPrivateKey`](https://helm.sh/docs/chart_template_guide/function_list/#genprivatekey) function. `secureCookieKey` is typically a UUID, which can be generated via a UUID generator such as Helm's [`uuidv4`](https://helm.sh/docs/chart_template_guide/function_list/#uuid-functions) function. ## Values @@ -466,7 +472,7 @@ Use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) disables | license.file | object | `{"contents":false,"mountPath":"/etc/rstudio-licensing","mountSubPath":false,"secret":false,"secretKey":"license.lic"}` | the file section is used for licensing with a license file | | license.file.contents | bool | `false` | contents is an in-line license file | | license.file.mountPath | string | `"/etc/rstudio-licensing"` | mountPath is the place the license file will be mounted into the container | -| license.file.mountSubPath | bool | `false` | mountSubPath is whether to mount the subPath for the file secret. -- It can be preferable _not_ to enable this, because then updates propagate automatically | +| license.file.mountSubPath | bool | `false` | It can be preferable _not_ to enable this, because then updates propagate automatically | | license.file.secret | bool | `false` | secret is an existing secret with a license file in it | | license.file.secretKey | string | `"license.lic"` | secretKey is the key for the secret to use for the license file | | license.key | string | `nil` | key is the license to use | @@ -545,5 +551,5 @@ Use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) disables | xdgConfigDirsExtra | list | `[]` | A list of additional XDG config dir paths | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1) diff --git a/charts/rstudio-workbench/README.md.gotmpl b/charts/rstudio-workbench/README.md.gotmpl index b6398432..cb32dc99 100644 --- a/charts/rstudio-workbench/README.md.gotmpl +++ b/charts/rstudio-workbench/README.md.gotmpl @@ -8,65 +8,66 @@ {{ template "rstudio.install" . }} -## Required Configuration +## Required configuration -This chart requires the following in order to function: +To function, this chart requires the following: -* A license file, license key, or address of a running license server. See the [Licensing](#licensing) section below for more details. +* A license file. See the [Licensing](#licensing) section below for more details. * A Kubernetes [PersistentVolume](https://kubernetes.io/docs/concepts/storage/persistent-volumes/) that contains the home directory for users. - * If `homeStorage.create` is set, a PVC that relies on the default storage class will be created to generate the + * If `homeStorage.create` is set, it creates a Persistent Volume Claim (PVC) that relies on the default storage class to generate the PersistentVolume. Most Kubernetes environments do not have a default storage class that you can use - with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend you disable `homeStorage.create` and - create your own `PersistentVolume` and `PersistentVolumeClaim`, then mount them into the container by specifying + with `ReadWriteMany` access mode out-of-the-box. In this case, we recommend that you: + * Disable `homeStorage.create` and + create your own `PersistentVolume` and `PersistentVolumeClaim`, then + * Mount them into the container by specifying the `pod.volumes` and `pod.volumeMounts` parameters, or by specifying your `PersistentVolumeClaim` using `homeStorage.name` and `homeStorage.mount`. - * If you cannot use a `PersistentVolume` to properly mount your users' home directories, you'll need to mount your + * If you cannot use a `PersistentVolume` to properly mount your users' home directories, mount your data in the container by using a regular [Kubernetes Volume](https://kubernetes.io/docs/concepts/storage/volumes/#nfs), specified in `pod.volumes` and `pod.volumeMounts`. - * If you cannot use a `Volume` to mount the directories, you'll need to manually mount them during container startup + * If you cannot use a `Volume` to mount the directories, manually mount them during container startup with a mechanism similar to what is described below for joining to auth domains. - * If not using `homeStorage.create`, you'll need to configure `config.serverDcf.launcher-mounts` to ensure that the correct mounts are used when users create new sessions. -* If using load balancing (by setting `replicas > 1`), you will need similar storage defined for `sharedStorage` to + * If not using `homeStorage.create`, configure `config.serverDcf.launcher-mounts` to ensure that the correct mounts are used when users create new sessions. +* If using load balancing (by setting `replicas > 1`), you need similar storage defined for `sharedStorage` to store shared project configuration. However, you can also configure the product to store its shared data underneath `/home` by setting `config.server.rserver\.conf.server-shared-storage-path=/home/some-shared-dir`. * A method to join the deployed `rstudio-workbench` container to your auth domain. The default `rstudio/rstudio-workbench` image has `sssd` installed and started by default. You can include `sssd` configuration in `config.userProvisioning` like so: -```yaml -config: - userProvisioning: - mysssd.conf: - sssd: - config_file_version: 2 - services: nss, pam - domains: rstudio.com - domain/rstudio.com: - id_provider: ldap - auth_provider: ldap -``` + ```yaml + config: + userProvisioning: + mysssd.conf: + sssd: + config_file_version: 2 + services: nss, pam + domains: rstudio.com + domain/rstudio.com: + id_provider: ldap + auth_provider: ldap + ``` {{ template "rstudio.licensing" . }} -## General Principles +## General principles - In most places, we opt to pass Helm values directly into ConfigMaps. We automatically translate these into the - valid `.ini` or `.dcf` file formats required by RStudio Workbench. Those config files and their mount locations are - below. -- If you need to modify the jobs launched by RStudio Workbench, you want to use `job-json-overrides`. There is a section on this below - and [a support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes) - on the topic in general. -- The prestart scripts for RStudio Workbench and RStudio Launcher are highly customized to: - - Get the service account information off of the RStudio Workbench pod for use in launching jobs -- RStudio Workbench does not export prometheus metrics on its own. Instead, we run a sidecar graphite exporter - [as described here](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) + valid `.ini` or `.dcf` file formats required by Workbench. + - Those configuration files and their mount locations are covered in the [Configuration files](#configuration-files) section below. +- If you need to modify the jobs launched by Workbench, use `job-json-overrides`. + - Review the [Job Json overrides](#job-json-overrides) section on this below. For general information, see [a support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes). +- The prestart scripts for Workbench and Posit Job Launcher are highly customized to get the service account information off of the Workbench pod for use in launching jobs. +- Workbench does not export prometheus metrics on its own. Instead, we run a sidecar graphite exporter. + - This is described in the + [Monitoring Posit Team Using Prometheus and Graphite](https://support.rstudio.com/hc/en-us/articles/360044800273-Monitoring-RStudio-Team-Using-Prometheus-and-Graphite) support article. ## Configuration files -These configuration values all take the form of usual helm values +These configuration values all take the form of usual Helm values so you can set the database password with something like: -``` +```{.bash} ... --set config.secret.database\.conf.password=mypassword ... ``` @@ -80,130 +81,133 @@ config: ``` The names of files are dynamically used, so you can add new files as needed. Beware that some files have default values, -so moving them can have adverse effects. Also, if you use a different mounting paradigm, you will need to change -the `XDG_CONFIG_DIRS` environment variable +so moving them can have adverse effects. Also, if you use a different mounting paradigm, you need to change +the `XDG_CONFIG_DIRS` environment variable. - Session Configuration - These configuration files are mounted into the server and - are mounted into the session pods as well. + are mounted into the session pods. - `repos.conf`, `rsession.conf`, `notifications.conf` - - located in the `config.session.<< name of file >>` helm values - - mounted at `/mnt/session-configmap/rstudio/` -- Session Secret Configuration - - These configuration files are mounted into the server and session pods as well - - `odbc.ini` and other similar shared secrets - - located in `config.sessionSecret.<< name of file>>` helm values - - mounted at `/mnt/session-secret/` -- Secret Configuration - - These configuration files are mounted into the server with more restrictive permissions (0600) + - Located in:
`config.session.<< name of file >>` Helm values + - Mounted at:
`/mnt/session-configmap/rstudio/` +- Session Secret Configuration: + - These configuration files are mounted into the server and session pods. + - `odbc.ini` and other similar shared secrets. + - Located in:
`config.sessionSecret.<< name of file>>` Helm values + - Mounted at:
`/mnt/session-secret/` +- Secret Configuration: + - These configuration files are mounted into the server with more restrictive permissions (0600). - `database.conf`, `openid-client-secret`, `databricks.conf` - - They are located in the `config.secret.<< name of file >>` helm values - - mounted at `/mnt/secret-configmap/rstudio/` -- Server Configuration - - These configuration files are mounted into the server (.ini file format) + - Located in:
`config.secret.<< name of file >>` Helm values + - Mounted at:
`/mnt/secret-configmap/rstudio/` +- Server Configuration: + - These configuration files are mounted into the server (.ini file format). - `rserver.conf`, `launcher.conf`, `jupyter.conf`, `logging.conf` - - They are located at `config.server.<< name of file >>` helm values - - mounted at `/mnt/configmap/rstudio/` -- Server DCF Configuration - - These configuration files are mounted into the server (.dcf file format) + - Located at:
`config.server.<< name of file >>` Helm values + - Mounted at:
`/mnt/configmap/rstudio/` +- Server DCF Configuration: + - These configuration files are mounted into the server (.dcf file format). - `launcher-mounts`, `launcher-env` - - They are located at `config.serverDcf.<< name of file >>` helm values - - included at `/mnt/configmap/rstudio/` -- Profiles Configuration - - These configuration files are mounted into the server (.ini file format) + - Located at:
`config.serverDcf.<< name of file >>` Helm values + - Included at:
`/mnt/configmap/rstudio/` +- Profiles Configuration: + - These configuration files are mounted into the server (.ini file format). - `launcher.kubernetes.profiles.conf` - - They are located at `config.profiles.<< name of file >>` helm values - - included at `/mnt/configmap/rstudio/` - - See the `Profiles` section below for more information -- Prestart - - This is provided by the helm chart in a configmap - - It is mounted into the pod at `/scripts/` - - `prestart-workbench.bash` is used to start workbench - - `prestart-launcher.bash` is used to start launcher -- User Provisioning Configuration - - These configuration files are used for configuring user provisioning (i.e. `sssd`) - - Located at `config.userProvisioning.<< name of file >>` helm values - - Mounted onto `/etc/sssd/conf.d/` with `0600` permissions by default -- Custom Startup Configuration - - `supervisord` service / unit definition `.conf` files - - Located at `config.startupCustom.<< name of file >>` helm values - - Will use the `.ini` file format, by default - - Mounted at `/startup/custom` - - As with all config files above, can override with a verbatim string if desired, like so: -```yaml -config: - startupCustom: - myfile.conf: | - file-used-verbatim -``` -- PAM configuration - - `pam` configuration files - - Located at `config.pam.<< name of file >>` helm values - - Will be mounted verbatim as individual files (using `subPath` mounts) at `/etc/pam.d/<< name of file >>` + - They are located at `config.profiles.<< name of file >>` Helm values + - Included at:
`/mnt/configmap/rstudio/` + - See the [Profiles](#rstudio-profiles) section below for more information. +- Prestart: + - This is provided by the Helm chart in a configmap. + - It is mounted into the pod at `/scripts/`. + - `prestart-workbench.bash` is used to start workbench. + - `prestart-launcher.bash` is used to start launcher. +- User Provisioning Configuration: + - These configuration files are used for configuring user provisioning (i.e., `sssd`). + - Located at:
`config.userProvisioning.<< name of file >>` Helm values + - Mounted onto:
`/etc/sssd/conf.d/` with `0600` permissions by default. +- Custom Startup Configuration: + - `supervisord` service / unit definition `.conf` files. + - Use the `.ini` file format by default. + - Mounted at:
`/startup/custom` + - As with all configuration files above, you can override with a verbatim string if desired: + - Located at:
`config.startupCustom.<< name of file >>` Helm values: + ```yaml + config: + startupCustom: + myfile.conf: | + file-used-verbatim + ``` +- PAM configuration: + - `pam` configuration files. + - Located at:
`config.pam.<< name of file >>` Helm values + - Mounted verbatim as individual files (using `subPath` mounts) at:
`/etc/pam.d/<< name of file >>` -### Configuring R and Python repositories - -#### R repositories +#### Python repositories -R package repositories can be configured with `config.session.repos.conf`. +pip can be configured with `config.session.pip.conf`. To ensure `pip.conf` is mounted into the session pods, it is important that: -``` -config: - session: - repos.conf: - CRAN: https://packagemanager.posit.co/cran/__linux__/jammy/latest -``` +- `launcher.useTemplates: true` is set +- `pip.conf` settings are listed under `config.session` as shown in the following example for adding Posit Public Package Manager's PyPI: -For more information about configuring CRAN repositories in Workbench refer to the [Admin Guide](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/package_installation.html#cran-repositories). + ```yaml + launcher: + useTemplates: true -#### Python repositories + config: + session: + pip.conf: + "global": + index-url: https://packagemanager.posit.co/pypi/latest/simple + trusted-host: packagemanager.posit.co + ``` -pip can be configured with `config.session.pip.conf`. To ensure `pip.conf` is mounted into the session pods it is important that `launcher.useTemplates: true` is set and `pip.conf` settings are listed under `config.session` like in the example below for adding Posit Public Package Manager's PyPI. +#### R repositories -``` -launcher: - useTemplates: true +R package repositories can be configured with `config.session.repos.conf`: +```yaml config: session: - pip.conf: - "global": - index-url: https://packagemanager.posit.co/pypi/latest/simple - trusted-host: packagemanager.posit.co + repos.conf: + CRAN: https://packagemanager.posit.co/cran/__linux__/jammy/latest ``` -## User Provisioning +For more information about configuring CRAN repositories in Workbench, see the [Posit Workbench Administrator Guide's - Package Installation > CRAN repositories](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/package_installation.html#cran-repositories) section. + +## User provisioning -Provisioning users in RStudio Workbench containers is challenging. Session images have users created automatically (with -consistent UIDs / GIDs), but creating users in the Workbench containers is a responsibility that falls to the -administrator today. +Provisioning users in Workbench containers is challenging. Session images create users automatically (with +consistent UIDs / GIDs). However, creating users in the Workbench containers is a responsibility that falls to the +administrator. The most common way to provision users is via `sssd`. -The [latest RStudio Workbench container](https://github.com/rstudio/rstudio-docker-products/tree/main/workbench#user-provisioning) +The [latest Workbench container](https://github.com/rstudio/rstudio-docker-products/tree/main/workbench#user-provisioning) has `sssd` included and running by default (see `userProvisioning` configuration files above). -The other way that this can be managed is via a lightweight "startup service" (runs once at startup and then sleeps forever) +The other way that this can be managed is via a lightweight startup service (runs once at startup and then sleeps forever) or a polling service (checks at regular intervals). Either can be written easily in `bash` or another programming language. -However, it is important to be careful of a few points: -- UID / GID consistency: linux usernames and their matching to UID/GID must be consistent across all nodes and across - time. Failing this can cause security issues and access by some users to files they should not be allowed to see -- usernames cannot have `@`. The `@` sign (often used in emails with SSO) is a problem for RStudio Workbench because - some operating systems disallow `@` signs in linux usernames -- `supervisord` is configured by default to exit if any of its child processes exit. If you use `config.startupCustom` - to configure a user management service, be careful that it does not exit unnecessarily +However, it is important to use caution for the following: -We do not provide such a service out of the box because we intend for RStudio Workbench to solve this problem in a -future release. Please get in touch with your account representative if you have feedback or questions about this +- UID / GID consistency: + - Linux usernames and their matching to UID/GID must be consistent across all nodes and across time. + - Failing can cause security issues and access by some users to access view they should not be allowed to see. +- Usernames cannot have `@`. + - The `@` sign (often used in emails with SSO) is a problem for Workbench because some operating systems disallow `@` signs in linux usernames. +- `supervisord` is configured by default to exit if any of its child processes exit. + - If you use `config.startupCustom` to configure a user management service, be careful that it does not exit unnecessarily. + +We do not provide such a service out-of-the box because we intend for Workbench to solve this problem in a +future release. Please contact your account representative if you have feedback or questions about this workflow. ### PAM -When starting sessions on RStudio Workbench, PAM configuration is often very important, even if PAM is not being used as -an authentication mechanism. The RStudio Workbench helm chart allows creating custom PAM files via the `config.pam` +When starting sessions on Workbench, PAM configuration is often very important, even if PAM is not being used as +an authentication mechanism. The Workbench Helm chart allows creating custom PAM files via the `config.pam` values section. -Each key under `config.pam` will become a PAM config file, and will be mounted into `/etc/pam.d/` in the container. For +Each key under `config.pam` becomes a PAM configuration file, and is mounted into `/etc/pam.d/` in the container. For example: ```yaml @@ -217,23 +221,23 @@ config: # will be used verbatim ``` -## RStudio Profiles +## RStudio profiles Profiles are used to define product behavior (in `.ini` file format) based on user and group membership. Sections define whether a set of configurations is applied to a user's jobs based on the following criteria: -- if section header is `[*]`, it applies to all users -- if a user's username is `myusername`, the section `[myusername]` will apply to them -- if a user is in the `allusers` group, then the section `[@allusers]` will apply to them +- If section header is `[*]`, it applies to all users. +- If a user's username is `myusername`, the section `[myusername]` applies to them. +- If a user is in the `allusers` group, then the section `[@allusers]` applies to them The product reads configuration from top to bottom and "last-in-wins" for a given configuration value. ### `/etc/rstudio/profiles` -The `/etc/rstudio/profiles` file enables you to tailor the behavior of sessions on a per-user or per-group basis. See the Workbench Admin Guide [User and Group Profiles](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/user_and_group_profiles.html) page for more details. +The `/etc/rstudio/profiles` file enables you to tailor the behavior of sessions on a per-user or per-group basis. See the [Posit Workbench Administrator Guide - User and Group Profiles](https://docs.posit.co/ide/server-pro/rstudio_pro_sessions/user_and_group_profiles.html) page for more information. -In the `values.yaml`, the content of `/etc/rstudio/profiles` should be defined in `config.server.profiles`. For example: +In the `values.yaml`, define the content of `/etc/rstudio/profiles` in `config.server.profiles`. For example: ```yaml config: @@ -256,17 +260,17 @@ session-timeout-minutes=60 ### `/etc/rstudio/launcher.kubernetes.profiles.conf` -The `/etc/rstudio/launcher.kubernetes.profiles.conf` contains the configuration of resource limits by user and group when using the Kubernetes Launcher Plugin. In the `values.yaml`, the content of `/etc/rstudio/launcher.kubernetes.profiles.conf ` should be defined in `config.profiles.launcher.kubernetes.profiles.conf`. The `config.profiles` section has a couple of niceties that are added in by default. +The `/etc/rstudio/launcher.kubernetes.profiles.conf` contains the configuration of resource limits by user and group when using the Kubernetes Launcher Plugin. In the `values.yaml`, define the content of `/etc/rstudio/launcher.kubernetes.profiles.conf ` in the `config.profiles.launcher.kubernetes.profiles.conf` file. The `config.profiles` section has a couple of niceties that are added in by default. -- YAML arrays like the following will be "comma-joined." For instance, the following will become: `some-key=value1,value2` +- YAML arrays like the following becomes "comma-joined." For instance, the following becomes: `some-key=value1,value2` -```yaml -some-key: - - value1 - - value2 -``` + ```yaml + some-key: + - value1 + - value2 + ``` -- The `[*]` section will have arrays "appended" to user and group sections, along with "defaults" defined by the chart. +- The `[*]` section has arrays "appended" to user and group sections, along with "defaults" defined by the chart. For example: @@ -283,6 +287,7 @@ config: - value4 - value5 ``` + Becomes: _/etc/rstudio/launcher.kubernetes.profiles.conf_ @@ -294,23 +299,24 @@ some-key: value1,value2 some-key: value1,value2,value3,value4 ``` -> NOTE: this appending/concatenation/array translation behavior only works with the helm chart +:::{.callout-note} +This appending/concatenation/array translation behavior only works with the helm chart. +::: -### Job Json Overrides +### Job Json overrides -If you want to customize the job launch process (i.e. how sessions are defined), you will need to edit the following -configuration: - - modify `config.profiles.launcher\.kubernetes\.profiles\.conf.<< some selector >>.job-json-overrides` - - create an array of maps with the following keys: - - `target`: the "target" part of the job spec to replace - - `name`: a unique identifier (ideally with no spaces) that will become a config filename on disk - - `json`: a YAML value that will be translated directly to JSON and injected into the job spec at `target` +If you want to customize the job launch process (i.e., how sessions are defined), edit the following configuration: -Note that several examples are provided -in [this support article](https://support.rstudio.com/hc/en-us/articles/360051652094-Using-Job-Json-Overrides-with-RStudio-Server-Pro-and-Kubernetes) -(however, examples do not use the helm chart syntax there). +- Modify: + ```yaml + config.profiles.launcher\.kubernetes\.profiles\.conf.<< some selector >>.job-json-overrides` + ``` +- Create an array of maps with the following keys: + - `target`: The "target" part of the job spec to replace. + - `name`: A unique identifier (ideally with no spaces) becomes a configuration filename on disk. + - `json`: A YAML value that is translated directly to JSON and injected into the job spec at `target`. -Alternatively, you can explore the docs in the [helm repository](https://github.com/rstudio/helm/blob/main/docs/customize.md) +Explore the docs in the [Helm repository](https://github.com/rstudio/helm/blob/main/docs/customize.md) for additional information. ```yaml config: @@ -330,10 +336,11 @@ config: - "two-image:tag ``` -## Sealed Secrets -This chart supports the use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) to allow for storing secrets in SCM and to ensure secrets are never leaked via helm. The target cluster must include a `SealedSecret` controller as the controller is responsible for converting a `SealedSecret` to a `Secret`. +## Sealed secrets + +This chart supports the use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) to allow for storing secrets in SCM and to ensure secrets are never leaked via Helm. The target cluster must include a `SealedSecret` controller as the controller is responsible for converting a `SealedSecret` to a `Secret`. -To activate the use of `SealedSecret` templates instead of `Secret` templates in the chart, set `sealedSecret.enabled=true` and ensure the following values are all encrypted. The chart does not support mixing encrypted values with unencrypted values. +To activate the use of `SealedSecret` templates instead of `Secret` templates in the chart, set `sealedSecret.enabled=true` and ensure the following values are all encrypted (the chart does not support mixing encrypted values with unencrypted values): - `config.secret` - `config.sessionSecret` @@ -341,7 +348,7 @@ To activate the use of `SealedSecret` templates instead of `Secret` templates in - `launcherPem` - `secureCookieKey` (or `global.secureCookieKey`) -Use of [Sealed Secrets](https://github.com/bitnami-labs/sealed-secrets) disables the chart's auto-generation and reuse capabilities for `launcherPem` and `secureCookieKey`. `launcherPem` is an RSA private key which can be generated via an RSA tool such as helm's [`genPrivateKey`](https://helm.sh/docs/chart_template_guide/function_list/#genprivatekey) function. `secureCookieKey` is typically a UUID which can be generated via a UUID generator such as helm's [`uuidv4`](https://helm.sh/docs/chart_template_guide/function_list/#uuid-functions) function. +Use of [Sealed secrets](https://github.com/bitnami-labs/sealed-secrets) disables the chart's auto-generation and reuse capabilities for `launcherPem` and `secureCookieKey`. `launcherPem` is an RSA private key, which can be generated via an RSA tool such as Helm's [`genPrivateKey`](https://helm.sh/docs/chart_template_guide/function_list/#genprivatekey) function. `secureCookieKey` is typically a UUID, which can be generated via a UUID generator such as Helm's [`uuidv4`](https://helm.sh/docs/chart_template_guide/function_list/#uuid-functions) function. {{ template "chart.valuesSection" . }} diff --git a/examples/connect/application-configuration/index.qmd b/examples/connect/application-configuration/index.qmd index 2ceb80c6..c8475c97 100644 --- a/examples/connect/application-configuration/index.qmd +++ b/examples/connect/application-configuration/index.qmd @@ -1,5 +1,5 @@ --- -category: "Basic Configuration" +category: "Basic configuration" --- # Configuring Posit Connect with Recommended Settings diff --git a/examples/connect/beta-migration/index.qmd b/examples/connect/beta-migration/index.qmd index 2993a3eb..99e81200 100644 --- a/examples/connect/beta-migration/index.qmd +++ b/examples/connect/beta-migration/index.qmd @@ -1,5 +1,5 @@ --- -category: "Beta Migration" +category: "Beta migration" --- # Off-Host Execution Beta User Migration diff --git a/examples/connect/container-images/custom-images.qmd b/examples/connect/container-images/custom-images.qmd index 5407c999..0b73badc 100644 --- a/examples/connect/container-images/custom-images.qmd +++ b/examples/connect/container-images/custom-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Connect with Custom Container Images diff --git a/examples/connect/container-images/private-images.qmd b/examples/connect/container-images/private-images.qmd index 6d387753..cfad496b 100644 --- a/examples/connect/container-images/private-images.qmd +++ b/examples/connect/container-images/private-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Connect to Access Image Registries Requiring Authentication diff --git a/examples/examples.ejs b/examples/examples.ejs index 069909a4..4fdf632f 100644 --- a/examples/examples.ejs +++ b/examples/examples.ejs @@ -2,7 +2,7 @@ const postsByCategory = {}; const basicConfigPosts = []; items.forEach(item => { - if (item.category === "Basic Configuration") { + if (item.category === "Basic configuration") { basicConfigPosts.push(item) } else { if (!postsByCategory[item.category]) { @@ -14,7 +14,7 @@ items.forEach(item => { // Basic config first if (basicConfigPosts.length > 0) { %> -

Basic Configuration

+

Basic configuration

    <% basicConfigPosts.forEach(post => { %>
  • diff --git a/examples/package-manager/container-images/custom-images.qmd b/examples/package-manager/container-images/custom-images.qmd index ef765035..b8fbb38d 100644 --- a/examples/package-manager/container-images/custom-images.qmd +++ b/examples/package-manager/container-images/custom-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Package Manager with Custom Container Images diff --git a/examples/package-manager/container-images/private-images.qmd b/examples/package-manager/container-images/private-images.qmd index 5f9dd663..112614eb 100644 --- a/examples/package-manager/container-images/private-images.qmd +++ b/examples/package-manager/container-images/private-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Package Manager to Access Image Registries Requiring Authentication diff --git a/examples/rbac/rstudio-launcher-rbac-0.2.21.yaml b/examples/rbac/rstudio-launcher-rbac-0.2.21.yaml new file mode 100644 index 00000000..3b322f8d --- /dev/null +++ b/examples/rbac/rstudio-launcher-rbac-0.2.21.yaml @@ -0,0 +1,88 @@ +--- +# Source: rstudio-launcher-rbac/templates/rbac.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: rstudio-launcher-rbac +--- +# Source: rstudio-launcher-rbac/templates/rbac.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: rstudio-launcher-rbac +rules: + - apiGroups: + - "" + resources: + - "serviceaccounts" + verbs: + - "list" + - apiGroups: + - "" + resources: + - "pods/log" + verbs: + - "get" + - "watch" + - "list" + - apiGroups: + - "" + resources: + - "pods" + - "pods/attach" + - "pods/exec" + verbs: + - "get" + - "create" + - "update" + - "patch" + - "watch" + - "list" + - "delete" + - apiGroups: + - "" + resources: + - "events" + verbs: + - "watch" + - apiGroups: + - "" + resources: + - "services" + verbs: + - "create" + - "get" + - "watch" + - "list" + - "delete" + - apiGroups: + - "batch" + resources: + - "jobs" + verbs: + - "create" + - "update" + - "patch" + - "get" + - "watch" + - "list" + - "delete" + - apiGroups: + - "metrics.k8s.io" + resources: + - "pods" + verbs: + - "get" +--- +# Source: rstudio-launcher-rbac/templates/rbac.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: rstudio-launcher-rbac +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: rstudio-launcher-rbac +subjects: + - kind: ServiceAccount + name: rstudio-launcher-rbac diff --git a/examples/workbench/application-configuration/index.qmd b/examples/workbench/application-configuration/index.qmd index 298a98ca..4551a908 100644 --- a/examples/workbench/application-configuration/index.qmd +++ b/examples/workbench/application-configuration/index.qmd @@ -1,5 +1,5 @@ --- -category: "Basic Configuration" +category: "Basic configuration" --- # Configuring Posit Workbench with Recommended Settings diff --git a/examples/workbench/container-images/custom-images.qmd b/examples/workbench/container-images/custom-images.qmd index df55c281..10ec1dab 100644 --- a/examples/workbench/container-images/custom-images.qmd +++ b/examples/workbench/container-images/custom-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Workbench with Custom Container Images diff --git a/examples/workbench/container-images/private-images.qmd b/examples/workbench/container-images/private-images.qmd index 886c926e..8a74b6cf 100644 --- a/examples/workbench/container-images/private-images.qmd +++ b/examples/workbench/container-images/private-images.qmd @@ -1,5 +1,5 @@ --- -category: "Container Images" +category: "Container images" --- # Configuring Posit Workbench to Access Image Registries Requiring Authentication diff --git a/examples/workbench/index.qmd b/examples/workbench/index.qmd index 6b6ec2c0..2a3fb88a 100644 --- a/examples/workbench/index.qmd +++ b/examples/workbench/index.qmd @@ -12,7 +12,7 @@ Before using an example, read through all the comments and ensure you address ea While each example focuses on one or more particular configurations, RStudio Workbench has some standard requirements listed in each example. -Each example will need the following to run correctly: +Each example needs the following to run correctly: - PostgreSQL database specified in the Workbench configuration - License key or file specified diff --git a/images/favicon.svg b/images/favicon.svg new file mode 100644 index 00000000..d154019f --- /dev/null +++ b/images/favicon.svg @@ -0,0 +1,21 @@ + + + + + + + + + + + + diff --git a/images/posit-guide-dm.svg b/images/posit-guide-dm.svg new file mode 100644 index 00000000..b0c67d11 --- /dev/null +++ b/images/posit-guide-dm.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/posit-guide-ltmd.svg b/images/posit-guide-ltmd.svg new file mode 100644 index 00000000..f2c33c23 --- /dev/null +++ b/images/posit-guide-ltmd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/posit-guide-open-dm.svg b/images/posit-guide-open-dm.svg new file mode 100644 index 00000000..d6b0e2b2 --- /dev/null +++ b/images/posit-guide-open-dm.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/posit-guide-open-ltmd.svg b/images/posit-guide-open-ltmd.svg new file mode 100644 index 00000000..77464c09 --- /dev/null +++ b/images/posit-guide-open-ltmd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/posit-icon-fullcolor.svg b/images/posit-icon-fullcolor.svg new file mode 100644 index 00000000..ec7f5525 --- /dev/null +++ b/images/posit-icon-fullcolor.svg @@ -0,0 +1,22 @@ + + + + + + diff --git a/images/posit-logo-black-TM.svg b/images/posit-logo-black-TM.svg new file mode 100644 index 00000000..3b159987 --- /dev/null +++ b/images/posit-logo-black-TM.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/posit-logo-fullcolor-TM.svg b/images/posit-logo-fullcolor-TM.svg new file mode 100644 index 00000000..30512e6b --- /dev/null +++ b/images/posit-logo-fullcolor-TM.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/index.qmd b/index.qmd index 319ec014..bc20cc3b 100644 --- a/index.qmd +++ b/index.qmd @@ -1,20 +1,22 @@ -# Posit Helm Charts +--- +title: Posit Helm Charts +--- [![Artifact Hub](https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/rstudio)](https://artifacthub.io/packages/search?repo=rstudio) [![GitHub license](https://img.shields.io/github/license/rstudio/helm.svg)](https://github.com/rstudio/helm/blob/main/LICENSE) ## Usage -1. Install [Helm](https://helm.sh). Please refer to Helm's [documentation](https://helm.sh/docs/) for more information on getting started. +1. Install [Helm](https://helm.sh). Please refer to the [Helm documentation](https://helm.sh/docs/) for more information on getting started. -2. Add the Posit Helm repo: +2. Add the Posit Helm repository: - ```console + ```{.bash} helm repo add rstudio https://helm.rstudio.com ``` 3. View charts: - ```console + ```{.bash} helm search repo rstudio - ``` + ``` \ No newline at end of file diff --git a/other-charts/prepull-daemonset/Chart.yaml b/other-charts/prepull-daemonset/Chart.yaml index 97c8fe24..bc72a7e6 100644 --- a/other-charts/prepull-daemonset/Chart.yaml +++ b/other-charts/prepull-daemonset/Chart.yaml @@ -1,6 +1,6 @@ name: prepull-daemonset description: a daemonset to prepull images so they are cached -version: 0.0.3 +version: 0.0.4 apiVersion: v2 icon: https://rstudio.com/wp-content/uploads/2018/10/RStudio-Logo-Flat.png home: https://www.rstudio.com diff --git a/other-charts/prepull-daemonset/NEWS.md b/other-charts/prepull-daemonset/NEWS.md index c7b0f049..8c4894c5 100644 --- a/other-charts/prepull-daemonset/NEWS.md +++ b/other-charts/prepull-daemonset/NEWS.md @@ -1,5 +1,9 @@ # Changelog +## 0.0.4 + +- Update docs + ## 0.0.3 - Updates to support standalone documentation site diff --git a/other-charts/prepull-daemonset/README.md b/other-charts/prepull-daemonset/README.md index 5f5492b0..a8c757e1 100644 --- a/other-charts/prepull-daemonset/README.md +++ b/other-charts/prepull-daemonset/README.md @@ -1,16 +1,16 @@ # prepull-daemonset -![Version: 0.0.3](https://img.shields.io/badge/Version-0.0.3-informational?style=flat-square) +![Version: 0.0.4](https://img.shields.io/badge/Version-0.0.4-informational?style=flat-square) #### _a daemonset to prepull images so they are cached_ ## Installing the Chart -To install the chart with the release name `my-release` at version 0.0.3: +To install the chart with the release name `my-release` at version 0.0.4: ```bash helm repo add rstudio https://helm.rstudio.com -helm install my-release rstudio/prepull-daemonset --version=0.0.3 +helm install my-release rstudio/prepull-daemonset --version=0.0.4 ``` ## Use @@ -54,5 +54,5 @@ kubectl rollout restart daemonset/prepull-daemonset | updateStrategy | object | `{}` | | ---------------------------------------------- -Autogenerated from chart metadata using [helm-docs v1.5.0](https://github.com/norwoodj/helm-docs/releases/v1.5.0) +Autogenerated from chart metadata using [helm-docs v1.13.1](https://github.com/norwoodj/helm-docs/releases/v1.13.1)