From fa7e02c20be6c0e7d352a4c7d18970194db538ad Mon Sep 17 00:00:00 2001 From: Ian Maddaus Date: Mon, 17 Jul 2023 16:29:11 -0400 Subject: [PATCH] Very initial draft of license content Signed-off-by: Ian Maddaus --- config/_default/menu.toml | 12 +- content/chef_license.md | 50 +----- content/chef_license_accept.md | 286 +-------------------------------- content/license/_index.md | 60 +++++++ content/license/accept.md | 286 +++++++++++++++++++++++++++++++++ content/license/terms.md | 56 +++++++ 6 files changed, 412 insertions(+), 338 deletions(-) create mode 100644 content/license/_index.md create mode 100644 content/license/accept.md create mode 100644 content/license/terms.md diff --git a/config/_default/menu.toml b/config/_default/menu.toml index 7951a979d98..615f7c09340 100644 --- a/config/_default/menu.toml +++ b/config/_default/menu.toml @@ -57,6 +57,12 @@ title = "Overview" identifier = "overview" weight = 20 + [[overview]] + title = "Licensing" + identifier = "overview/licensing" + parent = "overview" + weight = 10 + [[overview]] title = "Community" identifier = "overview/community" @@ -69,12 +75,6 @@ weight = 20 parent = "overview" weight = 30 - [[overview]] - title = "Licensing" - identifier = "overview/packages_&_platforms/licensing" - parent = "overview/packages_&_platforms" - weight = 60 - [[overview]] title = "Style Guide" identifier = "overview/style" diff --git a/content/chef_license.md b/content/chef_license.md index a22420dd537..bd3e949a3df 100644 --- a/content/chef_license.md +++ b/content/chef_license.md @@ -2,52 +2,6 @@ title = "About Chef Licenses" draft = false gh_repo = "chef-web-docs" -aliases = ["/chef_license.html"] -product = ["automate", "client", "server", "habitat", "inspec", "supermarket", "workstation"] - -[menu] - [menu.overview] - title = "About Licensing" - identifier = "overview/packages_&_platforms/licensing/chef_license.md About Licensing" - parent = "overview/packages_&_platforms/licensing" - weight = 10 +layout="redirect" +redirect_url="/license/" +++ - -All Chef products have a license that governs the entire product, while -some have separate licenses for the project source code and the -distribution that we build from it. Third-party software included in our -distributions may have individual licenses, which are listed in the -`/opt//LICENSE` file. Individual copies of all referenced -licenses can be found in the `/opt//LICENSES` directory. - -In April 2019 many of our software distributions switched to being -governed under the Chef EULA, while the software projects remained -governed by the Apache 2.0 license. To understand which license applies -to those distributions, see the [versions page](/versions/). General -information about this change can be found in our -[announcement](https://blog.chef.io/2019/04/02/chef-software-announces-the-enterprise-automation-stack/). - -## Chef EULA - -The commercial distributions of our products---such as Chef Infra -Client, Chef Habitat, or Chef InSpec--- are governed by either the -[Chef End User License Agreement (Chef -EULA)](https://www.chef.io/end-user-license-agreement) or your -commercial agreement with Progress Software Corporation as a customer. You are -required to accept these terms when using the distributions for the -first time. For additional information on how to accept the license, see -[Accepting the Chef License](/chef_license_accept/) documentation. - -## Chef MLSA - -Distributions of older proprietary Chef products---such as Chef Automate -1.x and the Chef Management Console---are governed by the [Chef Master -License and Services Agreement (Chef -MLSA)](https://www.chef.io/online-master-agreement), which must be -accepted as part of any install or upgrade process. - -## Apache 2.0 - -All source code of our open source Chef projects---such as Chef Infra Client, Chef -Automate, or Chef InSpec---are governed by the [Apache 2.0 -license](https://www.apache.org/licenses/LICENSE-2.0). diff --git a/content/chef_license_accept.md b/content/chef_license_accept.md index 523551d7634..e0008fbfbde 100644 --- a/content/chef_license_accept.md +++ b/content/chef_license_accept.md @@ -1,289 +1,7 @@ +++ title = "Accepting the Chef License" draft = false - gh_repo = "chef-web-docs" - -aliases = ["/chef_license_accept.html"] -product = ["automate", "client", "server", "habitat", "inspec", "supermarket", "workstation"] - -[menu] - [menu.overview] - title = "Accepting License" - identifier = "overview/packages_&_platforms/licensing/chef_license_accept.md Accepting License" - parent = "overview/packages_&_platforms/licensing" - weight = 20 +layout="redirect" +redirect_url="/license/accept/" +++ - -This page aims to document how to accept the Chef license for all Chef Software products. For an overview of the license, see the [Chef license](/chef_license/) documentation. There are two types of license: MLSA and EULA. The MLSA applies to customers with a commercial contract with Chef Software, and the EULA covers all other cases. - -## Accept the Chef MLSA - -There are three ways to accept the Chef MLSA: - -1. When running `chef--ctl reconfigure` the Chef MLSA is printed. Type `yes` to accept it. Anything other than typing `yes` rejects the Chef MLSA, and the upgrade process will exit. Typing `yes` adds a `.license.accepted` file to the `/etc/chef/accepted_licenses/` file. As long as this file exists in this directory, the Chef MLSA is accepted and the reconfigure process will not prompt for `yes`. -2. Run the `chef--ctl reconfigure` command using the `--chef-license=accept` option. This automatically types `yes` and skips printing the Chef MLSA. -3. Add a `.license.accepted` file to the `/var/opt//` directory. The contents of this file do not matter. As long as this file exists in this directory, the Chef MLSA is accepted and the reconfigure process will not prompt for `yes`. - -## Accept the Chef EULA - -Products below are split below into two categories: workstation and server. Affected product versions which require accepting the EULA to use are shown. Versions before this do not require accepting the EULA. More information on supported versions can be seen at the [Supported Versions](/versions/) documentation. - -### Workstation Products - -- Chef Workstation \>= 0.4, which also contains: - - Chef Infra Client - - Chef InSpec -- Chef Infra Client \>= 15.0 -- Chef InSpec \>= 4.0 -- Chef Habitat \>= 0.80 - -These products are typically installed on a user's workstation. Two common methods for accepting the license are: - -1. `--chef-license ` argument passed to the command line invocation. -1. `CHEF_LICENSE=""` as an environment variable. - `` can be specified as one of the following: - 1. `accept` - Accepts the license and attempts to persist a marker file locally. Persisting these marker files means future invocations do not require accepting the license again. - 1. `accept-silent` - Similar to `accept` except no messaging is sent to STDOUT - 1. `accept-no-persist` - Similar to `accept-silent` except no marker file is persisted. Future invocation will require accepting the license again. - -If no command line argument or environment variable is set, these products will attempt to request acceptance through an interactive prompt. If the prompt cannot be displayed, then the product will fail with an exit code 172. - -If the product attempts to persist the accepted license and fails, a message will be sent to STDOUT, but product invocation will continue successfully. In a future invocation, however, the license would need to be accepted again. - -Please see [License File Persistence](https://github.com/chef/license-acceptance#license-file-persistence) for details about persisted marker files. - -The `--chef-license` command line argument is not backwards compatible to older non-EULA versions. If you are managing a multi-version environment, we recommend using the environment variable as that is ignored by older versions. - -Products with specific features or differences from this general behavior are documented below. - -#### Chef Workstation - -Chef Workstation contains multiple Chef Software products. When invoking the `chef` command line tool and accepting the license, users are required to accept the license for all the embedded products as well. The same license applies to all products, but each product must have its own license acceptance. `chef --chef-license accept` will accept the license for Chef Workstation, Chef Infra Client, and Chef InSpec. For example, `chef env --chef-license accept`. - -#### Chef Infra Client - -In addition to the above methods, users can specify `chef_license 'accept'` in their Chef Infra Client and Chef Infra Server config. On a workstation, this can be specified in `~/.chef/config.rb` or `~/.chef/knife.rb`, and on a node, it can be specified in `/etc/chef/client.rb`. This method of license acceptance is backwards-compatible to non-EULA versions of Chef Infra Client. - -#### Chef Habitat - -There are two methods for accepting the Chef Habitat license: - -1. Users can execute `hab license accept` on the command line. -1. Alternatively, users can set `HAB_LICENSE=""` as an environment variable. - `` can be specified as one of the following: - 1. `accept` - Accepts the license and persists a marker file locally. Future invocations do not require accepting the license again. - 1. `accept-no-persist` - accepts the license without persisting an marker file. Future invocation will require accepting the license again. - -If the license is not accepted through either of these methods, Chef Habitat will request acceptance through an interactive prompt. - -Additionally, to accepting the license in CI or other automation, user may choose to create an empty file on the filesystem at `/hab/accepted-licenses/habitat` (if your hab commands run as root) or at `$HOME/.hab/accepted-licenses/habitat` (if your hab commands run as a user other than root). For situations where hab commands run as multiple users, it is advisable to create both files. - -#### Errors - -If the Chef Habitat License prompt cannot be displayed, then the product fails with an exit code 172. If Chef Habitat cannot persist the accepted license, it sends a message STDOUT, but the product invocation will continue successfully. In a future invocation, however, the user will need to accept the license again. - -#### Chef as `hab` packages - -Chef Software products are also distributed as `hab` packages. When Chef products are installed using Chef Habitat, the products request license acceptance at product usage time. Accept the licenses in the same way detailed above. - -### Server Products - -Some Chef products distributed as `hab` packages contain servers. In these cases, Chef Habitat runs the server products as a supervisor. See the below sections for information on how to accept the license for these products when they are distributed as `hab` packages. - - ---- - - - - - - - - - - - - - - - - - - - - -
ProductVersion
Chef Infra Server>= 13.0
Chef Automate>= 2.0
Supermarket>= 4.0
- -Server products are typically installed and managed by some kind of process supervisor. Chef Software server products do not allow interactive license acceptance because process supervisors do not allow interactivity. Instead, the license is accepted during the `reconfigure` command or `upgrade` command for the Omnibus ctl command. For example: - -- `chef-server-ctl reconfigure --chef-license=accept` -- `CHEF_LICENSE="accept-no-persist" supermarket-ctl reconfigure` - -In addition, the Chef license can be accepted via the omnibus configuration file. Specify `chef_license 'accept'` in the `chef-server.rb` or `supermarket.rb` configuration. - -#### Chef Automate - -Chef Automate has its own reconfigure tool, `automate-ctl`. This tool walks users through the install and setup of Chef Automate. The Chef license is accepted after that in the browser. Please follow the in-product prompts. - -#### Chef Infra Server - -When installed as a system package, users accept the license with the ctl command. For example, `chef-server-ctl reconfigure --chef-license=accept`. Acceptance can also be set in the configuration file `chef-server.rb` as `chef_license "accept"`. - -Chef Infra Server is also distributed as a `hab` package and ran using the supervisor. In this mode, users accept the license by setting the correct configuration values. The key is `chef_license.acceptance`. - -For example: Against a supervisor running Chef Infra Server, run `echo "chef_license.acceptance = accept" | hab config apply server.default 100`. See the [Chef Habitat config updates documentation](/habitat/service_updates/) for more information about how to apply this configuration to a service group. - -### Remote Management Products - -- Test Kitchen -- `knife bootstrap` in Chef Infra Client -- `chef-run` in Chef Workstation -- Packer -- Terraform Chef Provider (Deprecated) -- Vagrant - -These products install or manage Chef on a remote instance. If a user has accepted the appropriate product license locally, it will be automatically transferred to the remote instance. For example, if a user has accepted the Chef Infra Client license locally and converges a Test Kitchen instance with the Chef provisioner, it will succeed by copying the acceptance to the remote instance. We aim to support this behavior, so Workstation users do not have their workflow affected, but any differences from that behavior are documented below. - -#### Test Kitchen - -Test Kitchen is not owned by or covered by the Chef license, but installing Chef Infra Client on a test instance is covered by the EULA. Without accepting the license, the converge will fail on the test instance. - -The Chef provisioner in Test Kitchen \>= 2.3 has been updated to simplify accepting this license on behalf of the test instance. Users can set the `CHEF_LICENSE` environment variable or add `chef_license: accept` to their provisioner config in their **kitchen.yml**. Specifying **accept** will attempt to persist the license acceptance locally. If a local license marker file is detected, no configuration is required; acceptance is automatically transferred to the test instance. - -To disable this persistence, specify `accept-no-persist` on every test instance converge. - -`kitchen-inspec` uses Chef InSpec as a library, and is not covered by the EULA when installed as a gem, but is covered by the EULA when packaged as part of the Chef Workstation installation. Accept the license in a similar way to the Chef Infra Client license - specify the `CHEF_LICENSE` environment variable, specify the `chef_license` config under the verifier section in `kitchen.yml` or persist the acceptance locally. - -##### Test Kitchen: Pin to Chef 14 - -You can pin to a specific version of chef in your kitchen.yml: - -```none -provisioner: - name: chef_zero - product_name: chef - product_version: 14.12.3 -``` - -#### `knife bootstrap` - -`knife` usage does not require accepting the EULA. A Chef Infra Client instance does require EULA acceptance. Using `knife bootstrap` to manage a Chef Infra Client instance will prompt a user to accept the license locally before allowing for bootstrapping the remote instance. Without this, `knife bootstrap` would fail. - -In most usage cases via Chef Workstation, this license will already have been accepted and will transfer across transparently. But if a user installs Chef Workstation and the first command they ever run is `knife bootstrap`, it will perform the same license acceptance flow as the Chef Infra Client product. - -##### `knife bootstrap` in Chef Infra Client 14 - -The `knife bootstrap` command in Chef Infra Client 14 cannot accept the Chef Infra Client 15 EULA on remote nodes unless you use a [custom template](/workstation/knife_bootstrap/#custom-templates) and add chef_license "accept" to the client.rb. This applies to workstations who have Chef Infra Client \<= 14.x, ChefDK \<= 3.x or Chef Workstation \<= 0.3 installed. - -##### `knife bootstrap`: Pin to Chef 14 - -Specify the following argument: - -```bash -knife bootstrap --bootstrap-version 14.12.3 -``` - -#### `chef-run` - -`chef-run` in Chef Workstation \>= 0.3 has been updated to add support for accepting the license locally when remotely running Chef Infra Client 15. As of Chef Workstation \<= 0.4 there is no way to manage the version of Chef Infra Client installed on the remote node. It defaults to the latest stable version available. - -To accept the license, complete one of the following three tasks. Either pass the `--chef-license` command line flag, set the `CHEF_LICENSE` environment variable, or add the following to your `~/.chef-workstation/config.toml` file: - -```none -[chef] -chef_license = "accept" -``` - -#### Packer - -Use a custom [Chef configuration template](https://www.packer.io/docs/provisioners/chef/chef-client#chef-configuration). In your provisioners config, include: - -```json -{ - "type": "chef-client", - "config_template": "path/to/client.rb" -} -``` - -In `path/to/client.rb`, include: - -```ruby -chef_license 'accept' -``` - -You may also add it to the [execute_command](https://www.packer.io/docs/provisioners/chef-client.html#execute_command), but this is not backwards-compatible, so it is not suggested. - -##### Packer: Pin to Chef 14 - -In your [Packer provisioners -config](https://www.packer.io/docs/provisioners/chef-client.html#install_command), -include: - -```json -{ - "type": "chef-client", - "install_command": "curl -L https://omnitruck.chef.io/install.sh | sudo bash -s -- -v 14.12.9" -} -``` - -#### Terraform Chef Provisioner - -{{< warning >}} -Terraform deprecated the Chef Provisioner in the [0.13.4](https://www.terraform.io/docs/language/resources/provisioners/chef.html) release and they will remove it in a future version. Terraform continues to support the Chef Provider. -{{< /warning >}} - -The license can be accepted via the Chef Infra Client config file, which is specified by the `client_options` [Terraform provisioner config](https://www.terraform.io/docs/provisioners/chef.html#client_options-array-): - -```none -provisioner "chef" { - client_options = ["chef_license 'accept'"] -} -``` - -##### Terraform: Pin to Chef 14 - -In your [Terraform provisioner config](https://www.terraform.io/docs/provisioners/chef.html#version-string-), include: - -```none -provisioner "chef" { - version = "14.12.3" -} -``` - -#### Vagrant - -This license acceptance can be done via the arguments API: - -```ruby -config.vm.provision 'chef_zero' do |chef| - chef.arguments = '--chef-license accept' -end -``` - -See the [Vagrant documentation](https://www.vagrantup.com/docs/provisioning/chef_common.html#arguments) for details. The `--chef-license` argument is not backwards-compatible to non-EULA Chef Infra Client versions. So instead, users can use the [custom config path](https://www.vagrantup.com/docs/provisioning/chef_common.html#custom_config_path) and point at a local file, which specifies the `chef_license` config. The environment variable is not currently supported. - -##### Vagrant: Pin to Chef 14 - -This version pinning can be done using the [version API](https://www.vagrantup.com/docs/provisioning/chef_common.html#version). In your Chef provisioner config: - -```ruby -config.vm.provision 'chef_zero' do |chef| - chef.version = '14.12.3' -end -``` - -### Pre-upgrade support - -Chef Software aims to make upgrading from a non-EULA version to a EULA version as simple as possible. For some products (Chef Infra Client 14.12.9, Chef InSpec 3.9.3), we added backwards-compatible support for the `--chef-license` command that performs a no-op. This allows customers to start specifying that argument in whatever way they manage those products before upgrading. - -Alternatively, users can specify the `CHEF_LICENSE` environment variable when invoking any of the EULA products to accept the license. This environment variable is ignored by non-EULA products, and so is backwards-compatible to older versions. - -#### `chef-client` cookbook - -For users that manage their Chef Infra Client installation using the `chef-client` cookbook, we added a new attribute that can be specified. Specify the node attribute `node['chef_client']['chef_license'] = 'accept'` when running the cookbook to apply the license acceptance in a backwards-compatible way. - -This functionality allows users to set that attribute for a Chef Infra Client 14 install, upgrade to Chef Infra Client 15, and have the product continue to work correctly. diff --git a/content/license/_index.md b/content/license/_index.md new file mode 100644 index 00000000000..970f5c41dd2 --- /dev/null +++ b/content/license/_index.md @@ -0,0 +1,60 @@ ++++ +title = "About Chef Licenses" +draft = false +gh_repo = "chef-web-docs" +aliases = ["/chef_license.html"] + +[cascade] + product = ["automate", "client", "server", "habitat", "inspec", "supermarket", "workstation"] + +[menu] + [menu.overview] + title = "About Licensing" + identifier = "overview/licensing/chef_license.md About Licensing" + parent = "overview/licensing" + weight = 10 ++++ + +With the release of Chef InSpec 6, we are introducing a new licensing model which will expand to cover to all Chef products at a future date. The new licensing model is more flexible and lets customers and end-users choose a license which adapts to their specific DevOps scenarios. + +For all products, including Chef InSpec 6 and higher, the existing Progress Chef [EULA][EULA] still applies and is unchanged. The Progress Chef EULA covers the usage of the product distribution. Licensing and reuse of open source code is described in the section below [LINK]. + +Source code reuse is unchanged and follows the Apache 2.0 model as described below for open source products and repositories from Progress Chef. + +## Chef End-User License Agreement + +The commercial distributions of our products—such as Chef Infra Client, Chef Habitat, or Chef InSpec—are governed by either the Chef End User License Agreement (Chef EULA) or your commercial agreement with Progress Software Corporation. You are required to accept these terms when using the distributions for the first time. For additional information on how to accept the license, see [Accepting the Chef License](/license/accept/) documentation. + +If you have a license from before April 2019 (referred to as the Chef Master License and Services Agreement, or MLSA), please consult the [Chef versions documentation](https://docs.chef.io/versions/) to understand which license applies. + +## Overview of new license types + +For Chef InSpec 6 and higher, there are three new end-user licenses which govern usage and come with different entitlements: a free license, a trial license, and a commercial license. Upon installation of the Chef InSpec product distribution, the end-user accepts the basic Progress Chef [EULA][EULA] and then must activate the product with one of these new additional licenses. Chef InSpec 6 will not run without at least one of these licenses being applied. Each license type has different entitlements and permission grants based on the customer's intended usage. + +| License | Duration | Cost | Features | Intended environment | Support Model | Restrictions | Typical Persona | Intended uses | +| ----------- | ----------- | ----------- | ----------- | ----------- | ----------- | ----------- | ----------- | --------- | +| Free | Perpetual requiring annual renewal | Free | Basic | Non-production workloads | Community support in Slack | Some features and scale may be restricted | Issued to individual (seat license) | Personal and non-commercial use | +| Trial | Initial 30-day license renewable up to 90 days | Free | Advanced functionality enabled | Non-production workloads | Community support in Slack and solution architect support | Some features and scale may be restricted | Individual within an organization | Evaluate products in a non-production environment organization or company | +| Commercial | Duration of contract, renewable and upgradable | Paid | Advanced functionality enabled | Production and Non-production workloads | Support per contract | Full product(s) and content per contract | Professional DevOps Engineer within an organization | Enterprise workloads | + +Licensing is available for non-profit, research and/or academic organizations through a special, free or highly discounted commercial license at [NPRA](https://www.chef.io/nonprofit-entitlement-program). + +Official downstream distributions made from original Chef distributions (for example, CINC) are not affected by this license change. + +## Required and optional usage data + +The Progress Chef EULA requires basic license information to be transmitted to Chef for all products, including InSpec 6.0. The basic license information collected includes which applications are in use, what versions they are, and the license(s) they are being governed by. How often? Link to another article? + +The licensed customer may opt in to additional telemetry and usage data being sent back to Chef. This telemetry is used to tailor recommendations to customers, develop new features, and optimize the customer experience. Can the customer see this data? Can they opt-in / out regularly? Link to another article on what this is, maybe the telemetry service? + +## Reuse Progress Chef as open source + +Reuse of source code from the Progress Chef projects—including Chef Infra Client ("chef"), Chef InSpec, and Chef Habitat—is governed by the [Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0.txt) (unless specified in the repository otherwise) and source code is released publicly through repositories in these organizations: + +- [Progress Chef](https://github.com/chef) +- [Progress Chef InSpec](https://github.com/inspec) +- [Progress Chef Habitat](https://github.com/habitat-sh) + +Progress Chef identifies Third-party software included in our distributions in the `/opt//LICENSE` file of our distribution. Full copies of all third-party referenced licenses can be found in the `/opt//LICENSES` directory. + +Progress Chef releases other intermediate products on other public sites for use by the community. Binaries, modules, containers and executables (including scripts or interpreted language files such as Ruby) which are released on sites other than GitHub, are governed by the EULA above, require a license and are not considered open source. The reuse of source code and these intermediate products is described [here LINK](). For further questions, please contact Chef Developer Relations. diff --git a/content/license/accept.md b/content/license/accept.md new file mode 100644 index 00000000000..66dbf0c3205 --- /dev/null +++ b/content/license/accept.md @@ -0,0 +1,286 @@ ++++ +title = "Accepting the Chef License" +draft = false +gh_repo = "chef-web-docs" +aliases = ["/chef_license_accept.html", "/chef_license_accept/"] + +[menu] + [menu.overview] + title = "Accepting License" + identifier = "overview/licensing/Accepting License" + parent = "overview/licensing" + weight = 20 ++++ + +This page aims to document how to accept the Chef license for all Chef Software products. For an overview of the license, see the [Chef license](/chef_license/) documentation. There are two types of license: MLSA and EULA. The MLSA applies to customers with a commercial contract with Chef Software, and the EULA covers all other cases. + +## Accept the Chef MLSA + +There are three ways to accept the Chef MLSA: + +1. When running `chef--ctl reconfigure` the Chef MLSA is printed. Type `yes` to accept it. Anything other than typing `yes` rejects the Chef MLSA, and the upgrade process will exit. Typing `yes` adds a `.license.accepted` file to the `/etc/chef/accepted_licenses/` file. As long as this file exists in this directory, the Chef MLSA is accepted and the reconfigure process will not prompt for `yes`. +2. Run the `chef--ctl reconfigure` command using the `--chef-license=accept` option. This automatically types `yes` and skips printing the Chef MLSA. +3. Add a `.license.accepted` file to the `/var/opt//` directory. The contents of this file do not matter. As long as this file exists in this directory, the Chef MLSA is accepted and the reconfigure process will not prompt for `yes`. + +## Accept the Chef EULA + +Products below are split below into two categories: workstation and server. Affected product versions which require accepting the EULA to use are shown. Versions before this do not require accepting the EULA. More information on supported versions can be seen at the [Supported Versions](/versions/) documentation. + +### Workstation Products + +- Chef Workstation \>= 0.4, which also contains: + - Chef Infra Client + - Chef InSpec +- Chef Infra Client \>= 15.0 +- Chef InSpec \>= 4.0 +- Chef Habitat \>= 0.80 + +These products are typically installed on a user's workstation. Two common methods for accepting the license are: + +1. `--chef-license ` argument passed to the command line invocation. +1. `CHEF_LICENSE=""` as an environment variable. + `` can be specified as one of the following: + 1. `accept` - Accepts the license and attempts to persist a marker file locally. Persisting these marker files means future invocations do not require accepting the license again. + 1. `accept-silent` - Similar to `accept` except no messaging is sent to STDOUT + 1. `accept-no-persist` - Similar to `accept-silent` except no marker file is persisted. Future invocation will require accepting the license again. + +If no command line argument or environment variable is set, these products will attempt to request acceptance through an interactive prompt. If the prompt cannot be displayed, then the product will fail with an exit code 172. + +If the product attempts to persist the accepted license and fails, a message will be sent to STDOUT, but product invocation will continue successfully. In a future invocation, however, the license would need to be accepted again. + +Please see [License File Persistence](https://github.com/chef/license-acceptance#license-file-persistence) for details about persisted marker files. + +The `--chef-license` command line argument is not backwards compatible to older non-EULA versions. If you are managing a multi-version environment, we recommend using the environment variable as that is ignored by older versions. + +Products with specific features or differences from this general behavior are documented below. + +#### Chef Workstation + +Chef Workstation contains multiple Chef Software products. When invoking the `chef` command line tool and accepting the license, users are required to accept the license for all the embedded products as well. The same license applies to all products, but each product must have its own license acceptance. `chef --chef-license accept` will accept the license for Chef Workstation, Chef Infra Client, and Chef InSpec. For example, `chef env --chef-license accept`. + +#### Chef Infra Client + +In addition to the above methods, users can specify `chef_license 'accept'` in their Chef Infra Client and Chef Infra Server config. On a workstation, this can be specified in `~/.chef/config.rb` or `~/.chef/knife.rb`, and on a node, it can be specified in `/etc/chef/client.rb`. This method of license acceptance is backwards-compatible to non-EULA versions of Chef Infra Client. + +#### Chef Habitat + +There are two methods for accepting the Chef Habitat license: + +1. Users can execute `hab license accept` on the command line. +1. Alternatively, users can set `HAB_LICENSE=""` as an environment variable. + `` can be specified as one of the following: + 1. `accept` - Accepts the license and persists a marker file locally. Future invocations do not require accepting the license again. + 1. `accept-no-persist` - accepts the license without persisting an marker file. Future invocation will require accepting the license again. + +If the license is not accepted through either of these methods, Chef Habitat will request acceptance through an interactive prompt. + +Additionally, to accepting the license in CI or other automation, user may choose to create an empty file on the filesystem at `/hab/accepted-licenses/habitat` (if your hab commands run as root) or at `$HOME/.hab/accepted-licenses/habitat` (if your hab commands run as a user other than root). For situations where hab commands run as multiple users, it is advisable to create both files. + +#### Errors + +If the Chef Habitat License prompt cannot be displayed, then the product fails with an exit code 172. If Chef Habitat cannot persist the accepted license, it sends a message STDOUT, but the product invocation will continue successfully. In a future invocation, however, the user will need to accept the license again. + +#### Chef as `hab` packages + +Chef Software products are also distributed as `hab` packages. When Chef products are installed using Chef Habitat, the products request license acceptance at product usage time. Accept the licenses in the same way detailed above. + +### Server Products + +Some Chef products distributed as `hab` packages contain servers. In these cases, Chef Habitat runs the server products as a supervisor. See the below sections for information on how to accept the license for these products when they are distributed as `hab` packages. + + ++++ + + + + + + + + + + + + + + + + + + + + +
ProductVersion
Chef Infra Server>= 13.0
Chef Automate>= 2.0
Supermarket>= 4.0
+ +Server products are typically installed and managed by some kind of process supervisor. Chef Software server products do not allow interactive license acceptance because process supervisors do not allow interactivity. Instead, the license is accepted during the `reconfigure` command or `upgrade` command for the Omnibus ctl command. For example: + +- `chef-server-ctl reconfigure --chef-license=accept` +- `CHEF_LICENSE="accept-no-persist" supermarket-ctl reconfigure` + +In addition, the Chef license can be accepted via the omnibus configuration file. Specify `chef_license 'accept'` in the `chef-server.rb` or `supermarket.rb` configuration. + +#### Chef Automate + +Chef Automate has its own reconfigure tool, `automate-ctl`. This tool walks users through the install and setup of Chef Automate. The Chef license is accepted after that in the browser. Please follow the in-product prompts. + +#### Chef Infra Server + +When installed as a system package, users accept the license with the ctl command. For example, `chef-server-ctl reconfigure --chef-license=accept`. Acceptance can also be set in the configuration file `chef-server.rb` as `chef_license "accept"`. + +Chef Infra Server is also distributed as a `hab` package and ran using the supervisor. In this mode, users accept the license by setting the correct configuration values. The key is `chef_license.acceptance`. + +For example: Against a supervisor running Chef Infra Server, run `echo "chef_license.acceptance = accept" | hab config apply server.default 100`. See the [Chef Habitat config updates documentation](/habitat/service_updates/) for more information about how to apply this configuration to a service group. + +### Remote Management Products + +- Test Kitchen +- `knife bootstrap` in Chef Infra Client +- `chef-run` in Chef Workstation +- Packer +- Terraform Chef Provider (Deprecated) +- Vagrant + +These products install or manage Chef on a remote instance. If a user has accepted the appropriate product license locally, it will be automatically transferred to the remote instance. For example, if a user has accepted the Chef Infra Client license locally and converges a Test Kitchen instance with the Chef provisioner, it will succeed by copying the acceptance to the remote instance. We aim to support this behavior, so Workstation users do not have their workflow affected, but any differences from that behavior are documented below. + +#### Test Kitchen + +Test Kitchen is not owned by or covered by the Chef license, but installing Chef Infra Client on a test instance is covered by the EULA. Without accepting the license, the converge will fail on the test instance. + +The Chef provisioner in Test Kitchen \>= 2.3 has been updated to simplify accepting this license on behalf of the test instance. Users can set the `CHEF_LICENSE` environment variable or add `chef_license: accept` to their provisioner config in their **kitchen.yml**. Specifying **accept** will attempt to persist the license acceptance locally. If a local license marker file is detected, no configuration is required; acceptance is automatically transferred to the test instance. + +To disable this persistence, specify `accept-no-persist` on every test instance converge. + +`kitchen-inspec` uses Chef InSpec as a library, and is not covered by the EULA when installed as a gem, but is covered by the EULA when packaged as part of the Chef Workstation installation. Accept the license in a similar way to the Chef Infra Client license - specify the `CHEF_LICENSE` environment variable, specify the `chef_license` config under the verifier section in `kitchen.yml` or persist the acceptance locally. + +##### Test Kitchen: Pin to Chef 14 + +You can pin to a specific version of chef in your kitchen.yml: + +```none +provisioner: + name: chef_zero + product_name: chef + product_version: 14.12.3 +``` + +#### `knife bootstrap` + +`knife` usage does not require accepting the EULA. A Chef Infra Client instance does require EULA acceptance. Using `knife bootstrap` to manage a Chef Infra Client instance will prompt a user to accept the license locally before allowing for bootstrapping the remote instance. Without this, `knife bootstrap` would fail. + +In most usage cases via Chef Workstation, this license will already have been accepted and will transfer across transparently. But if a user installs Chef Workstation and the first command they ever run is `knife bootstrap`, it will perform the same license acceptance flow as the Chef Infra Client product. + +##### `knife bootstrap` in Chef Infra Client 14 + +The `knife bootstrap` command in Chef Infra Client 14 cannot accept the Chef Infra Client 15 EULA on remote nodes unless you use a [custom template](/workstation/knife_bootstrap/#custom-templates) and add chef_license "accept" to the client.rb. This applies to workstations who have Chef Infra Client \<= 14.x, ChefDK \<= 3.x or Chef Workstation \<= 0.3 installed. + +##### `knife bootstrap`: Pin to Chef 14 + +Specify the following argument: + +```bash +knife bootstrap --bootstrap-version 14.12.3 +``` + +#### `chef-run` + +`chef-run` in Chef Workstation \>= 0.3 has been updated to add support for accepting the license locally when remotely running Chef Infra Client 15. As of Chef Workstation \<= 0.4 there is no way to manage the version of Chef Infra Client installed on the remote node. It defaults to the latest stable version available. + +To accept the license, complete one of the following three tasks. Either pass the `--chef-license` command line flag, set the `CHEF_LICENSE` environment variable, or add the following to your `~/.chef-workstation/config.toml` file: + +```none +[chef] +chef_license = "accept" +``` + +#### Packer + +Use a custom [Chef configuration template](https://www.packer.io/docs/provisioners/chef/chef-client#chef-configuration). In your provisioners config, include: + +```json +{ + "type": "chef-client", + "config_template": "path/to/client.rb" +} +``` + +In `path/to/client.rb`, include: + +```ruby +chef_license 'accept' +``` + +You may also add it to the [execute_command](https://www.packer.io/docs/provisioners/chef-client.html#execute_command), but this is not backwards-compatible, so it is not suggested. + +##### Packer: Pin to Chef 14 + +In your [Packer provisioners +config](https://www.packer.io/docs/provisioners/chef-client.html#install_command), +include: + +```json +{ + "type": "chef-client", + "install_command": "curl -L https://omnitruck.chef.io/install.sh | sudo bash -s -- -v 14.12.9" +} +``` + +#### Terraform Chef Provisioner + +{{< warning >}} +Terraform deprecated the Chef Provisioner in the [0.13.4](https://www.terraform.io/docs/language/resources/provisioners/chef.html) release and they will remove it in a future version. Terraform continues to support the Chef Provider. +{{< /warning >}} + +The license can be accepted via the Chef Infra Client config file, which is specified by the `client_options` [Terraform provisioner config](https://www.terraform.io/docs/provisioners/chef.html#client_options-array-): + +```none +provisioner "chef" { + client_options = ["chef_license 'accept'"] +} +``` + +##### Terraform: Pin to Chef 14 + +In your [Terraform provisioner config](https://www.terraform.io/docs/provisioners/chef.html#version-string-), include: + +```none +provisioner "chef" { + version = "14.12.3" +} +``` + +#### Vagrant + +This license acceptance can be done via the arguments API: + +```ruby +config.vm.provision 'chef_zero' do |chef| + chef.arguments = '--chef-license accept' +end +``` + +See the [Vagrant documentation](https://www.vagrantup.com/docs/provisioning/chef_common.html#arguments) for details. The `--chef-license` argument is not backwards-compatible to non-EULA Chef Infra Client versions. So instead, users can use the [custom config path](https://www.vagrantup.com/docs/provisioning/chef_common.html#custom_config_path) and point at a local file, which specifies the `chef_license` config. The environment variable is not currently supported. + +##### Vagrant: Pin to Chef 14 + +This version pinning can be done using the [version API](https://www.vagrantup.com/docs/provisioning/chef_common.html#version). In your Chef provisioner config: + +```ruby +config.vm.provision 'chef_zero' do |chef| + chef.version = '14.12.3' +end +``` + +### Pre-upgrade support + +Chef Software aims to make upgrading from a non-EULA version to a EULA version as simple as possible. For some products (Chef Infra Client 14.12.9, Chef InSpec 3.9.3), we added backwards-compatible support for the `--chef-license` command that performs a no-op. This allows customers to start specifying that argument in whatever way they manage those products before upgrading. + +Alternatively, users can specify the `CHEF_LICENSE` environment variable when invoking any of the EULA products to accept the license. This environment variable is ignored by non-EULA products, and so is backwards-compatible to older versions. + +#### `chef-client` cookbook + +For users that manage their Chef Infra Client installation using the `chef-client` cookbook, we added a new attribute that can be specified. Specify the node attribute `node['chef_client']['chef_license'] = 'accept'` when running the cookbook to apply the license acceptance in a backwards-compatible way. + +This functionality allows users to set that attribute for a Chef Infra Client 14 install, upgrade to Chef Infra Client 15, and have the product continue to work correctly. diff --git a/content/license/terms.md b/content/license/terms.md new file mode 100644 index 00000000000..a3b9f4b1af6 --- /dev/null +++ b/content/license/terms.md @@ -0,0 +1,56 @@ ++++ +title = "Chef Licensing Terms" +draft = false +gh_repo = "chef-web-docs" +aliases = ["/chef_license.html", "/chef_license/"] + +[cascade] + product = ["automate", "client", "server", "habitat", "inspec", "supermarket", "workstation"] + +[menu] + [menu.overview] + title = "Terms" + identifier = "overview/plicensing/About Licensing" + parent = "overview/licensing" + weight = 30 ++++ + +Node +: Individual component of your system, physical or virtual (for example, a server, workstation, IP router, virtual machine, or another device or component) that is assessed, installed, configured, updated, scanned and/or managed using any Chef product. + +Scan +: Rules based of Inspection of a target. There can be many number of scans applied on a target. + +Target +: Each instance of infrastructure, software, configuration, cloud accounts, container hosts, or other technical resource that is the compliance target of one or more Chef InSpec profiles used by you. Each target can access a resource with its credentials and locations. + +Subscription License +: One of the license types that continue until the expiration of the subscription period identified in the order, unless earlier terminated in accordance with the terms of the EULA. + +Licensed Unit +: “License Unit” types/metrics include node, entitled content, service instance, target and/or endpoint. + +Measurement of License Units/License Consumption Data +: Measurement of usage of a license unit. It’s a numerical value based on the bundle\SKU or add-on(s) customer has purchased. + +Free-tier Users +: Users using a Free License of Chef (User will only get the executable but restricted in some way), not the code base. + +Trial Users +: Users downloading Chef products to evaluate its benefit to their organizations (restricted by time and limited features) + +Commercial Users +: Customers who have purchased a Chef license and are entitled to features/services (restricted based on the purchase order - #of days, #of nodes/target) + +Community Users +: [Open Source] CINC Users. [Free] Infra <= 12, Inspec <= 3 +: Users that use older versions of Chef open-source software or downstream OSS distributions of Chef (CINC). + +Open Source +: Chef Code available to all under Apache License, Version 2.0. This is not same as access to any licensed Chef products or free Chef products. + +Open Source Users +: Users who download the source code and build executables on their own, or get binaries/executables from open derivative work to confirming Apache License, Version 2.0. These users need not purchase license to use the product. + +Endpoint +: A compute device such as a laptop, desktop, or a tablet that is a primary workstation of a knowledge worker/student that has Chef supported platforms and is assessed, installed, configured, updated, scanned and is managed using Chef Desktop.