1// Copyright 2023 Google LLC
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7//     http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15syntax = "proto3";
16
17package google.cloud.securitycenter.v1;
18
19import "google/api/resource.proto";
20
21option csharp_namespace = "Google.Cloud.SecurityCenter.V1";
22option go_package = "cloud.google.com/go/securitycenter/apiv1/securitycenterpb;securitycenterpb";
23option java_multiple_files = true;
24option java_package = "com.google.cloud.securitycenter.v1";
25option php_namespace = "Google\\Cloud\\SecurityCenter\\V1";
26option ruby_package = "Google::Cloud::SecurityCenter::V1";
27
28// Security Command Center finding source. A finding source
29// is an entity or a mechanism that can produce a finding. A source is like a
30// container of findings that come from the same scanner, logger, monitor, and
31// other tools.
32message Source {
33  option (google.api.resource) = {
34    type: "securitycenter.googleapis.com/Source"
35    pattern: "organizations/{organization}/sources/{source}"
36    pattern: "folders/{folder}/sources/{source}"
37    pattern: "projects/{project}/sources/{source}"
38  };
39
40  // The relative resource name of this source. See:
41  // https://cloud.google.com/apis/design/resource_names#relative_resource_name
42  // Example:
43  // "organizations/{organization_id}/sources/{source_id}"
44  string name = 1;
45
46  // The source's display name.
47  // A source's display name must be unique amongst its siblings, for example,
48  // two sources with the same parent can't share the same display name.
49  // The display name must have a length between 1 and 64 characters
50  // (inclusive).
51  string display_name = 2;
52
53  // The description of the source (max of 1024 characters).
54  // Example:
55  // "Web Security Scanner is a web security scanner for common
56  // vulnerabilities in App Engine applications. It can automatically
57  // scan and detect four common vulnerabilities, including cross-site-scripting
58  // (XSS), Flash injection, mixed content (HTTP in HTTPS), and
59  // outdated or insecure libraries."
60  string description = 3;
61
62  // The canonical name of the finding. It's either
63  // "organizations/{organization_id}/sources/{source_id}",
64  // "folders/{folder_id}/sources/{source_id}" or
65  // "projects/{project_number}/sources/{source_id}",
66  // depending on the closest CRM ancestor of the resource associated with the
67  // finding.
68  string canonical_name = 14;
69}
70