diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md
index 3eaf20df4c..6916d37bd5 100644
--- a/.github/PULL_REQUEST_TEMPLATE.md
+++ b/.github/PULL_REQUEST_TEMPLATE.md
@@ -1,4 +1,6 @@
-**What this PR does / why we need it**:
+**What this PR does**:
+
+**Why we need it**:
 
 **Which issue(s) this PR fixes**:
 
diff --git a/docs/content/en/docs-dev/user-guide/managing-piped/adding-a-cloud-provider.md b/docs/content/en/docs-dev/user-guide/managing-piped/adding-a-cloud-provider.md
deleted file mode 100644
index e05aad45af..0000000000
--- a/docs/content/en/docs-dev/user-guide/managing-piped/adding-a-cloud-provider.md
+++ /dev/null
@@ -1,134 +0,0 @@
----
-title: "Adding a cloud provider"
-linkTitle: "Adding cloud provider"
-weight: 3
-description: >
-  This page describes how to add a cloud provider to enable its applications.
----
-
-> NOTE: Starting from version v0.35.0, the CloudProvider concept is being replaced by PlatformProvider. It's a name change due to the PipeCD vision improvement. __The CloudProvider configuration is marked as deprecated, please migrate your piped agent configuration to use PlatformProvider__.
-
-PipeCD supports multiple clouds and multiple application kinds.
-Cloud provider defines which cloud and where the application should be deployed to.
-So while registering a new application, the name of a configured cloud provider is required.
-
-Currently, PipeCD is supporting these five kinds of cloud providers: `KUBERNETES`, `ECS`, `TERRAFORM`, `CLOUDRUN`, `LAMBDA`.
-A new cloud provider can be enabled by adding a [CloudProvider](../configuration-reference/#cloudprovider) struct to the piped configuration file.
-A piped can have one or multiple cloud provider instances from the same or different cloud provider kind.
-
-The next sections show the specific configuration for each kind of cloud provider.
-
-### Configuring Kubernetes cloud provider
-
-By default, piped deploys Kubernetes application to the cluster where the piped is running in. An external cluster can be connected by specifying the `masterURL` and `kubeConfigPath` in the [configuration](../configuration-reference/#cloudproviderkubernetesconfig).
-
-And, the default resources (defined at [here](https://github.com/pipe-cd/pipecd/blob/master/pkg/app/piped/platformprovider/kubernetes/resourcekey.go)) from all namespaces of the Kubernetes cluster will be watched for rendering the application state in realtime and detecting the configuration drift. In case you want to restrict piped to watch only a single namespace, let specify the namespace in the [KubernetesAppStateInformer](../configuration-reference/#kubernetesappstateinformer) field. You can also add other resources or exclude resources to/from the watching targets by that field.
-
-Below configuration snippet just specifies a name and type of cloud provider. It means the cloud provider `kubernetes-dev` will connect to the Kubernetes cluster where the piped is running in, and this cloud provider watches all of the predefined resources from all namespaces inside that cluster.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: kubernetes-dev
-      type: KUBERNETES
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderkubernetesconfig) for the full configuration.
-
-### Configuring Terraform cloud provider
-
-A terraform cloud provider contains a list of shared terraform variables that will be applied while running the deployment of its applications.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: terraform-dev
-      type: TERRAFORM
-      config:
-        vars:
-          - "project=pipecd"
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderterraformconfig) for the full configuration.
-
-### Configuring Cloud Run cloud provider
-
-Adding a Cloud Run provider requires the name of the Google Cloud project and the region name where Cloud Run service is running. A service account file for accessing to Cloud Run is also required if the machine running the piped does not have enough permissions to access.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: cloudrun-dev
-      type: CLOUDRUN
-      config:
-        project: {GCP_PROJECT}
-        region: {CLOUDRUN_REGION}
-        credentialsFile: {PATH_TO_THE_SERVICE_ACCOUNT_FILE}
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudprovidercloudrunconfig) for the full configuration.
-
-### Configuring Lambda cloud provider
-
-Adding a Lambda provider requires the region name where Lambda service is running.
-
-```yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: lambda-dev
-      type: LAMBDA
-      config:
-        region: {LAMBDA_REGION}
-        profile: default
-        credentialsFile: {PATH_TO_THE_CREDENTIAL_FILE}
-```
-
-You will generally need your AWS credentials to authenticate with Lambda. Piped provides multiple methods of loading these credentials.
-It attempts to retrieve credentials in the following order:
-1. From the environment variables. Available environment variables are `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY` and `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`.
-2. From the given credentials file. (the `credentialsFile field in above sample`)
-3. From the pod running in EKS cluster via STS (SecurityTokenService).
-4. From the EC2 Instance Role.
-
-Therefore, you don't have to set credentialsFile if you use the environment variables or the EC2 Instance Role. Keep in mind the IAM role/user that you use with your Piped must possess the IAM policy permission for at least `Lambda.Function` and `Lambda.Alias` resources controll (list/read/write).
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderlambdaconfig) for the full configuration.
-
-### Configuring ECS cloud provider
-
-Adding a ECS provider requires the region name where ECS cluster is running.
-
-```yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: ecs-dev
-      type: ECS
-      config:
-        region: {ECS_CLUSTER_REGION}
-        profile: default
-        credentialsFile: {PATH_TO_THE_CREDENTIAL_FILE}
-```
-
-Just same as Lambda cloud provider, there are several ways to authorize Piped agent to enable it performs deployment jobs.
-It attempts to retrieve credentials in the following order:
-1. From the environment variables. Available environment variables are `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY` and `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`.
-2. From the given credentials file. (the `credentialsFile field in above sample`)
-3. From the pod running in EKS cluster via STS (SecurityTokenService).
-4. From the EC2 Instance Role.
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderecsconfig) for the full configuration.
diff --git a/docs/content/en/docs-dev/user-guide/managing-piped/configuration-reference.md b/docs/content/en/docs-dev/user-guide/managing-piped/configuration-reference.md
index 534a310007..207807ced3 100644
--- a/docs/content/en/docs-dev/user-guide/managing-piped/configuration-reference.md
+++ b/docs/content/en/docs-dev/user-guide/managing-piped/configuration-reference.md
@@ -30,7 +30,6 @@ spec:
 | repositories | [][Repository](#gitrepository) | List of Git repositories this piped will handle. | No |
 | chartRepositories | [][ChartRepository](#chartrepository) | List of Helm chart repositories that should be added while starting up. | No |
 | chartRegistries | [][ChartRegistry](#chartregistry) | List of helm chart registries that should be logged in while starting up. | No |
-| cloudProviders | [][CloudProvider](#cloudprovider) | List of cloud providers can be used by this piped. This field is deprecated, use `platformProviders` instead. | No |
 | platformProviders | [][PlatformProvider](#platformprovider) | List of platform providers can be used by this piped. | No |
 | analysisProviders | [][AnalysisProvider](#analysisprovider) | List of analysis providers can be used by this piped. | No |
 | eventWatcher | [EventWatcher](#eventwatcher) | Optional Event watcher settings. | No |
@@ -81,10 +80,6 @@ spec:
 | username | string | Username used for the registry authentication. | No |
 | password | string | Password used for the registry authentication. | No |
 
-## CloudProvider
-
-This field is deprecated, please use [PlatformProvider](#platformprovider) instead.
-
 ## PlatformProvider
 
 | Field | Type | Description | Required |
diff --git a/docs/content/en/docs-v0.49.x/user-guide/managing-piped/adding-a-cloud-provider.md b/docs/content/en/docs-v0.49.x/user-guide/managing-piped/adding-a-cloud-provider.md
deleted file mode 100644
index e05aad45af..0000000000
--- a/docs/content/en/docs-v0.49.x/user-guide/managing-piped/adding-a-cloud-provider.md
+++ /dev/null
@@ -1,134 +0,0 @@
----
-title: "Adding a cloud provider"
-linkTitle: "Adding cloud provider"
-weight: 3
-description: >
-  This page describes how to add a cloud provider to enable its applications.
----
-
-> NOTE: Starting from version v0.35.0, the CloudProvider concept is being replaced by PlatformProvider. It's a name change due to the PipeCD vision improvement. __The CloudProvider configuration is marked as deprecated, please migrate your piped agent configuration to use PlatformProvider__.
-
-PipeCD supports multiple clouds and multiple application kinds.
-Cloud provider defines which cloud and where the application should be deployed to.
-So while registering a new application, the name of a configured cloud provider is required.
-
-Currently, PipeCD is supporting these five kinds of cloud providers: `KUBERNETES`, `ECS`, `TERRAFORM`, `CLOUDRUN`, `LAMBDA`.
-A new cloud provider can be enabled by adding a [CloudProvider](../configuration-reference/#cloudprovider) struct to the piped configuration file.
-A piped can have one or multiple cloud provider instances from the same or different cloud provider kind.
-
-The next sections show the specific configuration for each kind of cloud provider.
-
-### Configuring Kubernetes cloud provider
-
-By default, piped deploys Kubernetes application to the cluster where the piped is running in. An external cluster can be connected by specifying the `masterURL` and `kubeConfigPath` in the [configuration](../configuration-reference/#cloudproviderkubernetesconfig).
-
-And, the default resources (defined at [here](https://github.com/pipe-cd/pipecd/blob/master/pkg/app/piped/platformprovider/kubernetes/resourcekey.go)) from all namespaces of the Kubernetes cluster will be watched for rendering the application state in realtime and detecting the configuration drift. In case you want to restrict piped to watch only a single namespace, let specify the namespace in the [KubernetesAppStateInformer](../configuration-reference/#kubernetesappstateinformer) field. You can also add other resources or exclude resources to/from the watching targets by that field.
-
-Below configuration snippet just specifies a name and type of cloud provider. It means the cloud provider `kubernetes-dev` will connect to the Kubernetes cluster where the piped is running in, and this cloud provider watches all of the predefined resources from all namespaces inside that cluster.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: kubernetes-dev
-      type: KUBERNETES
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderkubernetesconfig) for the full configuration.
-
-### Configuring Terraform cloud provider
-
-A terraform cloud provider contains a list of shared terraform variables that will be applied while running the deployment of its applications.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: terraform-dev
-      type: TERRAFORM
-      config:
-        vars:
-          - "project=pipecd"
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderterraformconfig) for the full configuration.
-
-### Configuring Cloud Run cloud provider
-
-Adding a Cloud Run provider requires the name of the Google Cloud project and the region name where Cloud Run service is running. A service account file for accessing to Cloud Run is also required if the machine running the piped does not have enough permissions to access.
-
-``` yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: cloudrun-dev
-      type: CLOUDRUN
-      config:
-        project: {GCP_PROJECT}
-        region: {CLOUDRUN_REGION}
-        credentialsFile: {PATH_TO_THE_SERVICE_ACCOUNT_FILE}
-```
-
-See [ConfigurationReference](../configuration-reference/#cloudprovidercloudrunconfig) for the full configuration.
-
-### Configuring Lambda cloud provider
-
-Adding a Lambda provider requires the region name where Lambda service is running.
-
-```yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: lambda-dev
-      type: LAMBDA
-      config:
-        region: {LAMBDA_REGION}
-        profile: default
-        credentialsFile: {PATH_TO_THE_CREDENTIAL_FILE}
-```
-
-You will generally need your AWS credentials to authenticate with Lambda. Piped provides multiple methods of loading these credentials.
-It attempts to retrieve credentials in the following order:
-1. From the environment variables. Available environment variables are `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY` and `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`.
-2. From the given credentials file. (the `credentialsFile field in above sample`)
-3. From the pod running in EKS cluster via STS (SecurityTokenService).
-4. From the EC2 Instance Role.
-
-Therefore, you don't have to set credentialsFile if you use the environment variables or the EC2 Instance Role. Keep in mind the IAM role/user that you use with your Piped must possess the IAM policy permission for at least `Lambda.Function` and `Lambda.Alias` resources controll (list/read/write).
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderlambdaconfig) for the full configuration.
-
-### Configuring ECS cloud provider
-
-Adding a ECS provider requires the region name where ECS cluster is running.
-
-```yaml
-apiVersion: pipecd.dev/v1beta1
-kind: Piped
-spec:
-  ...
-  cloudProviders:
-    - name: ecs-dev
-      type: ECS
-      config:
-        region: {ECS_CLUSTER_REGION}
-        profile: default
-        credentialsFile: {PATH_TO_THE_CREDENTIAL_FILE}
-```
-
-Just same as Lambda cloud provider, there are several ways to authorize Piped agent to enable it performs deployment jobs.
-It attempts to retrieve credentials in the following order:
-1. From the environment variables. Available environment variables are `AWS_ACCESS_KEY_ID` or `AWS_ACCESS_KEY` and `AWS_SECRET_ACCESS_KEY` or `AWS_SECRET_KEY`.
-2. From the given credentials file. (the `credentialsFile field in above sample`)
-3. From the pod running in EKS cluster via STS (SecurityTokenService).
-4. From the EC2 Instance Role.
-
-See [ConfigurationReference](../configuration-reference/#cloudproviderecsconfig) for the full configuration.
diff --git a/docs/content/en/docs-v0.49.x/user-guide/managing-piped/configuration-reference.md b/docs/content/en/docs-v0.49.x/user-guide/managing-piped/configuration-reference.md
index 534a310007..207807ced3 100644
--- a/docs/content/en/docs-v0.49.x/user-guide/managing-piped/configuration-reference.md
+++ b/docs/content/en/docs-v0.49.x/user-guide/managing-piped/configuration-reference.md
@@ -30,7 +30,6 @@ spec:
 | repositories | [][Repository](#gitrepository) | List of Git repositories this piped will handle. | No |
 | chartRepositories | [][ChartRepository](#chartrepository) | List of Helm chart repositories that should be added while starting up. | No |
 | chartRegistries | [][ChartRegistry](#chartregistry) | List of helm chart registries that should be logged in while starting up. | No |
-| cloudProviders | [][CloudProvider](#cloudprovider) | List of cloud providers can be used by this piped. This field is deprecated, use `platformProviders` instead. | No |
 | platformProviders | [][PlatformProvider](#platformprovider) | List of platform providers can be used by this piped. | No |
 | analysisProviders | [][AnalysisProvider](#analysisprovider) | List of analysis providers can be used by this piped. | No |
 | eventWatcher | [EventWatcher](#eventwatcher) | Optional Event watcher settings. | No |
@@ -81,10 +80,6 @@ spec:
 | username | string | Username used for the registry authentication. | No |
 | password | string | Password used for the registry authentication. | No |
 
-## CloudProvider
-
-This field is deprecated, please use [PlatformProvider](#platformprovider) instead.
-
 ## PlatformProvider
 
 | Field | Type | Description | Required |