2827b9342b
Feature extraction algorithm is changed to associate features with ancestry layer. Database is updated to keep the relationship.
1110 lines
43 KiB
Go
1110 lines
43 KiB
Go
// Code generated by protoc-gen-go. DO NOT EDIT.
|
|
// source: api/v3/clairpb/clair.proto
|
|
|
|
/*
|
|
Package clairpb is a generated protocol buffer package.
|
|
|
|
It is generated from these files:
|
|
api/v3/clairpb/clair.proto
|
|
|
|
It has these top-level messages:
|
|
Vulnerability
|
|
Feature
|
|
Layer
|
|
ClairStatus
|
|
GetAncestryRequest
|
|
GetAncestryResponse
|
|
PostAncestryRequest
|
|
PostAncestryResponse
|
|
GetNotificationRequest
|
|
GetNotificationResponse
|
|
PagedVulnerableAncestries
|
|
MarkNotificationAsReadRequest
|
|
MarkNotificationAsReadResponse
|
|
GetStatusRequest
|
|
GetStatusResponse
|
|
*/
|
|
package clairpb
|
|
|
|
import proto "github.com/golang/protobuf/proto"
|
|
import fmt "fmt"
|
|
import math "math"
|
|
import google_protobuf "github.com/golang/protobuf/ptypes/timestamp"
|
|
import _ "google.golang.org/genproto/googleapis/api/annotations"
|
|
|
|
import (
|
|
context "golang.org/x/net/context"
|
|
grpc "google.golang.org/grpc"
|
|
)
|
|
|
|
// Reference imports to suppress errors if they are not otherwise used.
|
|
var _ = proto.Marshal
|
|
var _ = fmt.Errorf
|
|
var _ = math.Inf
|
|
|
|
// This is a compile-time assertion to ensure that this generated file
|
|
// is compatible with the proto package it is being compiled against.
|
|
// A compilation error at this line likely means your copy of the
|
|
// proto package needs to be updated.
|
|
const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
|
|
|
|
type Vulnerability struct {
|
|
// The name of the vulnerability.
|
|
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
|
|
// The name of the namespace in which the vulnerability was detected.
|
|
NamespaceName string `protobuf:"bytes,2,opt,name=namespace_name,json=namespaceName" json:"namespace_name,omitempty"`
|
|
// A description of the vulnerability according to the source for the namespace.
|
|
Description string `protobuf:"bytes,3,opt,name=description" json:"description,omitempty"`
|
|
// A link to the vulnerability according to the source for the namespace.
|
|
Link string `protobuf:"bytes,4,opt,name=link" json:"link,omitempty"`
|
|
// How dangerous the vulnerability is.
|
|
Severity string `protobuf:"bytes,5,opt,name=severity" json:"severity,omitempty"`
|
|
// Namespace agnostic metadata about the vulnerability.
|
|
Metadata string `protobuf:"bytes,6,opt,name=metadata" json:"metadata,omitempty"`
|
|
// The feature that fixes this vulnerability.
|
|
// This field only exists when a vulnerability is a part of a Feature.
|
|
FixedBy string `protobuf:"bytes,7,opt,name=fixed_by,json=fixedBy" json:"fixed_by,omitempty"`
|
|
// The Features that are affected by the vulnerability.
|
|
// This field only exists when a vulnerability is a part of a Notification.
|
|
AffectedVersions []*Feature `protobuf:"bytes,8,rep,name=affected_versions,json=affectedVersions" json:"affected_versions,omitempty"`
|
|
}
|
|
|
|
func (m *Vulnerability) Reset() { *m = Vulnerability{} }
|
|
func (m *Vulnerability) String() string { return proto.CompactTextString(m) }
|
|
func (*Vulnerability) ProtoMessage() {}
|
|
func (*Vulnerability) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} }
|
|
|
|
func (m *Vulnerability) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetNamespaceName() string {
|
|
if m != nil {
|
|
return m.NamespaceName
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetDescription() string {
|
|
if m != nil {
|
|
return m.Description
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetLink() string {
|
|
if m != nil {
|
|
return m.Link
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetSeverity() string {
|
|
if m != nil {
|
|
return m.Severity
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetMetadata() string {
|
|
if m != nil {
|
|
return m.Metadata
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetFixedBy() string {
|
|
if m != nil {
|
|
return m.FixedBy
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Vulnerability) GetAffectedVersions() []*Feature {
|
|
if m != nil {
|
|
return m.AffectedVersions
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type Feature struct {
|
|
// The name of the feature.
|
|
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
|
|
// The name of the namespace in which the feature is detected.
|
|
NamespaceName string `protobuf:"bytes,2,opt,name=namespace_name,json=namespaceName" json:"namespace_name,omitempty"`
|
|
// The specific version of this feature.
|
|
Version string `protobuf:"bytes,3,opt,name=version" json:"version,omitempty"`
|
|
// The format used to parse version numbers for the feature.
|
|
VersionFormat string `protobuf:"bytes,4,opt,name=version_format,json=versionFormat" json:"version_format,omitempty"`
|
|
// The list of vulnerabilities that affect the feature.
|
|
Vulnerabilities []*Vulnerability `protobuf:"bytes,5,rep,name=vulnerabilities" json:"vulnerabilities,omitempty"`
|
|
}
|
|
|
|
func (m *Feature) Reset() { *m = Feature{} }
|
|
func (m *Feature) String() string { return proto.CompactTextString(m) }
|
|
func (*Feature) ProtoMessage() {}
|
|
func (*Feature) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1} }
|
|
|
|
func (m *Feature) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Feature) GetNamespaceName() string {
|
|
if m != nil {
|
|
return m.NamespaceName
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Feature) GetVersion() string {
|
|
if m != nil {
|
|
return m.Version
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Feature) GetVersionFormat() string {
|
|
if m != nil {
|
|
return m.VersionFormat
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *Feature) GetVulnerabilities() []*Vulnerability {
|
|
if m != nil {
|
|
return m.Vulnerabilities
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type Layer struct {
|
|
// The sha256 tarsum for the layer.
|
|
Hash string `protobuf:"bytes,1,opt,name=hash" json:"hash,omitempty"`
|
|
}
|
|
|
|
func (m *Layer) Reset() { *m = Layer{} }
|
|
func (m *Layer) String() string { return proto.CompactTextString(m) }
|
|
func (*Layer) ProtoMessage() {}
|
|
func (*Layer) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{2} }
|
|
|
|
func (m *Layer) GetHash() string {
|
|
if m != nil {
|
|
return m.Hash
|
|
}
|
|
return ""
|
|
}
|
|
|
|
type ClairStatus struct {
|
|
// The configured list of feature listers used to scan an ancestry.
|
|
Listers []string `protobuf:"bytes,1,rep,name=listers" json:"listers,omitempty"`
|
|
// The configured list of namespace detectors used to scan an ancestry.
|
|
Detectors []string `protobuf:"bytes,2,rep,name=detectors" json:"detectors,omitempty"`
|
|
// The time at which the updater last ran.
|
|
LastUpdateTime *google_protobuf.Timestamp `protobuf:"bytes,3,opt,name=last_update_time,json=lastUpdateTime" json:"last_update_time,omitempty"`
|
|
}
|
|
|
|
func (m *ClairStatus) Reset() { *m = ClairStatus{} }
|
|
func (m *ClairStatus) String() string { return proto.CompactTextString(m) }
|
|
func (*ClairStatus) ProtoMessage() {}
|
|
func (*ClairStatus) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{3} }
|
|
|
|
func (m *ClairStatus) GetListers() []string {
|
|
if m != nil {
|
|
return m.Listers
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *ClairStatus) GetDetectors() []string {
|
|
if m != nil {
|
|
return m.Detectors
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *ClairStatus) GetLastUpdateTime() *google_protobuf.Timestamp {
|
|
if m != nil {
|
|
return m.LastUpdateTime
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type GetAncestryRequest struct {
|
|
// The name of the desired ancestry.
|
|
AncestryName string `protobuf:"bytes,1,opt,name=ancestry_name,json=ancestryName" json:"ancestry_name,omitempty"`
|
|
// Whether to include vulnerabilities or not in the response.
|
|
WithVulnerabilities bool `protobuf:"varint,2,opt,name=with_vulnerabilities,json=withVulnerabilities" json:"with_vulnerabilities,omitempty"`
|
|
// Whether to include features or not in the response.
|
|
WithFeatures bool `protobuf:"varint,3,opt,name=with_features,json=withFeatures" json:"with_features,omitempty"`
|
|
}
|
|
|
|
func (m *GetAncestryRequest) Reset() { *m = GetAncestryRequest{} }
|
|
func (m *GetAncestryRequest) String() string { return proto.CompactTextString(m) }
|
|
func (*GetAncestryRequest) ProtoMessage() {}
|
|
func (*GetAncestryRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{4} }
|
|
|
|
func (m *GetAncestryRequest) GetAncestryName() string {
|
|
if m != nil {
|
|
return m.AncestryName
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetAncestryRequest) GetWithVulnerabilities() bool {
|
|
if m != nil {
|
|
return m.WithVulnerabilities
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (m *GetAncestryRequest) GetWithFeatures() bool {
|
|
if m != nil {
|
|
return m.WithFeatures
|
|
}
|
|
return false
|
|
}
|
|
|
|
type GetAncestryResponse struct {
|
|
// The ancestry requested.
|
|
Ancestry *GetAncestryResponse_Ancestry `protobuf:"bytes,1,opt,name=ancestry" json:"ancestry,omitempty"`
|
|
// The status of Clair at the time of the request.
|
|
Status *ClairStatus `protobuf:"bytes,2,opt,name=status" json:"status,omitempty"`
|
|
}
|
|
|
|
func (m *GetAncestryResponse) Reset() { *m = GetAncestryResponse{} }
|
|
func (m *GetAncestryResponse) String() string { return proto.CompactTextString(m) }
|
|
func (*GetAncestryResponse) ProtoMessage() {}
|
|
func (*GetAncestryResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{5} }
|
|
|
|
func (m *GetAncestryResponse) GetAncestry() *GetAncestryResponse_Ancestry {
|
|
if m != nil {
|
|
return m.Ancestry
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *GetAncestryResponse) GetStatus() *ClairStatus {
|
|
if m != nil {
|
|
return m.Status
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type GetAncestryResponse_AncestryLayer struct {
|
|
// The layer's information.
|
|
Layer *Layer `protobuf:"bytes,1,opt,name=layer" json:"layer,omitempty"`
|
|
// The features detected in this layer.
|
|
DetectedFeatures []*Feature `protobuf:"bytes,2,rep,name=detected_features,json=detectedFeatures" json:"detected_features,omitempty"`
|
|
}
|
|
|
|
func (m *GetAncestryResponse_AncestryLayer) Reset() { *m = GetAncestryResponse_AncestryLayer{} }
|
|
func (m *GetAncestryResponse_AncestryLayer) String() string { return proto.CompactTextString(m) }
|
|
func (*GetAncestryResponse_AncestryLayer) ProtoMessage() {}
|
|
func (*GetAncestryResponse_AncestryLayer) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor0, []int{5, 0}
|
|
}
|
|
|
|
func (m *GetAncestryResponse_AncestryLayer) GetLayer() *Layer {
|
|
if m != nil {
|
|
return m.Layer
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *GetAncestryResponse_AncestryLayer) GetDetectedFeatures() []*Feature {
|
|
if m != nil {
|
|
return m.DetectedFeatures
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type GetAncestryResponse_Ancestry struct {
|
|
// The name of the desired ancestry.
|
|
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
|
|
// The configured list of feature listers used to scan this ancestry.
|
|
ScannedListers []string `protobuf:"bytes,4,rep,name=scanned_listers,json=scannedListers" json:"scanned_listers,omitempty"`
|
|
// The configured list of namespace detectors used to scan an ancestry.
|
|
ScannedDetectors []string `protobuf:"bytes,5,rep,name=scanned_detectors,json=scannedDetectors" json:"scanned_detectors,omitempty"`
|
|
// The list of layers along with detected features in each.
|
|
Layers []*GetAncestryResponse_AncestryLayer `protobuf:"bytes,6,rep,name=layers" json:"layers,omitempty"`
|
|
}
|
|
|
|
func (m *GetAncestryResponse_Ancestry) Reset() { *m = GetAncestryResponse_Ancestry{} }
|
|
func (m *GetAncestryResponse_Ancestry) String() string { return proto.CompactTextString(m) }
|
|
func (*GetAncestryResponse_Ancestry) ProtoMessage() {}
|
|
func (*GetAncestryResponse_Ancestry) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{5, 1} }
|
|
|
|
func (m *GetAncestryResponse_Ancestry) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetAncestryResponse_Ancestry) GetScannedListers() []string {
|
|
if m != nil {
|
|
return m.ScannedListers
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *GetAncestryResponse_Ancestry) GetScannedDetectors() []string {
|
|
if m != nil {
|
|
return m.ScannedDetectors
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *GetAncestryResponse_Ancestry) GetLayers() []*GetAncestryResponse_AncestryLayer {
|
|
if m != nil {
|
|
return m.Layers
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type PostAncestryRequest struct {
|
|
// The name of the ancestry being scanned.
|
|
// If scanning OCI images, this should be the hash of the manifest.
|
|
AncestryName string `protobuf:"bytes,1,opt,name=ancestry_name,json=ancestryName" json:"ancestry_name,omitempty"`
|
|
// The format of the image being uploaded.
|
|
Format string `protobuf:"bytes,2,opt,name=format" json:"format,omitempty"`
|
|
// The layers to be scanned for this Ancestry, ordered in the way that i th
|
|
// layer is the parent of i + 1 th layer.
|
|
Layers []*PostAncestryRequest_PostLayer `protobuf:"bytes,3,rep,name=layers" json:"layers,omitempty"`
|
|
}
|
|
|
|
func (m *PostAncestryRequest) Reset() { *m = PostAncestryRequest{} }
|
|
func (m *PostAncestryRequest) String() string { return proto.CompactTextString(m) }
|
|
func (*PostAncestryRequest) ProtoMessage() {}
|
|
func (*PostAncestryRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{6} }
|
|
|
|
func (m *PostAncestryRequest) GetAncestryName() string {
|
|
if m != nil {
|
|
return m.AncestryName
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PostAncestryRequest) GetFormat() string {
|
|
if m != nil {
|
|
return m.Format
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PostAncestryRequest) GetLayers() []*PostAncestryRequest_PostLayer {
|
|
if m != nil {
|
|
return m.Layers
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type PostAncestryRequest_PostLayer struct {
|
|
// The hash of the layer.
|
|
Hash string `protobuf:"bytes,1,opt,name=hash" json:"hash,omitempty"`
|
|
// The location of the layer (URL or filepath).
|
|
Path string `protobuf:"bytes,2,opt,name=path" json:"path,omitempty"`
|
|
// Any HTTP Headers that need to be used if requesting a layer over HTTP(S).
|
|
Headers map[string]string `protobuf:"bytes,3,rep,name=headers" json:"headers,omitempty" protobuf_key:"bytes,1,opt,name=key" protobuf_val:"bytes,2,opt,name=value"`
|
|
}
|
|
|
|
func (m *PostAncestryRequest_PostLayer) Reset() { *m = PostAncestryRequest_PostLayer{} }
|
|
func (m *PostAncestryRequest_PostLayer) String() string { return proto.CompactTextString(m) }
|
|
func (*PostAncestryRequest_PostLayer) ProtoMessage() {}
|
|
func (*PostAncestryRequest_PostLayer) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor0, []int{6, 0}
|
|
}
|
|
|
|
func (m *PostAncestryRequest_PostLayer) GetHash() string {
|
|
if m != nil {
|
|
return m.Hash
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PostAncestryRequest_PostLayer) GetPath() string {
|
|
if m != nil {
|
|
return m.Path
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PostAncestryRequest_PostLayer) GetHeaders() map[string]string {
|
|
if m != nil {
|
|
return m.Headers
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type PostAncestryResponse struct {
|
|
// The status of Clair at the time of the request.
|
|
Status *ClairStatus `protobuf:"bytes,1,opt,name=status" json:"status,omitempty"`
|
|
}
|
|
|
|
func (m *PostAncestryResponse) Reset() { *m = PostAncestryResponse{} }
|
|
func (m *PostAncestryResponse) String() string { return proto.CompactTextString(m) }
|
|
func (*PostAncestryResponse) ProtoMessage() {}
|
|
func (*PostAncestryResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{7} }
|
|
|
|
func (m *PostAncestryResponse) GetStatus() *ClairStatus {
|
|
if m != nil {
|
|
return m.Status
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type GetNotificationRequest struct {
|
|
// The current page of previous vulnerabilities for the ancestry.
|
|
// This will be empty when it is the first page.
|
|
OldVulnerabilityPage string `protobuf:"bytes,1,opt,name=old_vulnerability_page,json=oldVulnerabilityPage" json:"old_vulnerability_page,omitempty"`
|
|
// The current page of vulnerabilities for the ancestry.
|
|
// This will be empty when it is the first page.
|
|
NewVulnerabilityPage string `protobuf:"bytes,2,opt,name=new_vulnerability_page,json=newVulnerabilityPage" json:"new_vulnerability_page,omitempty"`
|
|
// The requested maximum number of results per page.
|
|
Limit int32 `protobuf:"varint,3,opt,name=limit" json:"limit,omitempty"`
|
|
// The name of the notification being requested.
|
|
Name string `protobuf:"bytes,4,opt,name=name" json:"name,omitempty"`
|
|
}
|
|
|
|
func (m *GetNotificationRequest) Reset() { *m = GetNotificationRequest{} }
|
|
func (m *GetNotificationRequest) String() string { return proto.CompactTextString(m) }
|
|
func (*GetNotificationRequest) ProtoMessage() {}
|
|
func (*GetNotificationRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{8} }
|
|
|
|
func (m *GetNotificationRequest) GetOldVulnerabilityPage() string {
|
|
if m != nil {
|
|
return m.OldVulnerabilityPage
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationRequest) GetNewVulnerabilityPage() string {
|
|
if m != nil {
|
|
return m.NewVulnerabilityPage
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationRequest) GetLimit() int32 {
|
|
if m != nil {
|
|
return m.Limit
|
|
}
|
|
return 0
|
|
}
|
|
|
|
func (m *GetNotificationRequest) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
type GetNotificationResponse struct {
|
|
// The notification as requested.
|
|
Notification *GetNotificationResponse_Notification `protobuf:"bytes,1,opt,name=notification" json:"notification,omitempty"`
|
|
}
|
|
|
|
func (m *GetNotificationResponse) Reset() { *m = GetNotificationResponse{} }
|
|
func (m *GetNotificationResponse) String() string { return proto.CompactTextString(m) }
|
|
func (*GetNotificationResponse) ProtoMessage() {}
|
|
func (*GetNotificationResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{9} }
|
|
|
|
func (m *GetNotificationResponse) GetNotification() *GetNotificationResponse_Notification {
|
|
if m != nil {
|
|
return m.Notification
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type GetNotificationResponse_Notification struct {
|
|
// The name of the requested notification.
|
|
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
|
|
// The time at which the notification was created.
|
|
Created string `protobuf:"bytes,2,opt,name=created" json:"created,omitempty"`
|
|
// The time at which the notification was last sent out.
|
|
Notified string `protobuf:"bytes,3,opt,name=notified" json:"notified,omitempty"`
|
|
// The time at which a notification has been deleted.
|
|
Deleted string `protobuf:"bytes,4,opt,name=deleted" json:"deleted,omitempty"`
|
|
// The previous vulnerability and a paginated view of the ancestries it affects.
|
|
Old *PagedVulnerableAncestries `protobuf:"bytes,5,opt,name=old" json:"old,omitempty"`
|
|
// The newly updated vulnerability and a paginated view of the ancestries it affects.
|
|
New *PagedVulnerableAncestries `protobuf:"bytes,6,opt,name=new" json:"new,omitempty"`
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) Reset() { *m = GetNotificationResponse_Notification{} }
|
|
func (m *GetNotificationResponse_Notification) String() string { return proto.CompactTextString(m) }
|
|
func (*GetNotificationResponse_Notification) ProtoMessage() {}
|
|
func (*GetNotificationResponse_Notification) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor0, []int{9, 0}
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetCreated() string {
|
|
if m != nil {
|
|
return m.Created
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetNotified() string {
|
|
if m != nil {
|
|
return m.Notified
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetDeleted() string {
|
|
if m != nil {
|
|
return m.Deleted
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetOld() *PagedVulnerableAncestries {
|
|
if m != nil {
|
|
return m.Old
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *GetNotificationResponse_Notification) GetNew() *PagedVulnerableAncestries {
|
|
if m != nil {
|
|
return m.New
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type PagedVulnerableAncestries struct {
|
|
// The identifier for the current page.
|
|
CurrentPage string `protobuf:"bytes,1,opt,name=current_page,json=currentPage" json:"current_page,omitempty"`
|
|
// The token used to request the next page.
|
|
// This will be empty when there are no more pages.
|
|
NextPage string `protobuf:"bytes,2,opt,name=next_page,json=nextPage" json:"next_page,omitempty"`
|
|
// The requested maximum number of results per page.
|
|
Limit int32 `protobuf:"varint,3,opt,name=limit" json:"limit,omitempty"`
|
|
// The vulnerability that affects a given set of ancestries.
|
|
Vulnerability *Vulnerability `protobuf:"bytes,4,opt,name=vulnerability" json:"vulnerability,omitempty"`
|
|
// The ancestries affected by a vulnerability.
|
|
Ancestries []*PagedVulnerableAncestries_IndexedAncestryName `protobuf:"bytes,5,rep,name=ancestries" json:"ancestries,omitempty"`
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries) Reset() { *m = PagedVulnerableAncestries{} }
|
|
func (m *PagedVulnerableAncestries) String() string { return proto.CompactTextString(m) }
|
|
func (*PagedVulnerableAncestries) ProtoMessage() {}
|
|
func (*PagedVulnerableAncestries) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{10} }
|
|
|
|
func (m *PagedVulnerableAncestries) GetCurrentPage() string {
|
|
if m != nil {
|
|
return m.CurrentPage
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries) GetNextPage() string {
|
|
if m != nil {
|
|
return m.NextPage
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries) GetLimit() int32 {
|
|
if m != nil {
|
|
return m.Limit
|
|
}
|
|
return 0
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries) GetVulnerability() *Vulnerability {
|
|
if m != nil {
|
|
return m.Vulnerability
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries) GetAncestries() []*PagedVulnerableAncestries_IndexedAncestryName {
|
|
if m != nil {
|
|
return m.Ancestries
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type PagedVulnerableAncestries_IndexedAncestryName struct {
|
|
// 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.
|
|
Index int32 `protobuf:"varint,1,opt,name=index" json:"index,omitempty"`
|
|
// The name of the ancestry.
|
|
Name string `protobuf:"bytes,2,opt,name=name" json:"name,omitempty"`
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries_IndexedAncestryName) Reset() {
|
|
*m = PagedVulnerableAncestries_IndexedAncestryName{}
|
|
}
|
|
func (m *PagedVulnerableAncestries_IndexedAncestryName) String() string {
|
|
return proto.CompactTextString(m)
|
|
}
|
|
func (*PagedVulnerableAncestries_IndexedAncestryName) ProtoMessage() {}
|
|
func (*PagedVulnerableAncestries_IndexedAncestryName) Descriptor() ([]byte, []int) {
|
|
return fileDescriptor0, []int{10, 0}
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries_IndexedAncestryName) GetIndex() int32 {
|
|
if m != nil {
|
|
return m.Index
|
|
}
|
|
return 0
|
|
}
|
|
|
|
func (m *PagedVulnerableAncestries_IndexedAncestryName) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
type MarkNotificationAsReadRequest struct {
|
|
// The name of the Notification that has been processed.
|
|
Name string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"`
|
|
}
|
|
|
|
func (m *MarkNotificationAsReadRequest) Reset() { *m = MarkNotificationAsReadRequest{} }
|
|
func (m *MarkNotificationAsReadRequest) String() string { return proto.CompactTextString(m) }
|
|
func (*MarkNotificationAsReadRequest) ProtoMessage() {}
|
|
func (*MarkNotificationAsReadRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{11} }
|
|
|
|
func (m *MarkNotificationAsReadRequest) GetName() string {
|
|
if m != nil {
|
|
return m.Name
|
|
}
|
|
return ""
|
|
}
|
|
|
|
type MarkNotificationAsReadResponse struct {
|
|
}
|
|
|
|
func (m *MarkNotificationAsReadResponse) Reset() { *m = MarkNotificationAsReadResponse{} }
|
|
func (m *MarkNotificationAsReadResponse) String() string { return proto.CompactTextString(m) }
|
|
func (*MarkNotificationAsReadResponse) ProtoMessage() {}
|
|
func (*MarkNotificationAsReadResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{12} }
|
|
|
|
type GetStatusRequest struct {
|
|
}
|
|
|
|
func (m *GetStatusRequest) Reset() { *m = GetStatusRequest{} }
|
|
func (m *GetStatusRequest) String() string { return proto.CompactTextString(m) }
|
|
func (*GetStatusRequest) ProtoMessage() {}
|
|
func (*GetStatusRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{13} }
|
|
|
|
type GetStatusResponse struct {
|
|
// The status of the current Clair instance.
|
|
Status *ClairStatus `protobuf:"bytes,1,opt,name=status" json:"status,omitempty"`
|
|
}
|
|
|
|
func (m *GetStatusResponse) Reset() { *m = GetStatusResponse{} }
|
|
func (m *GetStatusResponse) String() string { return proto.CompactTextString(m) }
|
|
func (*GetStatusResponse) ProtoMessage() {}
|
|
func (*GetStatusResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{14} }
|
|
|
|
func (m *GetStatusResponse) GetStatus() *ClairStatus {
|
|
if m != nil {
|
|
return m.Status
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func init() {
|
|
proto.RegisterType((*Vulnerability)(nil), "coreos.clair.Vulnerability")
|
|
proto.RegisterType((*Feature)(nil), "coreos.clair.Feature")
|
|
proto.RegisterType((*Layer)(nil), "coreos.clair.Layer")
|
|
proto.RegisterType((*ClairStatus)(nil), "coreos.clair.ClairStatus")
|
|
proto.RegisterType((*GetAncestryRequest)(nil), "coreos.clair.GetAncestryRequest")
|
|
proto.RegisterType((*GetAncestryResponse)(nil), "coreos.clair.GetAncestryResponse")
|
|
proto.RegisterType((*GetAncestryResponse_AncestryLayer)(nil), "coreos.clair.GetAncestryResponse.AncestryLayer")
|
|
proto.RegisterType((*GetAncestryResponse_Ancestry)(nil), "coreos.clair.GetAncestryResponse.Ancestry")
|
|
proto.RegisterType((*PostAncestryRequest)(nil), "coreos.clair.PostAncestryRequest")
|
|
proto.RegisterType((*PostAncestryRequest_PostLayer)(nil), "coreos.clair.PostAncestryRequest.PostLayer")
|
|
proto.RegisterType((*PostAncestryResponse)(nil), "coreos.clair.PostAncestryResponse")
|
|
proto.RegisterType((*GetNotificationRequest)(nil), "coreos.clair.GetNotificationRequest")
|
|
proto.RegisterType((*GetNotificationResponse)(nil), "coreos.clair.GetNotificationResponse")
|
|
proto.RegisterType((*GetNotificationResponse_Notification)(nil), "coreos.clair.GetNotificationResponse.Notification")
|
|
proto.RegisterType((*PagedVulnerableAncestries)(nil), "coreos.clair.PagedVulnerableAncestries")
|
|
proto.RegisterType((*PagedVulnerableAncestries_IndexedAncestryName)(nil), "coreos.clair.PagedVulnerableAncestries.IndexedAncestryName")
|
|
proto.RegisterType((*MarkNotificationAsReadRequest)(nil), "coreos.clair.MarkNotificationAsReadRequest")
|
|
proto.RegisterType((*MarkNotificationAsReadResponse)(nil), "coreos.clair.MarkNotificationAsReadResponse")
|
|
proto.RegisterType((*GetStatusRequest)(nil), "coreos.clair.GetStatusRequest")
|
|
proto.RegisterType((*GetStatusResponse)(nil), "coreos.clair.GetStatusResponse")
|
|
}
|
|
|
|
// Reference imports to suppress errors if they are not otherwise used.
|
|
var _ context.Context
|
|
var _ grpc.ClientConn
|
|
|
|
// This is a compile-time assertion to ensure that this generated file
|
|
// is compatible with the grpc package it is being compiled against.
|
|
const _ = grpc.SupportPackageIsVersion4
|
|
|
|
// Client API for AncestryService service
|
|
|
|
type AncestryServiceClient interface {
|
|
// The RPC used to read the results of scanning for a particular ancestry.
|
|
GetAncestry(ctx context.Context, in *GetAncestryRequest, opts ...grpc.CallOption) (*GetAncestryResponse, error)
|
|
// The RPC used to create a new scan of an ancestry.
|
|
PostAncestry(ctx context.Context, in *PostAncestryRequest, opts ...grpc.CallOption) (*PostAncestryResponse, error)
|
|
}
|
|
|
|
type ancestryServiceClient struct {
|
|
cc *grpc.ClientConn
|
|
}
|
|
|
|
func NewAncestryServiceClient(cc *grpc.ClientConn) AncestryServiceClient {
|
|
return &ancestryServiceClient{cc}
|
|
}
|
|
|
|
func (c *ancestryServiceClient) GetAncestry(ctx context.Context, in *GetAncestryRequest, opts ...grpc.CallOption) (*GetAncestryResponse, error) {
|
|
out := new(GetAncestryResponse)
|
|
err := grpc.Invoke(ctx, "/coreos.clair.AncestryService/GetAncestry", in, out, c.cc, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return out, nil
|
|
}
|
|
|
|
func (c *ancestryServiceClient) PostAncestry(ctx context.Context, in *PostAncestryRequest, opts ...grpc.CallOption) (*PostAncestryResponse, error) {
|
|
out := new(PostAncestryResponse)
|
|
err := grpc.Invoke(ctx, "/coreos.clair.AncestryService/PostAncestry", in, out, c.cc, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return out, nil
|
|
}
|
|
|
|
// Server API for AncestryService service
|
|
|
|
type AncestryServiceServer interface {
|
|
// The RPC used to read the results of scanning for a particular ancestry.
|
|
GetAncestry(context.Context, *GetAncestryRequest) (*GetAncestryResponse, error)
|
|
// The RPC used to create a new scan of an ancestry.
|
|
PostAncestry(context.Context, *PostAncestryRequest) (*PostAncestryResponse, error)
|
|
}
|
|
|
|
func RegisterAncestryServiceServer(s *grpc.Server, srv AncestryServiceServer) {
|
|
s.RegisterService(&_AncestryService_serviceDesc, srv)
|
|
}
|
|
|
|
func _AncestryService_GetAncestry_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
|
in := new(GetAncestryRequest)
|
|
if err := dec(in); err != nil {
|
|
return nil, err
|
|
}
|
|
if interceptor == nil {
|
|
return srv.(AncestryServiceServer).GetAncestry(ctx, in)
|
|
}
|
|
info := &grpc.UnaryServerInfo{
|
|
Server: srv,
|
|
FullMethod: "/coreos.clair.AncestryService/GetAncestry",
|
|
}
|
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
|
return srv.(AncestryServiceServer).GetAncestry(ctx, req.(*GetAncestryRequest))
|
|
}
|
|
return interceptor(ctx, in, info, handler)
|
|
}
|
|
|
|
func _AncestryService_PostAncestry_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
|
in := new(PostAncestryRequest)
|
|
if err := dec(in); err != nil {
|
|
return nil, err
|
|
}
|
|
if interceptor == nil {
|
|
return srv.(AncestryServiceServer).PostAncestry(ctx, in)
|
|
}
|
|
info := &grpc.UnaryServerInfo{
|
|
Server: srv,
|
|
FullMethod: "/coreos.clair.AncestryService/PostAncestry",
|
|
}
|
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
|
return srv.(AncestryServiceServer).PostAncestry(ctx, req.(*PostAncestryRequest))
|
|
}
|
|
return interceptor(ctx, in, info, handler)
|
|
}
|
|
|
|
var _AncestryService_serviceDesc = grpc.ServiceDesc{
|
|
ServiceName: "coreos.clair.AncestryService",
|
|
HandlerType: (*AncestryServiceServer)(nil),
|
|
Methods: []grpc.MethodDesc{
|
|
{
|
|
MethodName: "GetAncestry",
|
|
Handler: _AncestryService_GetAncestry_Handler,
|
|
},
|
|
{
|
|
MethodName: "PostAncestry",
|
|
Handler: _AncestryService_PostAncestry_Handler,
|
|
},
|
|
},
|
|
Streams: []grpc.StreamDesc{},
|
|
Metadata: "api/v3/clairpb/clair.proto",
|
|
}
|
|
|
|
// Client API for NotificationService service
|
|
|
|
type NotificationServiceClient interface {
|
|
// The RPC used to get a particularly Notification.
|
|
GetNotification(ctx context.Context, in *GetNotificationRequest, opts ...grpc.CallOption) (*GetNotificationResponse, error)
|
|
// The RPC used to mark a Notification as read after it has been processed.
|
|
MarkNotificationAsRead(ctx context.Context, in *MarkNotificationAsReadRequest, opts ...grpc.CallOption) (*MarkNotificationAsReadResponse, error)
|
|
}
|
|
|
|
type notificationServiceClient struct {
|
|
cc *grpc.ClientConn
|
|
}
|
|
|
|
func NewNotificationServiceClient(cc *grpc.ClientConn) NotificationServiceClient {
|
|
return ¬ificationServiceClient{cc}
|
|
}
|
|
|
|
func (c *notificationServiceClient) GetNotification(ctx context.Context, in *GetNotificationRequest, opts ...grpc.CallOption) (*GetNotificationResponse, error) {
|
|
out := new(GetNotificationResponse)
|
|
err := grpc.Invoke(ctx, "/coreos.clair.NotificationService/GetNotification", in, out, c.cc, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return out, nil
|
|
}
|
|
|
|
func (c *notificationServiceClient) MarkNotificationAsRead(ctx context.Context, in *MarkNotificationAsReadRequest, opts ...grpc.CallOption) (*MarkNotificationAsReadResponse, error) {
|
|
out := new(MarkNotificationAsReadResponse)
|
|
err := grpc.Invoke(ctx, "/coreos.clair.NotificationService/MarkNotificationAsRead", in, out, c.cc, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return out, nil
|
|
}
|
|
|
|
// Server API for NotificationService service
|
|
|
|
type NotificationServiceServer interface {
|
|
// The RPC used to get a particularly Notification.
|
|
GetNotification(context.Context, *GetNotificationRequest) (*GetNotificationResponse, error)
|
|
// The RPC used to mark a Notification as read after it has been processed.
|
|
MarkNotificationAsRead(context.Context, *MarkNotificationAsReadRequest) (*MarkNotificationAsReadResponse, error)
|
|
}
|
|
|
|
func RegisterNotificationServiceServer(s *grpc.Server, srv NotificationServiceServer) {
|
|
s.RegisterService(&_NotificationService_serviceDesc, srv)
|
|
}
|
|
|
|
func _NotificationService_GetNotification_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
|
in := new(GetNotificationRequest)
|
|
if err := dec(in); err != nil {
|
|
return nil, err
|
|
}
|
|
if interceptor == nil {
|
|
return srv.(NotificationServiceServer).GetNotification(ctx, in)
|
|
}
|
|
info := &grpc.UnaryServerInfo{
|
|
Server: srv,
|
|
FullMethod: "/coreos.clair.NotificationService/GetNotification",
|
|
}
|
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
|
return srv.(NotificationServiceServer).GetNotification(ctx, req.(*GetNotificationRequest))
|
|
}
|
|
return interceptor(ctx, in, info, handler)
|
|
}
|
|
|
|
func _NotificationService_MarkNotificationAsRead_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
|
in := new(MarkNotificationAsReadRequest)
|
|
if err := dec(in); err != nil {
|
|
return nil, err
|
|
}
|
|
if interceptor == nil {
|
|
return srv.(NotificationServiceServer).MarkNotificationAsRead(ctx, in)
|
|
}
|
|
info := &grpc.UnaryServerInfo{
|
|
Server: srv,
|
|
FullMethod: "/coreos.clair.NotificationService/MarkNotificationAsRead",
|
|
}
|
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
|
return srv.(NotificationServiceServer).MarkNotificationAsRead(ctx, req.(*MarkNotificationAsReadRequest))
|
|
}
|
|
return interceptor(ctx, in, info, handler)
|
|
}
|
|
|
|
var _NotificationService_serviceDesc = grpc.ServiceDesc{
|
|
ServiceName: "coreos.clair.NotificationService",
|
|
HandlerType: (*NotificationServiceServer)(nil),
|
|
Methods: []grpc.MethodDesc{
|
|
{
|
|
MethodName: "GetNotification",
|
|
Handler: _NotificationService_GetNotification_Handler,
|
|
},
|
|
{
|
|
MethodName: "MarkNotificationAsRead",
|
|
Handler: _NotificationService_MarkNotificationAsRead_Handler,
|
|
},
|
|
},
|
|
Streams: []grpc.StreamDesc{},
|
|
Metadata: "api/v3/clairpb/clair.proto",
|
|
}
|
|
|
|
// Client API for StatusService service
|
|
|
|
type StatusServiceClient interface {
|
|
// The RPC used to show the internal state of current Clair instance.
|
|
GetStatus(ctx context.Context, in *GetStatusRequest, opts ...grpc.CallOption) (*GetStatusResponse, error)
|
|
}
|
|
|
|
type statusServiceClient struct {
|
|
cc *grpc.ClientConn
|
|
}
|
|
|
|
func NewStatusServiceClient(cc *grpc.ClientConn) StatusServiceClient {
|
|
return &statusServiceClient{cc}
|
|
}
|
|
|
|
func (c *statusServiceClient) GetStatus(ctx context.Context, in *GetStatusRequest, opts ...grpc.CallOption) (*GetStatusResponse, error) {
|
|
out := new(GetStatusResponse)
|
|
err := grpc.Invoke(ctx, "/coreos.clair.StatusService/GetStatus", in, out, c.cc, opts...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return out, nil
|
|
}
|
|
|
|
// Server API for StatusService service
|
|
|
|
type StatusServiceServer interface {
|
|
// The RPC used to show the internal state of current Clair instance.
|
|
GetStatus(context.Context, *GetStatusRequest) (*GetStatusResponse, error)
|
|
}
|
|
|
|
func RegisterStatusServiceServer(s *grpc.Server, srv StatusServiceServer) {
|
|
s.RegisterService(&_StatusService_serviceDesc, srv)
|
|
}
|
|
|
|
func _StatusService_GetStatus_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
|
|
in := new(GetStatusRequest)
|
|
if err := dec(in); err != nil {
|
|
return nil, err
|
|
}
|
|
if interceptor == nil {
|
|
return srv.(StatusServiceServer).GetStatus(ctx, in)
|
|
}
|
|
info := &grpc.UnaryServerInfo{
|
|
Server: srv,
|
|
FullMethod: "/coreos.clair.StatusService/GetStatus",
|
|
}
|
|
handler := func(ctx context.Context, req interface{}) (interface{}, error) {
|
|
return srv.(StatusServiceServer).GetStatus(ctx, req.(*GetStatusRequest))
|
|
}
|
|
return interceptor(ctx, in, info, handler)
|
|
}
|
|
|
|
var _StatusService_serviceDesc = grpc.ServiceDesc{
|
|
ServiceName: "coreos.clair.StatusService",
|
|
HandlerType: (*StatusServiceServer)(nil),
|
|
Methods: []grpc.MethodDesc{
|
|
{
|
|
MethodName: "GetStatus",
|
|
Handler: _StatusService_GetStatus_Handler,
|
|
},
|
|
},
|
|
Streams: []grpc.StreamDesc{},
|
|
Metadata: "api/v3/clairpb/clair.proto",
|
|
}
|
|
|
|
func init() { proto.RegisterFile("api/v3/clairpb/clair.proto", fileDescriptor0) }
|
|
|
|
var fileDescriptor0 = []byte{
|
|
// 1268 bytes of a gzipped FileDescriptorProto
|
|
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x57, 0x4b, 0x6f, 0x1b, 0x55,
|
|
0x14, 0xd6, 0x38, 0x71, 0x6c, 0x1f, 0xdb, 0x49, 0x7a, 0xed, 0xa6, 0x93, 0x49, 0x1f, 0xc9, 0x40,
|
|
0xd5, 0xd2, 0x22, 0x5b, 0x75, 0x59, 0x94, 0xb2, 0x40, 0xe9, 0x23, 0xa1, 0x52, 0xa9, 0xaa, 0x29,
|
|
0x64, 0x01, 0x42, 0xd6, 0xcd, 0xcc, 0x71, 0x32, 0xca, 0x78, 0xc6, 0xcc, 0xbd, 0x4e, 0x6a, 0x55,
|
|
0x65, 0xc1, 0x96, 0x15, 0xb0, 0xe0, 0x37, 0xb0, 0xe1, 0x1f, 0xb0, 0x62, 0xcb, 0x02, 0xc1, 0x16,
|
|
0x76, 0x2c, 0xf8, 0x03, 0xec, 0xd1, 0x7d, 0x4d, 0x66, 0x12, 0x37, 0x49, 0xcb, 0xca, 0x73, 0xde,
|
|
0xaf, 0xef, 0x9e, 0x93, 0x80, 0x43, 0x47, 0x61, 0x77, 0xff, 0x76, 0xd7, 0x8f, 0x68, 0x98, 0x8e,
|
|
0xb6, 0xd5, 0x6f, 0x67, 0x94, 0x26, 0x3c, 0x21, 0x0d, 0x3f, 0x49, 0x31, 0x61, 0x1d, 0xc9, 0x73,
|
|
0xae, 0xec, 0x24, 0xc9, 0x4e, 0x84, 0x5d, 0x29, 0xdb, 0x1e, 0x0f, 0xba, 0x3c, 0x1c, 0x22, 0xe3,
|
|
0x74, 0x38, 0x52, 0xea, 0xce, 0x45, 0xad, 0x20, 0x3c, 0xd2, 0x38, 0x4e, 0x38, 0xe5, 0x61, 0x12,
|
|
0x33, 0x25, 0x75, 0x7f, 0x28, 0x41, 0x73, 0x6b, 0x1c, 0xc5, 0x98, 0xd2, 0xed, 0x30, 0x0a, 0xf9,
|
|
0x84, 0x10, 0x98, 0x8d, 0xe9, 0x10, 0x6d, 0x6b, 0xd5, 0xba, 0x5e, 0xf3, 0xe4, 0x37, 0xb9, 0x0a,
|
|
0xf3, 0xe2, 0x97, 0x8d, 0xa8, 0x8f, 0x7d, 0x29, 0x2d, 0x49, 0x69, 0x33, 0xe3, 0x3e, 0x11, 0x6a,
|
|
0xab, 0x50, 0x0f, 0x90, 0xf9, 0x69, 0x38, 0x12, 0x21, 0xec, 0x19, 0xa9, 0x93, 0x67, 0x09, 0xe7,
|
|
0x51, 0x18, 0xef, 0xd9, 0xb3, 0xca, 0xb9, 0xf8, 0x26, 0x0e, 0x54, 0x19, 0xee, 0x63, 0x1a, 0xf2,
|
|
0x89, 0x5d, 0x96, 0xfc, 0x8c, 0x16, 0xb2, 0x21, 0x72, 0x1a, 0x50, 0x4e, 0xed, 0x39, 0x25, 0x33,
|
|
0x34, 0x59, 0x86, 0xea, 0x20, 0x7c, 0x8e, 0x41, 0x7f, 0x7b, 0x62, 0x57, 0xa4, 0xac, 0x22, 0xe9,
|
|
0x7b, 0x13, 0x72, 0x0f, 0xce, 0xd1, 0xc1, 0x00, 0x7d, 0x8e, 0x41, 0x7f, 0x1f, 0x53, 0x26, 0x0a,
|
|
0xb6, 0xab, 0xab, 0x33, 0xd7, 0xeb, 0xbd, 0xf3, 0x9d, 0x7c, 0xfb, 0x3a, 0x1b, 0x48, 0xf9, 0x38,
|
|
0x45, 0x6f, 0xd1, 0xe8, 0x6f, 0x69, 0x75, 0xf7, 0x57, 0x0b, 0x2a, 0x5a, 0xfa, 0x7f, 0x7a, 0x62,
|
|
0x43, 0x45, 0x67, 0xa0, 0xfb, 0x61, 0x48, 0xe1, 0x40, 0x7f, 0xf6, 0x07, 0x49, 0x3a, 0xa4, 0x5c,
|
|
0x77, 0xa5, 0xa9, 0xb9, 0x1b, 0x92, 0x49, 0x1e, 0xc2, 0xc2, 0x7e, 0x6e, 0x40, 0x21, 0x32, 0xbb,
|
|
0x2c, 0x2b, 0x59, 0x29, 0x56, 0x52, 0x98, 0xa2, 0x77, 0xd4, 0xc6, 0x5d, 0x81, 0xf2, 0x63, 0x3a,
|
|
0xc1, 0x54, 0xd4, 0xb2, 0x4b, 0xd9, 0xae, 0xa9, 0x45, 0x7c, 0xbb, 0xdf, 0x58, 0x50, 0xbf, 0x2f,
|
|
0xbc, 0x3c, 0xe3, 0x94, 0x8f, 0x99, 0x48, 0x3a, 0x0a, 0x19, 0xc7, 0x94, 0xd9, 0xd6, 0xea, 0x8c,
|
|
0x48, 0x5a, 0x93, 0xe4, 0x22, 0xd4, 0x02, 0xe4, 0xe8, 0xf3, 0x24, 0x65, 0x76, 0x49, 0xca, 0x0e,
|
|
0x19, 0xe4, 0x01, 0x2c, 0x46, 0x94, 0xf1, 0xfe, 0x78, 0x14, 0x50, 0x8e, 0x7d, 0x01, 0x45, 0x59,
|
|
0x75, 0xbd, 0xe7, 0x74, 0x14, 0x0c, 0x3b, 0x06, 0xa7, 0x9d, 0x4f, 0x0c, 0x4e, 0xbd, 0x79, 0x61,
|
|
0xf3, 0xa9, 0x34, 0x11, 0x4c, 0xf7, 0x5b, 0x0b, 0xc8, 0x26, 0xf2, 0xf5, 0xd8, 0x47, 0xc6, 0xd3,
|
|
0x89, 0x87, 0x5f, 0x8e, 0x91, 0x71, 0xf2, 0x16, 0x34, 0xa9, 0x66, 0xf5, 0x73, 0xd3, 0x68, 0x18,
|
|
0xa6, 0x6c, 0xf7, 0x2d, 0x68, 0x1f, 0x84, 0x7c, 0xb7, 0x7f, 0xb4, 0x65, 0x62, 0x36, 0x55, 0xaf,
|
|
0x25, 0x64, 0x5b, 0x45, 0x91, 0xf0, 0x2b, 0x4d, 0x06, 0x6a, 0xd8, 0x4c, 0x66, 0x5c, 0xf5, 0x1a,
|
|
0x82, 0xa9, 0x01, 0xc0, 0xdc, 0xdf, 0x66, 0xa0, 0x55, 0xc8, 0x89, 0x8d, 0x92, 0x98, 0x21, 0xd9,
|
|
0x80, 0xaa, 0x89, 0x2f, 0xf3, 0xa9, 0xf7, 0x6e, 0x14, 0xc7, 0x32, 0xc5, 0xa8, 0x93, 0x31, 0x32,
|
|
0x5b, 0x72, 0x0b, 0xe6, 0x98, 0xec, 0xbd, 0xcc, 0xb4, 0xde, 0x5b, 0x2e, 0x7a, 0xc9, 0x0d, 0xc7,
|
|
0xd3, 0x8a, 0xce, 0x57, 0xd0, 0x34, 0x8e, 0xd4, 0x64, 0xdf, 0x81, 0x72, 0x24, 0x3e, 0x74, 0x22,
|
|
0xad, 0xa2, 0x0b, 0xa9, 0xe3, 0x29, 0x0d, 0xf1, 0x40, 0xd4, 0xd4, 0x30, 0x38, 0xac, 0xbb, 0x74,
|
|
0xe2, 0x03, 0x31, 0xfa, 0xa6, 0x25, 0xce, 0xcf, 0x16, 0x54, 0x4d, 0x02, 0x53, 0x5f, 0xc8, 0x35,
|
|
0x58, 0x60, 0x3e, 0x8d, 0x63, 0x0c, 0xfa, 0x06, 0x4d, 0xb3, 0x12, 0x31, 0xf3, 0x9a, 0xfd, 0x58,
|
|
0x83, 0xea, 0x26, 0x9c, 0x33, 0x8a, 0x87, 0xe0, 0x2a, 0x4b, 0xd5, 0x45, 0x2d, 0x78, 0x90, 0x61,
|
|
0x6c, 0x13, 0xe6, 0x64, 0x0d, 0xcc, 0x9e, 0x93, 0xf9, 0x76, 0xcf, 0xde, 0x6f, 0xd5, 0x02, 0x6d,
|
|
0xee, 0xfe, 0x55, 0x82, 0xd6, 0xd3, 0x84, 0xbd, 0x19, 0xce, 0x96, 0x60, 0x4e, 0x3f, 0x5a, 0xf5,
|
|
0xea, 0x35, 0x45, 0xee, 0x67, 0xd9, 0xcd, 0xc8, 0xec, 0x6e, 0x16, 0xb3, 0x9b, 0x12, 0x4f, 0xf2,
|
|
0x0a, 0x99, 0x39, 0xbf, 0x58, 0x50, 0xcb, 0xb8, 0xd3, 0x1e, 0xac, 0xe0, 0x8d, 0x28, 0xdf, 0xd5,
|
|
0xc1, 0xe5, 0x37, 0xf1, 0xa0, 0xb2, 0x8b, 0x34, 0x38, 0x8c, 0x7d, 0xe7, 0x35, 0x62, 0x77, 0x3e,
|
|
0x52, 0xa6, 0x0f, 0x63, 0x21, 0x35, 0x8e, 0x9c, 0xbb, 0xd0, 0xc8, 0x0b, 0xc8, 0x22, 0xcc, 0xec,
|
|
0xe1, 0x44, 0xa7, 0x22, 0x3e, 0x49, 0x1b, 0xca, 0xfb, 0x34, 0x1a, 0x9b, 0xed, 0xa7, 0x88, 0xbb,
|
|
0xa5, 0x3b, 0x96, 0xfb, 0x08, 0xda, 0xc5, 0x90, 0xfa, 0xc9, 0x1c, 0x42, 0xdd, 0x3a, 0x23, 0xd4,
|
|
0xdd, 0x9f, 0x2c, 0x58, 0xda, 0x44, 0xfe, 0x24, 0xe1, 0xe1, 0x20, 0xf4, 0xe5, 0x01, 0x33, 0xd3,
|
|
0x7a, 0x0f, 0x96, 0x92, 0x28, 0x28, 0xbc, 0xf7, 0x49, 0x7f, 0x44, 0x77, 0xcc, 0xd8, 0xda, 0x49,
|
|
0x14, 0x14, 0x56, 0xe3, 0x53, 0xba, 0x83, 0xc2, 0x2a, 0xc6, 0x83, 0x69, 0x56, 0xaa, 0x8c, 0x76,
|
|
0x8c, 0x07, 0xc7, 0xad, 0xda, 0x50, 0x8e, 0xc2, 0x61, 0xc8, 0xe5, 0x86, 0x28, 0x7b, 0x8a, 0xc8,
|
|
0xa0, 0x3f, 0x7b, 0x08, 0x7d, 0xf7, 0xcf, 0x12, 0x5c, 0x38, 0x96, 0xb0, 0xae, 0x7f, 0x0b, 0x1a,
|
|
0x71, 0x8e, 0xaf, 0xbb, 0xd0, 0x3b, 0x06, 0xe3, 0x69, 0xc6, 0x9d, 0x02, 0xb3, 0xe0, 0xc7, 0xf9,
|
|
0xc7, 0x82, 0x46, 0x5e, 0x3c, 0xf5, 0x4d, 0xda, 0x50, 0xf1, 0x53, 0xa4, 0x1c, 0x03, 0x5d, 0xa9,
|
|
0x21, 0xc5, 0xa9, 0x55, 0xee, 0x30, 0xd0, 0x97, 0x2a, 0xa3, 0x85, 0x55, 0x80, 0x11, 0x0a, 0x2b,
|
|
0x55, 0xa5, 0x21, 0xc9, 0xfb, 0x30, 0x93, 0x44, 0x81, 0xbc, 0xdb, 0xf5, 0xde, 0xb5, 0x23, 0x80,
|
|
0xa3, 0x3b, 0x98, 0xf5, 0x3e, 0x42, 0x0d, 0x84, 0x10, 0x99, 0x27, 0x6c, 0x84, 0x69, 0x8c, 0x07,
|
|
0xf2, 0xac, 0xbf, 0x8e, 0x69, 0x8c, 0x07, 0xee, 0xef, 0x25, 0x58, 0x7e, 0xa5, 0x0a, 0x59, 0x83,
|
|
0x86, 0x3f, 0x4e, 0x53, 0x8c, 0x79, 0x1e, 0x08, 0x75, 0xcd, 0x93, 0x93, 0x5c, 0x81, 0x5a, 0x8c,
|
|
0xcf, 0x79, 0x7e, 0xe4, 0x55, 0xc1, 0x38, 0x61, 0xcc, 0xeb, 0xd0, 0x2c, 0xc0, 0x45, 0x76, 0xe2,
|
|
0x94, 0x2b, 0x5c, 0xb4, 0x20, 0x9f, 0x03, 0xd0, 0x2c, 0x4d, 0x7d, 0xc5, 0x3f, 0x38, 0x63, 0xe1,
|
|
0x9d, 0x47, 0x71, 0x80, 0xcf, 0x31, 0x58, 0xcf, 0x6d, 0x21, 0x2f, 0xe7, 0xce, 0xf9, 0x10, 0x5a,
|
|
0x53, 0x54, 0x44, 0x31, 0xa1, 0x60, 0xcb, 0x2e, 0x94, 0x3d, 0x45, 0x64, 0xd0, 0x28, 0xe5, 0x30,
|
|
0x7b, 0x1b, 0x2e, 0x7d, 0x4c, 0xd3, 0xbd, 0x3c, 0x84, 0xd6, 0x99, 0x87, 0x34, 0x30, 0x4f, 0x6d,
|
|
0x0a, 0x9e, 0xdc, 0x55, 0xb8, 0xfc, 0x2a, 0x23, 0x85, 0x58, 0x97, 0xc0, 0xe2, 0x26, 0x72, 0xfd,
|
|
0xa0, 0x95, 0x27, 0x77, 0x03, 0xce, 0xe5, 0x78, 0x6f, 0xbc, 0x17, 0x7a, 0xff, 0x5a, 0xb0, 0x60,
|
|
0xaa, 0x7d, 0x86, 0xe9, 0x7e, 0xe8, 0x23, 0x19, 0x43, 0x3d, 0x77, 0x03, 0xc8, 0xea, 0x09, 0xe7,
|
|
0x41, 0x26, 0xe3, 0xac, 0x9d, 0x7a, 0x40, 0xdc, 0xb5, 0xaf, 0xff, 0xf8, 0xfb, 0xfb, 0xd2, 0x0a,
|
|
0x59, 0xee, 0x9a, 0x23, 0xd0, 0x7d, 0x51, 0xb8, 0x11, 0x2f, 0xc9, 0x1e, 0x34, 0xf2, 0xdb, 0x8e,
|
|
0xac, 0x9d, 0xba, 0x7c, 0x1d, 0xf7, 0x24, 0x15, 0x1d, 0xb9, 0x2d, 0x23, 0xcf, 0xbb, 0xb5, 0x2c,
|
|
0xf2, 0x5d, 0xeb, 0x46, 0xef, 0xc7, 0x12, 0xb4, 0xf2, 0x2d, 0x37, 0xb5, 0xbf, 0x84, 0x85, 0x23,
|
|
0x8b, 0x83, 0xbc, 0x7d, 0xca, 0x5e, 0x51, 0xa9, 0x5c, 0x3d, 0xd3, 0xf6, 0x71, 0x2f, 0xc9, 0x6c,
|
|
0x2e, 0x90, 0xf3, 0xdd, 0xfc, 0xe6, 0x61, 0xdd, 0x17, 0xaa, 0x07, 0xdf, 0x59, 0xb0, 0x34, 0x1d,
|
|
0x0d, 0xe4, 0xc8, 0x1d, 0x3c, 0x11, 0x68, 0xce, 0xbb, 0x67, 0x53, 0x2e, 0x26, 0x75, 0x63, 0x7a,
|
|
0x52, 0xbd, 0x18, 0x9a, 0x0a, 0x35, 0xa6, 0x49, 0x5f, 0x40, 0x2d, 0x03, 0x1f, 0xb9, 0x7c, 0xac,
|
|
0xf0, 0x02, 0x52, 0x9d, 0x2b, 0xaf, 0x94, 0xeb, 0xe8, 0x0b, 0x32, 0x7a, 0x8d, 0x54, 0xba, 0x0a,
|
|
0x93, 0xf7, 0x2e, 0x43, 0xcb, 0x4f, 0x86, 0x45, 0xb3, 0xd1, 0xf6, 0x67, 0x15, 0xfd, 0xaf, 0xdc,
|
|
0xf6, 0x9c, 0xfc, 0x0b, 0xf8, 0xf6, 0x7f, 0x01, 0x00, 0x00, 0xff, 0xff, 0xc7, 0xaf, 0x17, 0x4a,
|
|
0xe3, 0x0d, 0x00, 0x00,
|
|
}
|