2018-04-05 21:02:13 +00:00
|
|
|
// Copyright 2018 clair authors
|
2017-06-05 14:37:29 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
syntax = "proto3";
|
2018-04-05 21:02:13 +00:00
|
|
|
|
2017-07-12 21:04:05 +00:00
|
|
|
import "google/protobuf/timestamp.proto";
|
2017-06-05 14:37:29 +00:00
|
|
|
|
2018-04-22 19:11:41 +00:00
|
|
|
import "google/api/annotations.proto";
|
|
|
|
|
|
|
|
package coreos.clair;
|
|
|
|
|
|
|
|
option go_package = "clairpb";
|
|
|
|
option java_package = "com.coreos.clair.pb";
|
|
|
|
|
2019-02-21 20:21:09 +00:00
|
|
|
service AncestryService {
|
|
|
|
// The RPC used to read the results of scanning for a particular ancestry.
|
|
|
|
rpc GetAncestry(GetAncestryRequest) returns (GetAncestryResponse) {
|
|
|
|
option (google.api.http) = { get: "/ancestry/{ancestry_name}" };
|
|
|
|
}
|
|
|
|
// The RPC used to create a new scan of an ancestry.
|
|
|
|
rpc PostAncestry(PostAncestryRequest) returns (PostAncestryResponse) {
|
|
|
|
option (google.api.http) = {
|
|
|
|
post: "/ancestry"
|
|
|
|
body: "*"
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
service StatusService {
|
|
|
|
// The RPC used to show the internal state of current Clair instance.
|
|
|
|
rpc GetStatus(GetStatusRequest) returns (GetStatusResponse) {
|
|
|
|
option (google.api.http) = { get: "/status" };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
service NotificationService {
|
|
|
|
// The RPC used to get a particularly Notification.
|
|
|
|
rpc GetNotification(GetNotificationRequest) returns (GetNotificationResponse) {
|
|
|
|
option (google.api.http) = { get: "/notifications/{name}" };
|
|
|
|
}
|
|
|
|
// The RPC used to mark a Notification as read after it has been processed.
|
|
|
|
rpc MarkNotificationAsRead(MarkNotificationAsReadRequest) returns (MarkNotificationAsReadResponse) {
|
|
|
|
option (google.api.http) = { delete: "/notifications/{name}" };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-05 14:37:29 +00:00
|
|
|
message Vulnerability {
|
2018-04-05 21:02:13 +00:00
|
|
|
// The name of the vulnerability.
|
|
|
|
string name = 1;
|
|
|
|
// The name of the namespace in which the vulnerability was detected.
|
|
|
|
string namespace_name = 2;
|
|
|
|
// A description of the vulnerability according to the source for the namespace.
|
|
|
|
string description = 3;
|
|
|
|
// A link to the vulnerability according to the source for the namespace.
|
|
|
|
string link = 4;
|
|
|
|
// How dangerous the vulnerability is.
|
|
|
|
string severity = 5;
|
|
|
|
// Namespace agnostic metadata about the vulnerability.
|
|
|
|
string metadata = 6;
|
|
|
|
// The feature that fixes this vulnerability.
|
|
|
|
// This field only exists when a vulnerability is a part of a Feature.
|
|
|
|
string fixed_by = 7;
|
|
|
|
// The Features that are affected by the vulnerability.
|
|
|
|
// This field only exists when a vulnerability is a part of a Notification.
|
|
|
|
repeated Feature affected_versions = 8;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-09-12 20:41:45 +00:00
|
|
|
message Detector {
|
2018-10-08 18:12:00 +00:00
|
|
|
enum DType {
|
|
|
|
DETECTOR_D_TYPE_INVALID = 0;
|
|
|
|
DETECTOR_D_TYPE_NAMESPACE = 1;
|
|
|
|
DETECTOR_D_TYPE_FEATURE = 2;
|
2018-09-12 20:41:45 +00:00
|
|
|
}
|
|
|
|
// The name of the detector.
|
|
|
|
string name = 1;
|
|
|
|
// The version of the detector.
|
|
|
|
string version = 2;
|
|
|
|
// The type of the detector.
|
2018-10-08 18:12:00 +00:00
|
|
|
DType dtype = 3;
|
2018-09-12 20:41:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message Namespace {
|
|
|
|
// The name of the namespace.
|
|
|
|
string name = 1;
|
|
|
|
// The detector used to detect the namespace. This only exists when present in
|
|
|
|
// an Ancestry Feature.
|
|
|
|
Detector detector = 2;
|
|
|
|
}
|
|
|
|
|
2018-04-05 21:02:13 +00:00
|
|
|
message Feature {
|
|
|
|
// The name of the feature.
|
|
|
|
string name = 1;
|
2018-09-12 20:41:45 +00:00
|
|
|
// The namespace in which the feature is detected.
|
|
|
|
Namespace namespace = 2;
|
2018-04-05 21:02:13 +00:00
|
|
|
// The specific version of this feature.
|
|
|
|
string version = 3;
|
|
|
|
// The format used to parse version numbers for the feature.
|
|
|
|
string version_format = 4;
|
2018-09-12 20:41:45 +00:00
|
|
|
// The detector used to detect this feature. This only exists when present in
|
|
|
|
// an Ancestry.
|
|
|
|
Detector detector = 5;
|
2018-04-05 21:02:13 +00:00
|
|
|
// The list of vulnerabilities that affect the feature.
|
2018-09-12 20:41:45 +00:00
|
|
|
repeated Vulnerability vulnerabilities = 6;
|
2019-02-19 22:03:44 +00:00
|
|
|
// The feature type indicates if the feature represents a source package or
|
|
|
|
// binary package.
|
|
|
|
string feature_type = 7;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-04-22 19:11:41 +00:00
|
|
|
message Layer {
|
2018-04-05 21:02:13 +00:00
|
|
|
// The sha256 tarsum for the layer.
|
|
|
|
string hash = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message ClairStatus {
|
2018-09-12 20:41:45 +00:00
|
|
|
// The implemented detectors in this Clair instance
|
|
|
|
repeated Detector detectors = 1;
|
2018-04-05 21:02:13 +00:00
|
|
|
// The time at which the updater last ran.
|
2018-09-12 20:41:45 +00:00
|
|
|
google.protobuf.Timestamp last_update_time = 2;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-04-05 21:02:13 +00:00
|
|
|
message GetAncestryRequest {
|
|
|
|
// The name of the desired ancestry.
|
|
|
|
string ancestry_name = 1;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-04-05 21:02:13 +00:00
|
|
|
message GetAncestryResponse {
|
2018-09-05 15:32:14 +00:00
|
|
|
message AncestryLayer {
|
|
|
|
// The layer's information.
|
|
|
|
Layer layer = 1;
|
|
|
|
// The features detected in this layer.
|
2018-09-05 15:34:49 +00:00
|
|
|
repeated Feature detected_features = 2;
|
2018-09-05 15:32:14 +00:00
|
|
|
}
|
2018-04-05 21:02:13 +00:00
|
|
|
message Ancestry {
|
|
|
|
// The name of the desired ancestry.
|
|
|
|
string name = 1;
|
2018-09-12 20:41:45 +00:00
|
|
|
// The detectors used to scan this Ancestry. It may not be the current set
|
|
|
|
// of detectors in clair status.
|
|
|
|
repeated Detector detectors = 2;
|
2018-09-05 15:32:14 +00:00
|
|
|
// The list of layers along with detected features in each.
|
2018-09-12 20:41:45 +00:00
|
|
|
repeated AncestryLayer layers = 3;
|
2018-04-05 21:02:13 +00:00
|
|
|
}
|
|
|
|
// The ancestry requested.
|
|
|
|
Ancestry ancestry = 1;
|
|
|
|
// The status of Clair at the time of the request.
|
2018-04-22 19:11:41 +00:00
|
|
|
ClairStatus status = 2;
|
2017-07-12 21:04:05 +00:00
|
|
|
}
|
2017-06-05 14:37:29 +00:00
|
|
|
|
|
|
|
message PostAncestryRequest {
|
2018-04-05 21:02:13 +00:00
|
|
|
message PostLayer {
|
|
|
|
// The hash of the layer.
|
|
|
|
string hash = 1;
|
2019-02-21 20:21:09 +00:00
|
|
|
// The location of the layer (URL or file path).
|
2018-04-05 21:02:13 +00:00
|
|
|
string path = 2;
|
2018-04-22 19:11:41 +00:00
|
|
|
// Any HTTP Headers that need to be used if requesting a layer over HTTP(S).
|
|
|
|
map<string, string> headers = 3;
|
|
|
|
}
|
2018-04-05 21:02:13 +00:00
|
|
|
// The name of the ancestry being scanned.
|
|
|
|
// If scanning OCI images, this should be the hash of the manifest.
|
|
|
|
string ancestry_name = 1;
|
|
|
|
// The format of the image being uploaded.
|
|
|
|
string format = 2;
|
2018-09-05 15:32:14 +00:00
|
|
|
// The layers to be scanned for this Ancestry, ordered in the way that i th
|
|
|
|
// layer is the parent of i + 1 th layer.
|
2018-04-05 21:02:13 +00:00
|
|
|
repeated PostLayer layers = 3;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message PostAncestryResponse {
|
2018-04-05 21:02:13 +00:00
|
|
|
// The status of Clair at the time of the request.
|
2018-04-22 19:11:41 +00:00
|
|
|
ClairStatus status = 1;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message GetNotificationRequest {
|
2018-04-05 21:02:13 +00:00
|
|
|
// The current page of previous vulnerabilities for the ancestry.
|
|
|
|
// This will be empty when it is the first page.
|
|
|
|
string old_vulnerability_page = 1;
|
|
|
|
// The current page of vulnerabilities for the ancestry.
|
|
|
|
// This will be empty when it is the first page.
|
|
|
|
string new_vulnerability_page = 2;
|
|
|
|
// The requested maximum number of results per page.
|
|
|
|
int32 limit = 3;
|
|
|
|
// The name of the notification being requested.
|
|
|
|
string name = 4;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message GetNotificationResponse {
|
2018-04-05 21:02:13 +00:00
|
|
|
message Notification {
|
|
|
|
// The name of the requested notification.
|
|
|
|
string name = 1;
|
|
|
|
// The time at which the notification was created.
|
|
|
|
string created = 2;
|
|
|
|
// The time at which the notification was last sent out.
|
|
|
|
string notified = 3;
|
|
|
|
// The time at which a notification has been deleted.
|
2018-04-22 19:11:41 +00:00
|
|
|
string deleted = 4;
|
2018-04-05 21:02:13 +00:00
|
|
|
// The previous vulnerability and a paginated view of the ancestries it affects.
|
|
|
|
PagedVulnerableAncestries old = 5;
|
|
|
|
// The newly updated vulnerability and a paginated view of the ancestries it affects.
|
|
|
|
PagedVulnerableAncestries new = 6;
|
|
|
|
}
|
|
|
|
// The notification as requested.
|
|
|
|
Notification notification = 1;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-04-05 21:02:13 +00:00
|
|
|
message PagedVulnerableAncestries {
|
|
|
|
message IndexedAncestryName {
|
|
|
|
// The index is an ever increasing number associated with the particular ancestry.
|
|
|
|
// This is useful if you're processing notifications, and need to keep track of the progress of paginating the results.
|
|
|
|
int32 index = 1;
|
|
|
|
// The name of the ancestry.
|
|
|
|
string name = 2;
|
|
|
|
}
|
|
|
|
// The identifier for the current page.
|
|
|
|
string current_page = 1;
|
|
|
|
// The token used to request the next page.
|
|
|
|
// This will be empty when there are no more pages.
|
|
|
|
string next_page = 2;
|
|
|
|
// The requested maximum number of results per page.
|
2018-04-22 19:11:41 +00:00
|
|
|
int32 limit = 3;
|
2018-04-05 21:02:13 +00:00
|
|
|
// The vulnerability that affects a given set of ancestries.
|
|
|
|
Vulnerability vulnerability = 4;
|
|
|
|
// The ancestries affected by a vulnerability.
|
|
|
|
repeated IndexedAncestryName ancestries = 5;
|
2017-06-05 14:37:29 +00:00
|
|
|
}
|
|
|
|
|
2018-04-05 21:02:13 +00:00
|
|
|
message MarkNotificationAsReadRequest {
|
|
|
|
// The name of the Notification that has been processed.
|
|
|
|
string name = 1;
|
|
|
|
}
|
2018-04-23 19:36:52 +00:00
|
|
|
|
|
|
|
message MarkNotificationAsReadResponse {}
|
2018-08-30 19:09:24 +00:00
|
|
|
|
|
|
|
message GetStatusRequest {}
|
|
|
|
|
|
|
|
message GetStatusResponse {
|
|
|
|
// The status of the current Clair instance.
|
|
|
|
ClairStatus status = 1;
|
|
|
|
}
|