Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Additional doc updates from QA review #51

Merged
merged 3 commits into from
Oct 4, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ This provider, maintained by Solace, is a plugin for Terraform that enables you

The provider is available from the [Terraform Providers Registry](https://registry.terraform.io/providers/solaceproducts/solacebroker/latest).

The minimum required PubSub+ Software Event Broker version 10.4.

## Quick Start

1. Ensure you have admin access to a Solace PubSub+ Software Event Broker. Options include [local deployment of a containerized version](https://docs.solace.com/Software-Broker/SW-Broker-Set-Up/Containers/Set-Up-Container-Image.htm) or use of a free broker from [PubSub+ Cloud](https://docs.solace.com/Cloud/cloud-lp.htm).
Expand Down
51 changes: 30 additions & 21 deletions docs/guides/config-generator.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,16 @@ You can run the provider binary directly with the `generate` command to generate
- `<filename>` is the desirable name of the generated filename.
- There are also supported options, which mirror the configuration options for the provider object. These can be found [here](#supported-options).

### Usage
## Important notes

The generated configuration shoud be reviewed for followings:

* Provider configuration values (url, username, etc.) may need to be updated.
* Write-only attributes, such as passwords, are omitted from the config as they cannot be read from the broker configuration. They need to be added manually.
* Default resources may be present that may be omitted.
* The generator uses a naming scheme for the resources. This may be updated by manually replacing the generated names.

## Usage

```shell
terraform-provider-solacebroker -h
Expand Down Expand Up @@ -52,7 +61,26 @@ For example:
This command would create a file `my-message-vpn-queue.tf` that contains the msg_vpn_queue resource , `test` for the
Message VPN, `default`, assuming a msg_vpn_queue resource called `test` exists for the Message VPN, `default`.

### Troubleshooting
### Supported Options

The following parameters can be set as ENVIRONMENT VARIABLES. When used as environment variables
each parameter must be preceded with _SOLACEBROKER__. For example for a PubSub+ broker using username and password
_**admin/password**_
would be:

`SOLACEBROKER_USERNAME=admin SOLACEBROKER_PASSWORD=password`

- `bearer_token`, (String, Sensitive, Mandatory if `password` will not be provided)
- `insecure_skip_verify` (Boolean) Disable validation of server SSL certificates, accept/ignore self-signed.
- `password` (String, Sensitive, Mandatory is `bearer_token` will not be provided)
- `request_min_interval` (String)
- `request_timeout_duration` (String)
- `retries` (Number)
- `retry_max_interval` (String)
- `retry_min_interval` (String)
- `username` (String, Mandatory) The username for the broker request.

## Troubleshooting

The following issues may arise while using the generator.

Expand Down Expand Up @@ -80,22 +108,3 @@ The following issues may arise while using the generator.
|-----------------|------------------------------------------------------------------------------------------------------------|
| Explanation | This indicates the resource by name _xxx_ is not recognized by the generator. |
| Possible Action | Ensure the resource name used is available as a Terraform resource for the version of the provider in use. |

### Supported Options

The following parameters can be set as ENVIRONMENT VARIABLES. When used as environment variables
each parameter must be preceded with _SOLACEBROKER__. For example for a PubSub+ broker using username and password
_**admin/password**_
would be:

`SOLACEBROKER_USERNAME=admin SOLACEBROKER_PASSWORD=password`

- `bearer_token`, (String, Sensitive, Mandatory if `password` will not be provided)
- `insecure_skip_verify` (Boolean) Disable validation of server SSL certificates, accept/ignore self-signed.
- `password` (String, Sensitive, Mandatory is `bearer_token` will not be provided)
- `request_min_interval` (String)
- `request_timeout_duration` (String)
- `retries` (Number)
- `retry_max_interval` (String)
- `retry_min_interval` (String)
- `username` (String, Mandatory) The username for the broker request.
2 changes: 1 addition & 1 deletion docs/guides/provider.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ The SEMP API minor version reflects the supported set of objects, attributes, th

New versions of the PubSub+ event broker with new features typically require a newer SEMP API version that supports the new or updated objects, attributes, etc. The SEMP API version of a broker version can be determined from the [Solace PubSub+ documentation](https://docs.solace.com/Admin/SEMP/SEMP-API-Versions.htm#SEMP_v2_to_SolOS_Version_Mapping).

A given version of the provider is built to support a specific version of the SEMP API. For the SEMP API version of the provider, see the release notes in the GitHub repo.
A given version of the provider is built to support a specific version of the SEMP API. For the SEMP API version of the provider and corresponding broker version, refer to the [Version Compatibility section](https://docs.solace.com/Admin/SEMP/Declarative-SEMP.htm#Version) of the Solace PubSub+ documentation.

* Broker versions at the same SEMP API version level as the provider can be fully configured.
* Broker versions at a lower SEMP API version level than the provider can be configured, except for objects or attributes that have been deprecated and removed in the provider's SEMP version. However, configuration will fail when attempting to configure objects or attributes that have been introduced in a later SEMP version than the broker supports.
Expand Down
6 changes: 5 additions & 1 deletion docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,10 @@ This provider also offers the possibility to generate an [HCL configuration](htt

Use the navigation to the left for more information in the guides and for the available provider resources and data sources.

## Minimum broker version

The minimum required PubSub+ Software Event Broker version is 10.4.

## Example Usage

```terraform
Expand Down Expand Up @@ -65,7 +69,7 @@ resource "solacebroker_msg_vpn_queue" "q" {

### Optional

- `bearer_token` (String, Sensitive) A bearer token that will be sent in the Authorization header of SEMP requests. Conflicts with username and password.
- `bearer_token` (String, Sensitive) A bearer token that will be sent in the Authorization header of SEMP requests. Requires TLS transport enabled. Conflicts with username and password.
- `insecure_skip_verify` (Boolean) Disable validation of server SSL certificates, accept/ignore self-signed. The default value is false.
- `password` (String, Sensitive) The password to connect to the broker with. Requires username and conflicts with bearer_token.
- `request_min_interval` (String) A [duration](https://pkg.go.dev/maze.io/x/duration#ParseDuration) string indicating the minimum interval between requests; this serves as a rate limit. This setting does not apply to retries. Set to 0 for no rate limit. The default value is 100ms (which equates to a rate limit of 10 calls per second).
Expand Down
2 changes: 1 addition & 1 deletion internal/broker/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ func (p *BrokerProvider) Schema(_ context.Context, _ provider.SchemaRequest, res
Sensitive: true,
},
"bearer_token": schema.StringAttribute{
MarkdownDescription: "A bearer token that will be sent in the Authorization header of SEMP requests. Conflicts with username and password.",
MarkdownDescription: "A bearer token that will be sent in the Authorization header of SEMP requests. Requires TLS transport enabled. Conflicts with username and password.",
Optional: true,
Sensitive: true,
},
Expand Down
51 changes: 30 additions & 21 deletions templates/guides/config-generator.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,16 @@ You can run the provider binary directly with the `generate` command to generate
- `<filename>` is the desirable name of the generated filename.
- There are also supported options, which mirror the configuration options for the provider object. These can be found [here](#supported-options).

### Usage
## Important notes

The generated configuration shoud be reviewed for followings:

* Provider configuration values (url, username, etc.) may need to be updated.
* Write-only attributes, such as passwords, are omitted from the config as they cannot be read from the broker configuration. They need to be added manually.
* Default resources may be present that may be omitted.
* The generator uses a naming scheme for the resources. This may be updated by manually replacing the generated names.

## Usage

```shell
terraform-provider-solacebroker -h
Expand Down Expand Up @@ -52,7 +61,26 @@ For example:
This command would create a file `my-message-vpn-queue.tf` that contains the msg_vpn_queue resource , `test` for the
Message VPN, `default`, assuming a msg_vpn_queue resource called `test` exists for the Message VPN, `default`.

### Troubleshooting
### Supported Options

The following parameters can be set as ENVIRONMENT VARIABLES. When used as environment variables
each parameter must be preceded with _SOLACEBROKER__. For example for a PubSub+ broker using username and password
_**admin/password**_
would be:

`SOLACEBROKER_USERNAME=admin SOLACEBROKER_PASSWORD=password`

- `bearer_token`, (String, Sensitive, Mandatory if `password` will not be provided)
- `insecure_skip_verify` (Boolean) Disable validation of server SSL certificates, accept/ignore self-signed.
- `password` (String, Sensitive, Mandatory is `bearer_token` will not be provided)
- `request_min_interval` (String)
- `request_timeout_duration` (String)
- `retries` (Number)
- `retry_max_interval` (String)
- `retry_min_interval` (String)
- `username` (String, Mandatory) The username for the broker request.

## Troubleshooting

The following issues may arise while using the generator.

Expand Down Expand Up @@ -80,22 +108,3 @@ The following issues may arise while using the generator.
|-----------------|------------------------------------------------------------------------------------------------------------|
| Explanation | This indicates the resource by name _xxx_ is not recognized by the generator. |
| Possible Action | Ensure the resource name used is available as a Terraform resource for the version of the provider in use. |

### Supported Options

The following parameters can be set as ENVIRONMENT VARIABLES. When used as environment variables
each parameter must be preceded with _SOLACEBROKER__. For example for a PubSub+ broker using username and password
_**admin/password**_
would be:

`SOLACEBROKER_USERNAME=admin SOLACEBROKER_PASSWORD=password`

- `bearer_token`, (String, Sensitive, Mandatory if `password` will not be provided)
- `insecure_skip_verify` (Boolean) Disable validation of server SSL certificates, accept/ignore self-signed.
- `password` (String, Sensitive, Mandatory is `bearer_token` will not be provided)
- `request_min_interval` (String)
- `request_timeout_duration` (String)
- `retries` (Number)
- `retry_max_interval` (String)
- `retry_min_interval` (String)
- `username` (String, Mandatory) The username for the broker request.
2 changes: 1 addition & 1 deletion templates/guides/provider.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ The SEMP API minor version reflects the supported set of objects, attributes, th

New versions of the PubSub+ event broker with new features typically require a newer SEMP API version that supports the new or updated objects, attributes, etc. The SEMP API version of a broker version can be determined from the [Solace PubSub+ documentation](https://docs.solace.com/Admin/SEMP/SEMP-API-Versions.htm#SEMP_v2_to_SolOS_Version_Mapping).

A given version of the provider is built to support a specific version of the SEMP API. For the SEMP API version of the provider, see the release notes in the GitHub repo.
A given version of the provider is built to support a specific version of the SEMP API. For the SEMP API version of the provider and corresponding broker version, refer to the [Version Compatibility section](https://docs.solace.com/Admin/SEMP/Declarative-SEMP.htm#Version) of the Solace PubSub+ documentation.

* Broker versions at the same SEMP API version level as the provider can be fully configured.
* Broker versions at a lower SEMP API version level than the provider can be configured, except for objects or attributes that have been deprecated and removed in the provider's SEMP version. However, configuration will fail when attempting to configure objects or attributes that have been introduced in a later SEMP version than the broker supports.
Expand Down
4 changes: 4 additions & 0 deletions templates/index.md.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,10 @@ This provider also offers the possibility to generate an [HCL configuration](htt

Use the navigation to the left for more information in the guides and for the available provider resources and data sources.

## Minimum broker version

The minimum required PubSub+ Software Event Broker version 10.4.

## Example Usage

{{ tffile "examples/sampleconfig.tf" }}
Expand Down