From aed6fd50122e8e998c2b7480006672d366b3d4a1 Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Fri, 25 Oct 2024 16:47:46 +0200 Subject: [PATCH 1/7] Add support to expose deployment modes fields --- packages/datastream.go | 17 +++++++------- packages/package.go | 52 ++++++++++++++++++++++++++---------------- 2 files changed, 41 insertions(+), 28 deletions(-) diff --git a/packages/datastream.go b/packages/datastream.go index 85dc95105..f21ef0274 100644 --- a/packages/datastream.go +++ b/packages/datastream.go @@ -84,14 +84,15 @@ type Stream struct { } type Variable struct { - Name string `config:"name" json:"name" yaml:"name"` - Type string `config:"type" json:"type" yaml:"type"` - Title string `config:"title" json:"title,omitempty" yaml:"title,omitempty"` - Description string `config:"description" json:"description,omitempty" yaml:"description,omitempty"` - Multi bool `config:"multi" json:"multi" yaml:"multi"` - Required bool `config:"required" json:"required" yaml:"required"` - ShowUser bool `config:"show_user" json:"show_user" yaml:"show_user"` - Default interface{} `config:"default" json:"default,omitempty" yaml:"default,omitempty"` + Name string `config:"name" json:"name" yaml:"name"` + Type string `config:"type" json:"type" yaml:"type"` + Title string `config:"title" json:"title,omitempty" yaml:"title,omitempty"` + Description string `config:"description" json:"description,omitempty" yaml:"description,omitempty"` + Multi bool `config:"multi" json:"multi" yaml:"multi"` + Required bool `config:"required" json:"required" yaml:"required"` + ShowUser bool `config:"show_user" json:"show_user" yaml:"show_user"` + Default interface{} `config:"default" json:"default,omitempty" yaml:"default,omitempty"` + HideInDeploymentModes []string `config:"hide_in_deployment_modes,omitempty" json:"hide_in_deployment_modes,omitempty" yaml:"hide_in_deployment_modes,omitempty"` } type DataStreamAgent struct { diff --git a/packages/package.go b/packages/package.go index 6e3f16861..01c3b05e7 100644 --- a/packages/package.go +++ b/packages/package.go @@ -81,24 +81,26 @@ type BasePackage struct { // BasePolicyTemplate is used for the package policy templates in the /search endpoint type BasePolicyTemplate struct { - Name string `config:"name" json:"name" validate:"required"` - Title string `config:"title" json:"title" validate:"required"` - Description string `config:"description" json:"description" validate:"required"` - Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` - Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` + Name string `config:"name" json:"name" validate:"required"` + Title string `config:"title" json:"title" validate:"required"` + Description string `config:"description" json:"description" validate:"required"` + Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` + Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` + DeploymentModes *DeploymentModes `config:"deployment_modes,omitempty" json:"deployment_modes,omitempty" yaml:"deployment_modes,omitempty"` } type PolicyTemplate struct { - Name string `config:"name" json:"name" validate:"required"` - Title string `config:"title" json:"title" validate:"required"` - Description string `config:"description" json:"description" validate:"required"` - DataStreams []string `config:"data_streams,omitempty" json:"data_streams,omitempty" yaml:"data_streams,omitempty"` - Inputs []Input `config:"inputs" json:"inputs,omitempty" yaml:"inputs,omitempty"` - Multiple *bool `config:"multiple" json:"multiple,omitempty" yaml:"multiple,omitempty"` - Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` - Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` - Screenshots []Image `config:"screenshots,omitempty" json:"screenshots,omitempty" yaml:"screenshots,omitempty"` - Readme *string `config:"readme,omitempty" json:"readme,omitempty" yaml:"readme,omitempty"` + Name string `config:"name" json:"name" validate:"required"` + Title string `config:"title" json:"title" validate:"required"` + Description string `config:"description" json:"description" validate:"required"` + DataStreams []string `config:"data_streams,omitempty" json:"data_streams,omitempty" yaml:"data_streams,omitempty"` + Inputs []Input `config:"inputs" json:"inputs,omitempty" yaml:"inputs,omitempty"` + Multiple *bool `config:"multiple" json:"multiple,omitempty" yaml:"multiple,omitempty"` + Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` + Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` + Screenshots []Image `config:"screenshots,omitempty" json:"screenshots,omitempty" yaml:"screenshots,omitempty"` + Readme *string `config:"readme,omitempty" json:"readme,omitempty" yaml:"readme,omitempty"` + DeploymentModes *DeploymentModes `config:"deployment_modes,omitempty" json:"deployment_modes,omitempty" yaml:"deployment_modes,omitempty"` // For purposes of "input packages" Type string `config:"type,omitempty" json:"type,omitempty" yaml:"type,omitempty"` @@ -184,6 +186,15 @@ type Download struct { Type string `config:"type" json:"type" validate:"required"` } +type DeploymentModes struct { + Default *DeploymentMode `config:"default,omitempty" json:"default,omitempty" yaml:"default,omitempty"` + Agentless *DeploymentMode `config:"agentless,omitempty" json:"agentless,omitempty" yaml:"agentless,omitempty"` +} + +type DeploymentMode struct { + Enabled bool `config:"enabled" json:"enabled" yaml:"enabled" validate:"required"` +} + func NewDownload(p Package, t string) Download { return Download{ Path: getDownloadPath(p, t), @@ -378,11 +389,12 @@ func (p *Package) setRuntimeFields() error { func (p *Package) setBasePolicyTemplates() { for _, t := range p.PolicyTemplates { baseT := BasePolicyTemplate{ - Name: t.Name, - Title: t.Title, - Description: t.Description, - Categories: t.Categories, - Icons: t.Icons, + Name: t.Name, + Title: t.Title, + Description: t.Description, + Categories: t.Categories, + Icons: t.Icons, + DeploymentModes: t.DeploymentModes, } p.BasePolicyTemplates = append(p.BasePolicyTemplates, baseT) From 243239439e7c1d4f27f9e04b77b683270f8d94f6 Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Fri, 25 Oct 2024 16:50:32 +0200 Subject: [PATCH 2/7] Add test package with deployment modes --- packages/testdata/marshaler/packages.json | 120 ++++++++++++++++++ .../generated/categories-experimental.json | 2 +- ...tegories-prerelease-capabilities-none.json | 2 +- ...e-capabilities-observability-security.json | 2 +- testdata/generated/categories-prerelease.json | 2 +- .../package/deployment_modes/0.0.1/index.json | 120 ++++++++++++++++++ .../search-package-experimental.json | 65 ++++++++++ .../generated/search-package-prerelease.json | 65 ++++++++++ .../search-prerelease-capabilities-none.json | 65 ++++++++++ ...e-capabilities-observability-security.json | 65 ++++++++++ .../deployment_modes/0.0.1/LICENSE.txt | 93 ++++++++++++++ .../deployment_modes/0.0.1/changelog.yml | 6 + .../deployment_modes/0.0.1/docs/README.md | 84 ++++++++++++ .../0.0.1/img/sample-logo.svg | 1 + .../0.0.1/img/sample-screenshot.png | Bin 0 -> 18849 bytes .../deployment_modes/0.0.1/manifest.yml | 68 ++++++++++ 16 files changed, 756 insertions(+), 4 deletions(-) create mode 100644 testdata/generated/package/deployment_modes/0.0.1/index.json create mode 100644 testdata/package/deployment_modes/0.0.1/LICENSE.txt create mode 100644 testdata/package/deployment_modes/0.0.1/changelog.yml create mode 100644 testdata/package/deployment_modes/0.0.1/docs/README.md create mode 100644 testdata/package/deployment_modes/0.0.1/img/sample-logo.svg create mode 100644 testdata/package/deployment_modes/0.0.1/img/sample-screenshot.png create mode 100644 testdata/package/deployment_modes/0.0.1/manifest.yml diff --git a/packages/testdata/marshaler/packages.json b/packages/testdata/marshaler/packages.json index 26ee3018a..53ccb491a 100644 --- a/packages/testdata/marshaler/packages.json +++ b/packages/testdata/marshaler/packages.json @@ -505,6 +505,126 @@ "/package/defaultrelease/0.0.1/docs/README.md" ] }, + { + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ], + "format_version": "3.3.0", + "readme": "/package/deployment_modes/0.0.1/docs/README.md", + "license": "basic", + "screenshots": [ + { + "src": "/img/sample-screenshot.png", + "path": "/package/deployment_modes/0.0.1/img/sample-screenshot.png", + "title": "Sample screenshot", + "size": "600x600", + "type": "image/png" + } + ], + "assets": [ + "/package/deployment_modes/0.0.1/LICENSE.txt", + "/package/deployment_modes/0.0.1/changelog.yml", + "/package/deployment_modes/0.0.1/manifest.yml", + "/package/deployment_modes/0.0.1/docs/README.md", + "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "/package/deployment_modes/0.0.1/img/sample-screenshot.png" + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "inputs": [ + { + "type": "logfile", + "vars": [ + { + "name": "path", + "type": "text", + "multi": false, + "required": false, + "show_user": true + }, + { + "name": "tags", + "type": "text", + "multi": true, + "required": false, + "show_user": false, + "hide_in_deployment_modes": [ + "agentless" + ] + } + ], + "title": "Collect sample logs from instances", + "description": "Collecting sample logs" + } + ], + "multiple": false, + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "inputs": [ + { + "type": "logfile", + "title": "Collect sample logs from instances", + "description": "Collecting sample logs" + } + ], + "multiple": false, + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ] + }, { "name": "ecs_style_dataset", "title": "Default pipeline Integration", diff --git a/testdata/generated/categories-experimental.json b/testdata/generated/categories-experimental.json index 8e22f9266..a47e2f536 100644 --- a/testdata/generated/categories-experimental.json +++ b/testdata/generated/categories-experimental.json @@ -27,7 +27,7 @@ { "id": "custom", "title": "Custom", - "count": 17 + "count": 18 }, { "id": "datastore", diff --git a/testdata/generated/categories-prerelease-capabilities-none.json b/testdata/generated/categories-prerelease-capabilities-none.json index c8a3778ff..8e22f9266 100644 --- a/testdata/generated/categories-prerelease-capabilities-none.json +++ b/testdata/generated/categories-prerelease-capabilities-none.json @@ -27,7 +27,7 @@ { "id": "custom", "title": "Custom", - "count": 16 + "count": 17 }, { "id": "datastore", diff --git a/testdata/generated/categories-prerelease-capabilities-observability-security.json b/testdata/generated/categories-prerelease-capabilities-observability-security.json index 4ba4a850b..6796d6af8 100644 --- a/testdata/generated/categories-prerelease-capabilities-observability-security.json +++ b/testdata/generated/categories-prerelease-capabilities-observability-security.json @@ -27,7 +27,7 @@ { "id": "custom", "title": "Custom", - "count": 16 + "count": 17 }, { "id": "datastore", diff --git a/testdata/generated/categories-prerelease.json b/testdata/generated/categories-prerelease.json index 6796d6af8..095645170 100644 --- a/testdata/generated/categories-prerelease.json +++ b/testdata/generated/categories-prerelease.json @@ -27,7 +27,7 @@ { "id": "custom", "title": "Custom", - "count": 17 + "count": 18 }, { "id": "datastore", diff --git a/testdata/generated/package/deployment_modes/0.0.1/index.json b/testdata/generated/package/deployment_modes/0.0.1/index.json new file mode 100644 index 000000000..1cb21f19e --- /dev/null +++ b/testdata/generated/package/deployment_modes/0.0.1/index.json @@ -0,0 +1,120 @@ +{ + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ], + "format_version": "3.3.0", + "readme": "/package/deployment_modes/0.0.1/docs/README.md", + "license": "basic", + "screenshots": [ + { + "src": "/img/sample-screenshot.png", + "path": "/package/deployment_modes/0.0.1/img/sample-screenshot.png", + "title": "Sample screenshot", + "size": "600x600", + "type": "image/png" + } + ], + "assets": [ + "/package/deployment_modes/0.0.1/LICENSE.txt", + "/package/deployment_modes/0.0.1/changelog.yml", + "/package/deployment_modes/0.0.1/manifest.yml", + "/package/deployment_modes/0.0.1/docs/README.md", + "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "/package/deployment_modes/0.0.1/img/sample-screenshot.png" + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "inputs": [ + { + "type": "logfile", + "vars": [ + { + "name": "path", + "type": "text", + "multi": false, + "required": false, + "show_user": true + }, + { + "name": "tags", + "type": "text", + "multi": true, + "required": false, + "show_user": false, + "hide_in_deployment_modes": [ + "agentless" + ] + } + ], + "title": "Collect sample logs from instances", + "description": "Collecting sample logs" + } + ], + "multiple": false, + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "inputs": [ + { + "type": "logfile", + "title": "Collect sample logs from instances", + "description": "Collecting sample logs" + } + ], + "multiple": false, + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ] +} diff --git a/testdata/generated/search-package-experimental.json b/testdata/generated/search-package-experimental.json index 09c5c2c55..00b9b1b38 100644 --- a/testdata/generated/search-package-experimental.json +++ b/testdata/generated/search-package-experimental.json @@ -142,6 +142,71 @@ "message_queue" ] }, + { + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ] + }, { "name": "elasticsearch_privileges", "title": "Elasticsearch Privileges", diff --git a/testdata/generated/search-package-prerelease.json b/testdata/generated/search-package-prerelease.json index 822256fa3..ac4adb1b7 100644 --- a/testdata/generated/search-package-prerelease.json +++ b/testdata/generated/search-package-prerelease.json @@ -142,6 +142,71 @@ "message_queue" ] }, + { + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ] + }, { "name": "elasticsearch_privileges", "title": "Elasticsearch Privileges", diff --git a/testdata/generated/search-prerelease-capabilities-none.json b/testdata/generated/search-prerelease-capabilities-none.json index 46e784af7..46b383cc0 100644 --- a/testdata/generated/search-prerelease-capabilities-none.json +++ b/testdata/generated/search-prerelease-capabilities-none.json @@ -142,6 +142,71 @@ "message_queue" ] }, + { + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ] + }, { "name": "elasticsearch_privileges", "title": "Elasticsearch Privileges", diff --git a/testdata/generated/search-prerelease-capabilities-observability-security.json b/testdata/generated/search-prerelease-capabilities-observability-security.json index a2a976bd8..fa41ee239 100644 --- a/testdata/generated/search-prerelease-capabilities-observability-security.json +++ b/testdata/generated/search-prerelease-capabilities-observability-security.json @@ -142,6 +142,71 @@ "message_queue" ] }, + { + "name": "deployment_modes", + "title": "Deployment Modes", + "version": "0.0.1", + "release": "beta", + "source": { + "license": "Elastic-2.0" + }, + "description": "Package containing policy templates with different deployment modes", + "type": "integration", + "download": "/epr/deployment_modes/deployment_modes-0.0.1.zip", + "path": "/package/deployment_modes/0.0.1", + "icons": [ + { + "src": "/img/sample-logo.svg", + "path": "/package/deployment_modes/0.0.1/img/sample-logo.svg", + "title": "Sample logo", + "size": "32x32", + "type": "image/svg+xml" + } + ], + "policy_templates": [ + { + "name": "agentless", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": false + }, + "agentless": { + "enabled": true + } + } + }, + { + "name": "default", + "title": "Sample logs", + "description": "Collect sample logs", + "deployment_modes": { + "default": { + "enabled": true + }, + "agentless": { + "enabled": false + } + } + } + ], + "conditions": { + "kibana": { + "version": "^8.15.2" + }, + "elastic": { + "subscription": "basic" + } + }, + "owner": { + "type": "elastic", + "github": "elastic/integrations" + }, + "categories": [ + "custom" + ] + }, { "name": "elasticsearch_privileges", "title": "Elasticsearch Privileges", diff --git a/testdata/package/deployment_modes/0.0.1/LICENSE.txt b/testdata/package/deployment_modes/0.0.1/LICENSE.txt new file mode 100644 index 000000000..809108b85 --- /dev/null +++ b/testdata/package/deployment_modes/0.0.1/LICENSE.txt @@ -0,0 +1,93 @@ +Elastic License 2.0 + +URL: https://www.elastic.co/licensing/elastic-license + +## Acceptance + +By using the software, you agree to all of the terms and conditions below. + +## Copyright License + +The licensor grants you a non-exclusive, royalty-free, worldwide, +non-sublicensable, non-transferable license to use, copy, distribute, make +available, and prepare derivative works of the software, in each case subject to +the limitations and conditions below. + +## Limitations + +You may not provide the software to third parties as a hosted or managed +service, where the service provides users with access to any substantial set of +the features or functionality of the software. + +You may not move, change, disable, or circumvent the license key functionality +in the software, and you may not remove or obscure any functionality in the +software that is protected by the license key. + +You may not alter, remove, or obscure any licensing, copyright, or other notices +of the licensor in the software. Any use of the licensor’s trademarks is subject +to applicable law. + +## Patents + +The licensor grants you a license, under any patent claims the licensor can +license, or becomes able to license, to make, have made, use, sell, offer for +sale, import and have imported the software, in each case subject to the +limitations and conditions in this license. This license does not cover any +patent claims that you cause to be infringed by modifications or additions to +the software. If you or your company make any written claim that the software +infringes or contributes to infringement of any patent, your patent license for +the software granted under these terms ends immediately. If your company makes +such a claim, your patent license ends immediately for work on behalf of your +company. + +## Notices + +You must ensure that anyone who gets a copy of any part of the software from you +also gets a copy of these terms. + +If you modify the software, you must include in any modified copies of the +software prominent notices stating that you have modified the software. + +## No Other Rights + +These terms do not imply any licenses other than those expressly granted in +these terms. + +## Termination + +If you use the software in violation of these terms, such use is not licensed, +and your licenses will automatically terminate. If the licensor provides you +with a notice of your violation, and you cease all violation of this license no +later than 30 days after you receive that notice, your licenses will be +reinstated retroactively. However, if you violate these terms after such +reinstatement, any additional violation of these terms will cause your licenses +to terminate automatically and permanently. + +## No Liability + +*As far as the law allows, the software comes as is, without any warranty or +condition, and the licensor will not be liable to you for any damages arising +out of these terms or the use or nature of the software, under any kind of +legal claim.* + +## Definitions + +The **licensor** is the entity offering these terms, and the **software** is the +software the licensor makes available under these terms, including any portion +of it. + +**you** refers to the individual or entity agreeing to these terms. + +**your company** is any legal entity, sole proprietorship, or other kind of +organization that you work for, plus all organizations that have control over, +are under the control of, or are under common control with that +organization. **control** means ownership of substantially all the assets of an +entity, or the power to direct its management and policies by vote, contract, or +otherwise. Control can be direct or indirect. + +**your licenses** are all the licenses granted to you for the software under +these terms. + +**use** means anything you do with the software requiring one of your licenses. + +**trademark** means trademarks, service marks, and similar rights. diff --git a/testdata/package/deployment_modes/0.0.1/changelog.yml b/testdata/package/deployment_modes/0.0.1/changelog.yml new file mode 100644 index 000000000..bb0320a52 --- /dev/null +++ b/testdata/package/deployment_modes/0.0.1/changelog.yml @@ -0,0 +1,6 @@ +# newer versions go on top +- version: "0.0.1" + changes: + - description: Initial draft of the package + type: enhancement + link: https://github.com/elastic/integrations/pull/1 # FIXME Replace with the real PR link diff --git a/testdata/package/deployment_modes/0.0.1/docs/README.md b/testdata/package/deployment_modes/0.0.1/docs/README.md new file mode 100644 index 000000000..dd3645e9f --- /dev/null +++ b/testdata/package/deployment_modes/0.0.1/docs/README.md @@ -0,0 +1,84 @@ + + + +# Deployment Modes + + + +## Data streams + + + + + + + + + + + +## Requirements + +You need Elasticsearch for storing and searching your data and Kibana for visualizing and managing it. +You can use our hosted Elasticsearch Service on Elastic Cloud, which is recommended, or self-manage the Elastic Stack on your own hardware. + + + +## Setup + + + +For step-by-step instructions on how to set up an integration, see the +[Getting started](https://www.elastic.co/guide/en/welcome-to-elastic/current/getting-started-observability.html) guide. + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/testdata/package/deployment_modes/0.0.1/img/sample-logo.svg b/testdata/package/deployment_modes/0.0.1/img/sample-logo.svg new file mode 100644 index 000000000..6268dd88f --- /dev/null +++ b/testdata/package/deployment_modes/0.0.1/img/sample-logo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/testdata/package/deployment_modes/0.0.1/img/sample-screenshot.png b/testdata/package/deployment_modes/0.0.1/img/sample-screenshot.png new file mode 100644 index 0000000000000000000000000000000000000000..d7a56a3ecc078c38636698cefba33f86291dd178 GIT binary patch literal 18849 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

}qal5$moSACwfNXLXG5|3R0AtBcN` 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 literal 0 HcmV?d00001 diff --git a/testdata/package/deployment_modes/0.0.1/manifest.yml b/testdata/package/deployment_modes/0.0.1/manifest.yml new file mode 100644 index 000000000..f7525cc17 --- /dev/null +++ b/testdata/package/deployment_modes/0.0.1/manifest.yml @@ -0,0 +1,68 @@ +format_version: 3.3.0 +name: deployment_modes +title: "Deployment Modes" +version: 0.0.1 +source: + license: "Elastic-2.0" +description: "Package containing policy templates with different deployment modes" +type: integration +categories: + - custom +conditions: + kibana: + version: "^8.15.2" + elastic: + subscription: "basic" +screenshots: + - src: /img/sample-screenshot.png + title: Sample screenshot + size: 600x600 + type: image/png +icons: + - src: /img/sample-logo.svg + title: Sample logo + size: 32x32 + type: image/svg+xml +policy_templates: + - name: agentless + title: Sample logs + description: Collect sample logs + inputs: + - type: logfile + title: Collect sample logs from instances + description: Collecting sample logs + vars: + - name: path + type: text + show_user: true + - name: tags + type: text + multi: true + show_user: false + hide_in_deployment_modes: + - agentless + deployment_modes: + default: + enabled: false + agentless: + enabled: true + organization: elastic + division: observability + team: integration + multiple: false + - name: default + title: Sample logs + description: Collect sample logs + inputs: + - type: logfile + title: Collect sample logs from instances + description: Collecting sample logs + deployment_modes: + default: + enabled: true + agentless: + enabled: false + multiple: false +owner: + github: elastic/integrations + type: elastic From 38b7f101ea376f5ecd1505249df0505e6808ccaa Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Fri, 25 Oct 2024 17:26:50 +0200 Subject: [PATCH 3/7] Add changelog entry - temporal link --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8838a8943..d47c28544 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,6 +15,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added * Add new `discovery` parameter to search and category endpoints. [#1235](https://github.com/elastic/package-registry/pull/1235) +* Expose `deployment_modes` and `hide_in_deployment_modes` fields in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) ### Deprecated From 3f100dec328d9804a81c804db5f701f0ecb4c61e Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Mon, 28 Oct 2024 16:15:27 +0100 Subject: [PATCH 4/7] Expose policy_templates_behavior field --- CHANGELOG.md | 1 + packages/package.go | 33 ++++++++++--------- packages/testdata/marshaler/packages.json | 1 + .../package/deployment_modes/0.0.1/index.json | 1 + .../search-package-experimental.json | 1 + .../generated/search-package-prerelease.json | 1 + .../search-prerelease-capabilities-none.json | 1 + ...e-capabilities-observability-security.json | 1 + .../deployment_modes/0.0.1/manifest.yml | 1 + 9 files changed, 25 insertions(+), 16 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d47c28544..913ac3b48 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 * Add new `discovery` parameter to search and category endpoints. [#1235](https://github.com/elastic/package-registry/pull/1235) * Expose `deployment_modes` and `hide_in_deployment_modes` fields in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) +* Expose `policy_templates_behavior` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) ### Deprecated diff --git a/packages/package.go b/packages/package.go index 01c3b05e7..3d117b788 100644 --- a/packages/package.go +++ b/packages/package.go @@ -61,22 +61,23 @@ type FileSystemBuilder func(*Package) (PackageFileSystem, error) // BasePackage is used for the output of the package info in the /search endpoint type BasePackage struct { - Name string `config:"name" json:"name"` - Title *string `config:"title,omitempty" json:"title,omitempty" yaml:"title,omitempty"` - Version string `config:"version" json:"version"` - Release string `config:"release,omitempty" json:"release,omitempty"` - Source *Source `config:"source,omitempty" json:"source,omitempty" yaml:"source,omitempty"` - Description string `config:"description" json:"description"` - Type string `config:"type" json:"type"` - Download string `json:"download" yaml:"download,omitempty"` - Path string `json:"path" yaml:"path,omitempty"` - Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` - BasePolicyTemplates []BasePolicyTemplate `json:"policy_templates,omitempty"` - Conditions *Conditions `config:"conditions,omitempty" json:"conditions,omitempty" yaml:"conditions,omitempty"` - Owner *Owner `config:"owner,omitempty" json:"owner,omitempty" yaml:"owner,omitempty"` - Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` - SignaturePath string `config:"signature_path,omitempty" json:"signature_path,omitempty" yaml:"signature_path,omitempty"` - Discovery *Discovery `config:"discovery,omitempty" json:"discovery,omitempty" yaml:"discovery,omitempty"` + Name string `config:"name" json:"name"` + Title *string `config:"title,omitempty" json:"title,omitempty" yaml:"title,omitempty"` + Version string `config:"version" json:"version"` + Release string `config:"release,omitempty" json:"release,omitempty"` + Source *Source `config:"source,omitempty" json:"source,omitempty" yaml:"source,omitempty"` + Description string `config:"description" json:"description"` + Type string `config:"type" json:"type"` + Download string `json:"download" yaml:"download,omitempty"` + Path string `json:"path" yaml:"path,omitempty"` + Icons []Image `config:"icons,omitempty" json:"icons,omitempty" yaml:"icons,omitempty"` + PolicyTemplatesBehavior string `config:"policy_templates_behavior,omitempty" json:"policy_templates_behavior,omitempty" yaml:"policy_templates_behavior,omitempty"` + BasePolicyTemplates []BasePolicyTemplate `json:"policy_templates,omitempty"` + Conditions *Conditions `config:"conditions,omitempty" json:"conditions,omitempty" yaml:"conditions,omitempty"` + Owner *Owner `config:"owner,omitempty" json:"owner,omitempty" yaml:"owner,omitempty"` + Categories []string `config:"categories,omitempty" json:"categories,omitempty" yaml:"categories,omitempty"` + SignaturePath string `config:"signature_path,omitempty" json:"signature_path,omitempty" yaml:"signature_path,omitempty"` + Discovery *Discovery `config:"discovery,omitempty" json:"discovery,omitempty" yaml:"discovery,omitempty"` } // BasePolicyTemplate is used for the package policy templates in the /search endpoint diff --git a/packages/testdata/marshaler/packages.json b/packages/testdata/marshaler/packages.json index 53ccb491a..2cb059b92 100644 --- a/packages/testdata/marshaler/packages.json +++ b/packages/testdata/marshaler/packages.json @@ -526,6 +526,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "conditions": { "kibana": { "version": "^8.15.2" diff --git a/testdata/generated/package/deployment_modes/0.0.1/index.json b/testdata/generated/package/deployment_modes/0.0.1/index.json index 1cb21f19e..d95dabba2 100644 --- a/testdata/generated/package/deployment_modes/0.0.1/index.json +++ b/testdata/generated/package/deployment_modes/0.0.1/index.json @@ -19,6 +19,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "conditions": { "kibana": { "version": "^8.15.2" diff --git a/testdata/generated/search-package-experimental.json b/testdata/generated/search-package-experimental.json index 00b9b1b38..9f38a6a2e 100644 --- a/testdata/generated/search-package-experimental.json +++ b/testdata/generated/search-package-experimental.json @@ -163,6 +163,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "policy_templates": [ { "name": "agentless", diff --git a/testdata/generated/search-package-prerelease.json b/testdata/generated/search-package-prerelease.json index ac4adb1b7..fb71e8dff 100644 --- a/testdata/generated/search-package-prerelease.json +++ b/testdata/generated/search-package-prerelease.json @@ -163,6 +163,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "policy_templates": [ { "name": "agentless", diff --git a/testdata/generated/search-prerelease-capabilities-none.json b/testdata/generated/search-prerelease-capabilities-none.json index 46b383cc0..3f246c40a 100644 --- a/testdata/generated/search-prerelease-capabilities-none.json +++ b/testdata/generated/search-prerelease-capabilities-none.json @@ -163,6 +163,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "policy_templates": [ { "name": "agentless", diff --git a/testdata/generated/search-prerelease-capabilities-observability-security.json b/testdata/generated/search-prerelease-capabilities-observability-security.json index fa41ee239..40c226616 100644 --- a/testdata/generated/search-prerelease-capabilities-observability-security.json +++ b/testdata/generated/search-prerelease-capabilities-observability-security.json @@ -163,6 +163,7 @@ "type": "image/svg+xml" } ], + "policy_templates_behavior": "combined_policy", "policy_templates": [ { "name": "agentless", diff --git a/testdata/package/deployment_modes/0.0.1/manifest.yml b/testdata/package/deployment_modes/0.0.1/manifest.yml index f7525cc17..8face9ed2 100644 --- a/testdata/package/deployment_modes/0.0.1/manifest.yml +++ b/testdata/package/deployment_modes/0.0.1/manifest.yml @@ -23,6 +23,7 @@ icons: title: Sample logo size: 32x32 type: image/svg+xml +policy_templates_behavior: combined_policy policy_templates: - name: agentless title: Sample logs From 50113709af7d4d6a24d1ac98285e00d09f83b82c Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Mon, 28 Oct 2024 16:27:34 +0100 Subject: [PATCH 5/7] Revert expose hide_in_deployment_modes field --- CHANGELOG.md | 2 +- packages/datastream.go | 17 ++++++++--------- packages/testdata/marshaler/packages.json | 5 +---- .../package/deployment_modes/0.0.1/index.json | 5 +---- 4 files changed, 11 insertions(+), 18 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 913ac3b48..becb56aa3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,7 +15,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added * Add new `discovery` parameter to search and category endpoints. [#1235](https://github.com/elastic/package-registry/pull/1235) -* Expose `deployment_modes` and `hide_in_deployment_modes` fields in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) +* Expose `deployment_modes` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) * Expose `policy_templates_behavior` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) ### Deprecated diff --git a/packages/datastream.go b/packages/datastream.go index f21ef0274..85dc95105 100644 --- a/packages/datastream.go +++ b/packages/datastream.go @@ -84,15 +84,14 @@ type Stream struct { } type Variable struct { - Name string `config:"name" json:"name" yaml:"name"` - Type string `config:"type" json:"type" yaml:"type"` - Title string `config:"title" json:"title,omitempty" yaml:"title,omitempty"` - Description string `config:"description" json:"description,omitempty" yaml:"description,omitempty"` - Multi bool `config:"multi" json:"multi" yaml:"multi"` - Required bool `config:"required" json:"required" yaml:"required"` - ShowUser bool `config:"show_user" json:"show_user" yaml:"show_user"` - Default interface{} `config:"default" json:"default,omitempty" yaml:"default,omitempty"` - HideInDeploymentModes []string `config:"hide_in_deployment_modes,omitempty" json:"hide_in_deployment_modes,omitempty" yaml:"hide_in_deployment_modes,omitempty"` + Name string `config:"name" json:"name" yaml:"name"` + Type string `config:"type" json:"type" yaml:"type"` + Title string `config:"title" json:"title,omitempty" yaml:"title,omitempty"` + Description string `config:"description" json:"description,omitempty" yaml:"description,omitempty"` + Multi bool `config:"multi" json:"multi" yaml:"multi"` + Required bool `config:"required" json:"required" yaml:"required"` + ShowUser bool `config:"show_user" json:"show_user" yaml:"show_user"` + Default interface{} `config:"default" json:"default,omitempty" yaml:"default,omitempty"` } type DataStreamAgent struct { diff --git a/packages/testdata/marshaler/packages.json b/packages/testdata/marshaler/packages.json index 2cb059b92..44664a779 100644 --- a/packages/testdata/marshaler/packages.json +++ b/packages/testdata/marshaler/packages.json @@ -583,10 +583,7 @@ "type": "text", "multi": true, "required": false, - "show_user": false, - "hide_in_deployment_modes": [ - "agentless" - ] + "show_user": false } ], "title": "Collect sample logs from instances", diff --git a/testdata/generated/package/deployment_modes/0.0.1/index.json b/testdata/generated/package/deployment_modes/0.0.1/index.json index d95dabba2..694632d01 100644 --- a/testdata/generated/package/deployment_modes/0.0.1/index.json +++ b/testdata/generated/package/deployment_modes/0.0.1/index.json @@ -76,10 +76,7 @@ "type": "text", "multi": true, "required": false, - "show_user": false, - "hide_in_deployment_modes": [ - "agentless" - ] + "show_user": false } ], "title": "Collect sample logs from instances", From 62316bb4d513d80b5b792915a973ee07df2c165a Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Mon, 28 Oct 2024 16:36:36 +0100 Subject: [PATCH 6/7] Rewrite changelog entry --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index becb56aa3..8f209be0f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,7 +15,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added * Add new `discovery` parameter to search and category endpoints. [#1235](https://github.com/elastic/package-registry/pull/1235) -* Expose `deployment_modes` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) +* Expose `policy_templates.*.deployment_modes` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) * Expose `policy_templates_behavior` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) ### Deprecated From 12b606dd7173baeac2af46db3f5049049c5fb834 Mon Sep 17 00:00:00 2001 From: Mario Rodriguez Molins Date: Mon, 28 Oct 2024 18:09:16 +0100 Subject: [PATCH 7/7] Update changelog link --- CHANGELOG.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8f209be0f..add5d13ae 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,8 +15,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added * Add new `discovery` parameter to search and category endpoints. [#1235](https://github.com/elastic/package-registry/pull/1235) -* Expose `policy_templates.*.deployment_modes` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) -* Expose `policy_templates_behavior` field in both search and package endpoints. [#9999](https://github.com/elastic/package-registry/pull/9999) +* Expose `policy_templates.*.deployment_modes` field in both search and package endpoints. [#1244](https://github.com/elastic/package-registry/pull/1244) +* Expose `policy_templates_behavior` field in both search and package endpoints. [#1244](https://github.com/elastic/package-registry/pull/1244) ### Deprecated