From 9915628bacfda6e7fae33c9b921f7356ab82980f Mon Sep 17 00:00:00 2001 From: gruebel Date: Sat, 14 Oct 2023 19:36:00 +0200 Subject: [PATCH] add BC token deprecation notice and v3 migration guide --- README.md | 1 + .../common/bridgecrew/platform_integration.py | 11 +++- docs/1.Welcome/Migration.md | 57 +++++++++++++++++++ 3 files changed, 68 insertions(+), 1 deletion(-) create mode 100644 docs/1.Welcome/Migration.md diff --git a/README.md b/README.md index a4e2ea357b8..67460e4e8bf 100644 --- a/README.md +++ b/README.md @@ -37,6 +37,7 @@ Checkov also powers [**Bridgecrew**](https://bridgecrew.io/?utm_source=github&ut - [Getting Started](#getting-started) - [Disclaimer](#disclaimer) - [Support](#support) +- [Migration - v2 to v3](docs/1.Welcome/Migration.md) ## Features diff --git a/checkov/common/bridgecrew/platform_integration.py b/checkov/common/bridgecrew/platform_integration.py index 6533df4dd55..9fd51f11bf6 100644 --- a/checkov/common/bridgecrew/platform_integration.py +++ b/checkov/common/bridgecrew/platform_integration.py @@ -170,7 +170,16 @@ def is_token_valid(token: str) -> bool: parts = token.split('::') parts_len = len(parts) if parts_len == 1: - return BcPlatformIntegration.is_bc_token(token) + valid = BcPlatformIntegration.is_bc_token(token) + if valid: + print( + "We're glad you're using Checkov with Bridgecrew!\n" + "Bridgecrew has been fully integrated into Prisma Cloud with a powerful code to cloud experience.\n" + "As a part of the transition, we will be shutting down Bridgecrew standalone edition at the end of 2023 (https://www.paloaltonetworks.com/services/support/end-of-life-announcements).\n" + "Please upgrade to Prisma Cloud Enterprise Edition before the end of the year.\n" + ) + + return valid elif parts_len == 2: # A Prisma access key is a UUID, same as a BC API key if BcPlatformIntegration.is_bc_token(parts[0]) and parts[1] and BASE64_PATTERN.match(parts[1]) is not None: diff --git a/docs/1.Welcome/Migration.md b/docs/1.Welcome/Migration.md new file mode 100644 index 00000000000..782fa57baae --- /dev/null +++ b/docs/1.Welcome/Migration.md @@ -0,0 +1,57 @@ +--- +layout: default +published: true +title: Migration +nav_order: 5 +--- + +# Migration - v2 to v3 + +With v3 not only new features were added, but following behaviour changed or was completely removed. +We plan to release the new version end of October 2023. + +## Remove of "level up" + +Since Bridgecrew standalone edition will be shutting down at the [end of 2023](https://www.paloaltonetworks.com/services/support/end-of-life-announcements) we removed the "level up" flow, +which is triggered by just running `checkov` without any flag. + +## Python custom checks + +If you are still using the old syntax of running your custom code + +```python +from __future__ import annotations + +from typing import Any + +from checkov.common.models.enums import CheckResult +from checkov.terraform.checks.resource.base_resource_check import BaseResourceCheck + + +class Example(BaseResourceCheck): + ... + + def scan_resource_conf(self, conf: dict[str, list[Any]], entity_type: str) -> CheckResult: + ... +``` + +then you can easily use the simplified syntax and still access `entity_type`, if needed + +```python +from __future__ import annotations + +from typing import Any + +from checkov.common.models.enums import CheckResult +from checkov.terraform.checks.resource.base_resource_check import BaseResourceCheck + + +class Example(BaseResourceCheck): + ... + + def scan_resource_conf(self, conf: dict[str, list[Any]]) -> CheckResult: + if self.entity_type == 'aws_instance': + ... + + ... +```