提交 8d46bc6a 编写于 作者: J jiazhiguang

epm: reconstruct the code of epm

上级 fcf45681
...@@ -42,32 +42,32 @@ func runServer(opts *options.Options) error { ...@@ -42,32 +42,32 @@ func runServer(opts *options.Options) error {
return fmt.Errorf("create metadata server failed. %++v", err) return fmt.Errorf("create metadata server failed. %++v", err)
} }
server := epm.CachePoolManagerServer{} server := epm.EnclavePoolManagerServer{}
bundleCache0 := occlum.Cach0Manager{ bundleCache0 := occlum.BundleCach0Manager{
DefaultCachePoolManager: epm.DefaultCachePoolManager{ DefaultEnclavePool: epm.DefaultEnclavePool{
Root: cfg.Root, Root: cfg.Root,
CacheMetadata: metadata, CacheMetadata: metadata,
}} }}
bundleCache1 := occlum.Cach1Manager{ bundleCache1 := occlum.BundleCach1Manager{
DefaultCachePoolManager: epm.DefaultCachePoolManager{ DefaultEnclavePool: epm.DefaultEnclavePool{
Root: cfg.Root, Root: cfg.Root,
CacheMetadata: metadata, CacheMetadata: metadata,
}} }}
bundleCache2 := occlum.Cach2Manager{ bundleCache2 := occlum.BundleCach2Manager{
DefaultCachePoolManager: epm.DefaultCachePoolManager{ DefaultEnclavePool: epm.DefaultEnclavePool{
Root: cfg.Root, Root: cfg.Root,
CacheMetadata: metadata, CacheMetadata: metadata,
}} }}
// registry the bundle cache pool managers to the manager server // register the bundle cache pool managers to the manager server
server.RegistryCachePoolManager(&bundleCache0) server.RegisterCachePoolManager(&bundleCache0)
server.RegistryCachePoolManager(&bundleCache1) server.RegisterCachePoolManager(&bundleCache1)
server.RegistryCachePoolManager(&bundleCache2) server.RegisterCachePoolManager(&bundleCache2)
// start the grpc server with the server options // start the grpc server with the server options
s := grpc.NewServer(serverOpts...) s := grpc.NewServer(serverOpts...)
// registry and start the cache pool manager server // registry and start the cache pool manager server
v1alpha1.RegisterCachePoolManagerServer(s, &server) v1alpha1.RegisterEnclavePoolManagerServer(s, &server)
// listen and serve // listen and serve
lis, err := net.Listen("udp", cfg.GRPC.Address) lis, err := net.Listen("udp", cfg.GRPC.Address)
if err != nil { if err != nil {
......
...@@ -5,8 +5,8 @@ import ( ...@@ -5,8 +5,8 @@ import (
"github.com/spf13/cobra" "github.com/spf13/cobra"
) )
// NewCachePoolManagerServer creat and start the cache pool manager server // NewEnclavePoolManagerServer creat and start the enclave pool manager server
func NewCachePoolManagerServer() *cobra.Command { func NewEnclavePoolManagerServer() *cobra.Command {
opts := &options.Options{} opts := &options.Options{}
cmd := &cobra.Command{ cmd := &cobra.Command{
Short: "Launch signature server", Short: "Launch signature server",
......
...@@ -14,7 +14,7 @@ func main() { ...@@ -14,7 +14,7 @@ func main() {
runtime.GOMAXPROCS(runtime.NumCPU()) runtime.GOMAXPROCS(runtime.NumCPU())
} }
cmd := app.NewCachePoolManagerServer() cmd := app.NewEnclavePoolManagerServer()
cmd.Flags().AddGoFlagSet(flag.CommandLine) cmd.Flags().AddGoFlagSet(flag.CommandLine)
if err := cmd.Execute(); err != nil { if err := cmd.Execute(); err != nil {
......
root = "/var/local/epm" root = "/var/local/epm"
db_path = "/var/local/epm/epm.db"
db_timeout = 10
[grpc] [grpc]
address = "/var/run/containerd/containerd.sock" address = "/var/run/containerd/containerd.sock"
...@@ -7,10 +9,10 @@ root = "/var/local/epm" ...@@ -7,10 +9,10 @@ root = "/var/local/epm"
max_recv_message_size = 16777216 max_recv_message_size = 16777216
max_send_message_size = 16777216 max_send_message_size = 16777216
[caches] [pools]
[caches.bundle-cache-pool_occlum_cache0] [pools."bundle-cache.occlum.cache0"]
type = "bundle-cache-pool.occlum.cache0" type = "bundle-cache.occlum.cache0"
[caches.bundle-cache-pool_occlum_cache1] [pools."bundle-cache.occlum.cache1"]
type = "bundle-cache-pool.occlum.cache1" type = "bundle-cache.occlum.cache1"
[caches.bundle-cache-pool_occlum_cache2] [pools."bundle-cache.occlum.cache2"]
type = "bundle-cache-pool.occlum.cache2" type = "bundle-cache.occlum.cache2"
\ No newline at end of file \ No newline at end of file
...@@ -9,8 +9,8 @@ type Config struct { ...@@ -9,8 +9,8 @@ type Config struct {
DBPath string `toml:"db_path"` DBPath string `toml:"db_path"`
// DBTimeout is the amount of time to wait to obtain a database file lock. // DBTimeout is the amount of time to wait to obtain a database file lock.
DBTimeout int `toml:"db_timeout"` DBTimeout int `toml:"db_timeout"`
// CachePools stores the configurations of cache pool managers // EnclavePools stores the configurations of enclave pool
CachePools map[string]CachePool `toml:"cache_pools"` EnclavePools map[string]EnclavePoolConfiguration `toml:"pools"`
} }
// GRPCConfig provides GRPC configuration for the socket // GRPCConfig provides GRPC configuration for the socket
...@@ -25,7 +25,7 @@ type GRPCConfig struct { ...@@ -25,7 +25,7 @@ type GRPCConfig struct {
MaxSendMsgSize int `toml:"max_send_message_size"` MaxSendMsgSize int `toml:"max_send_message_size"`
} }
// CachePool provides the configuration for the cache pool // EnclavePoolConfiguration provides the configuration for the enclave pool
type CachePool struct { type EnclavePoolConfiguration struct {
Type string `toml:"type"` Type string `toml:"type"`
} }
...@@ -10,6 +10,8 @@ import ( ...@@ -10,6 +10,8 @@ import (
func TestDecodeConfig(t *testing.T) { func TestDecodeConfig(t *testing.T) {
text := ` text := `
root = "/var/local/epm" root = "/var/local/epm"
db_path = "/var/local/epm/epm.db"
db_timeout = 10
[grpc] [grpc]
address = "/var/run/containerd/containerd.sock" address = "/var/run/containerd/containerd.sock"
...@@ -18,13 +20,13 @@ root = "/var/local/epm" ...@@ -18,13 +20,13 @@ root = "/var/local/epm"
max_recv_message_size = 16777216 max_recv_message_size = 16777216
max_send_message_size = 16777216 max_send_message_size = 16777216
[cache_pools] [pools]
[cache_pools.bundle-cache-pool_occlum_cache0] [pools."bundle-cache.occlum.cache0"]
type = "bundle-cache-pool.occlum.cache0" type = "bundle-cache.occlum.cache0"
[cache_pools.bundle-cache-pool_occlum_cache1] [pools."bundle-cache.occlum.cache1"]
type = "bundle-cache-pool.occlum.cache1" type = "bundle-cache.occlum.cache1"
[cache_pools.bundle-cache-pool_occlum_cache2] [pools."bundle-cache.occlum.cache2"]
type = "bundle-cache-pool.occlum.cache2" type = "bundle-cache.occlum.cache2"
` `
var cfg Config var cfg Config
...@@ -32,7 +34,7 @@ root = "/var/local/epm" ...@@ -32,7 +34,7 @@ root = "/var/local/epm"
t.Fatal(err) t.Fatal(err)
} }
for k, v := range cfg.CachePools { for k, v := range cfg.EnclavePools {
fmt.Println(k) fmt.Println(k)
fmt.Println(v.Type) fmt.Println(v.Type)
} }
......
...@@ -7,12 +7,11 @@ ...@@ -7,12 +7,11 @@
package v1alpha1 package v1alpha1
import ( import (
reflect "reflect"
sync "sync"
proto "github.com/golang/protobuf/proto" proto "github.com/golang/protobuf/proto"
protoreflect "google.golang.org/protobuf/reflect/protoreflect" protoreflect "google.golang.org/protobuf/reflect/protoreflect"
protoimpl "google.golang.org/protobuf/runtime/protoimpl" protoimpl "google.golang.org/protobuf/runtime/protoimpl"
reflect "reflect"
sync "sync"
) )
const ( const (
...@@ -26,15 +25,15 @@ const ( ...@@ -26,15 +25,15 @@ const (
// of the legacy proto package is being used. // of the legacy proto package is being used.
const _ = proto.ProtoPackageIsVersion4 const _ = proto.ProtoPackageIsVersion4
// Cache represents the metadata of a cache managed by cache pool manager. // Cache represents the metadata of a cache managed by enclave pool.
type Cache struct { type Cache struct {
state protoimpl.MessageState state protoimpl.MessageState
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// Type represents the type of cache pool manager // Type represents the type of enclave pool
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
// ID represents the id of the cache and the id is unique in the same type of cache // ID represents the id of the cache and the id is unique in the same type of enclave pool
ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"` ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"`
// SavePath represents the absolute path to store the cache // SavePath represents the absolute path to store the cache
SavePath string `protobuf:"bytes,3,opt,name=savePath,proto3" json:"savePath,omitempty"` SavePath string `protobuf:"bytes,3,opt,name=savePath,proto3" json:"savePath,omitempty"`
...@@ -126,7 +125,7 @@ type GetCacheRequest struct { ...@@ -126,7 +125,7 @@ type GetCacheRequest struct {
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// Type represents the type of cache pool manager // Type represents the type of enclave pool
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
// ID represents the id of the cache // ID represents the id of the cache
ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"` ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"`
...@@ -336,7 +335,7 @@ type ListCacheRequest struct { ...@@ -336,7 +335,7 @@ type ListCacheRequest struct {
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// Type represents the type of cache pool manager // Type represents the type of enclave pool
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
// LastCacheID represents the id of the last cache metadata in the most recent query list, // LastCacheID represents the id of the last cache metadata in the most recent query list,
// if the value is "", query the cache metadata from the starting point of DB, // if the value is "", query the cache metadata from the starting point of DB,
...@@ -404,7 +403,7 @@ type ListCacheResponse struct { ...@@ -404,7 +403,7 @@ type ListCacheResponse struct {
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// CachePools represents the list of response caches // Caches represents the list of response caches
Caches []*Cache `protobuf:"bytes,1,rep,name=caches,proto3" json:"caches,omitempty"` Caches []*Cache `protobuf:"bytes,1,rep,name=caches,proto3" json:"caches,omitempty"`
} }
...@@ -452,7 +451,7 @@ type DeleteCacheRequest struct { ...@@ -452,7 +451,7 @@ type DeleteCacheRequest struct {
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// Type represents the type of cache pool manager // Type represents the type of enclave pool
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
// ID represents the id of the cache // ID represents the id of the cache
ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"` ID string `protobuf:"bytes,2,opt,name=ID,proto3" json:"ID,omitempty"`
...@@ -557,7 +556,7 @@ type LoadCacheRequest struct { ...@@ -557,7 +556,7 @@ type LoadCacheRequest struct {
sizeCache protoimpl.SizeCache sizeCache protoimpl.SizeCache
unknownFields protoimpl.UnknownFields unknownFields protoimpl.UnknownFields
// Type represents the type of cache pool manager // Type represents the type of enclave pool
Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"` Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
// ID represents the id of the cache // ID represents the id of the cache
ID string `protobuf:"bytes,3,opt,name=ID,proto3" json:"ID,omitempty"` ID string `protobuf:"bytes,3,opt,name=ID,proto3" json:"ID,omitempty"`
...@@ -719,31 +718,31 @@ var file_api_proto_rawDesc = []byte{ ...@@ -719,31 +718,31 @@ var file_api_proto_rawDesc = []byte{
0x01, 0x28, 0x09, 0x52, 0x0a, 0x74, 0x61, 0x72, 0x67, 0x65, 0x74, 0x50, 0x61, 0x74, 0x68, 0x22, 0x01, 0x28, 0x09, 0x52, 0x0a, 0x74, 0x61, 0x72, 0x67, 0x65, 0x74, 0x50, 0x61, 0x74, 0x68, 0x22,
0x23, 0x0a, 0x11, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x23, 0x0a, 0x11, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70,
0x6f, 0x6e, 0x73, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x6f, 0x6b, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08, 0x6f, 0x6e, 0x73, 0x65, 0x12, 0x0e, 0x0a, 0x02, 0x6f, 0x6b, 0x18, 0x01, 0x20, 0x01, 0x28, 0x08,
0x52, 0x02, 0x6f, 0x6b, 0x32, 0xfd, 0x02, 0x0a, 0x10, 0x43, 0x61, 0x63, 0x68, 0x65, 0x50, 0x6f, 0x52, 0x02, 0x6f, 0x6b, 0x32, 0xff, 0x02, 0x0a, 0x12, 0x45, 0x6e, 0x63, 0x6c, 0x61, 0x76, 0x65,
0x6f, 0x6c, 0x4d, 0x61, 0x6e, 0x61, 0x67, 0x65, 0x72, 0x12, 0x43, 0x0a, 0x08, 0x47, 0x65, 0x74, 0x50, 0x6f, 0x6f, 0x6c, 0x4d, 0x61, 0x6e, 0x61, 0x67, 0x65, 0x72, 0x12, 0x43, 0x0a, 0x08, 0x47,
0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x19, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x65, 0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x19, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68,
0x2e, 0x47, 0x65, 0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x61, 0x31, 0x2e, 0x47, 0x65, 0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65,
0x1a, 0x1a, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x47, 0x65, 0x74, 0x43, 0x73, 0x74, 0x1a, 0x1a, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x47, 0x65,
0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00,
0x12, 0x46, 0x0a, 0x09, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e,
0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63,
0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c,
0x70, 0x68, 0x61, 0x31, 0x2e, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65,
0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x46, 0x0a, 0x09, 0x4c, 0x69, 0x73, 0x74,
0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31,
0x2e, 0x4c, 0x69, 0x73, 0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73,
0x74, 0x1a, 0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x4c, 0x69, 0x73,
0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00,
0x12, 0x4c, 0x0a, 0x0b, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12,
0x1c, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74,
0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1d, 0x2e,
0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43,
0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x46, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x46,
0x0a, 0x09, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e, 0x76, 0x31, 0x0a, 0x09, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e, 0x76, 0x31,
0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65,
0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68,
0x61, 0x31, 0x2e, 0x53, 0x61, 0x76, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x61, 0x31, 0x2e, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70,
0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x46, 0x0a, 0x09, 0x4c, 0x69, 0x73, 0x74, 0x43, 0x61, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x4c,
0x69, 0x73, 0x74, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a,
0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x4c, 0x69, 0x73, 0x74, 0x43,
0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x4c,
0x0a, 0x0b, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1c, 0x2e,
0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43,
0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1d, 0x2e, 0x76, 0x31,
0x61, 0x6c, 0x70, 0x68, 0x61, 0x31, 0x2e, 0x44, 0x65, 0x6c, 0x65, 0x74, 0x65, 0x43, 0x61, 0x63,
0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e, 0x73, 0x65, 0x22, 0x00, 0x12, 0x46, 0x0a, 0x09,
0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x12, 0x1a, 0x2e, 0x76, 0x31, 0x61, 0x6c,
0x70, 0x68, 0x61, 0x31, 0x2e, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65,
0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x1b, 0x2e, 0x76, 0x31, 0x61, 0x6c, 0x70, 0x68, 0x61, 0x31,
0x2e, 0x4c, 0x6f, 0x61, 0x64, 0x43, 0x61, 0x63, 0x68, 0x65, 0x52, 0x65, 0x73, 0x70, 0x6f, 0x6e,
0x73, 0x65, 0x22, 0x00, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
} }
var ( var (
...@@ -777,16 +776,16 @@ var file_api_proto_depIdxs = []int32{ ...@@ -777,16 +776,16 @@ var file_api_proto_depIdxs = []int32{
0, // 1: v1alpha1.GetCacheResponse.cache:type_name -> v1alpha1.Cache 0, // 1: v1alpha1.GetCacheResponse.cache:type_name -> v1alpha1.Cache
0, // 2: v1alpha1.SaveCacheRequest.cache:type_name -> v1alpha1.Cache 0, // 2: v1alpha1.SaveCacheRequest.cache:type_name -> v1alpha1.Cache
0, // 3: v1alpha1.ListCacheResponse.caches:type_name -> v1alpha1.Cache 0, // 3: v1alpha1.ListCacheResponse.caches:type_name -> v1alpha1.Cache
1, // 4: v1alpha1.CachePoolManager.GetCache:input_type -> v1alpha1.GetCacheRequest 1, // 4: v1alpha1.EnclavePoolManager.GetCache:input_type -> v1alpha1.GetCacheRequest
3, // 5: v1alpha1.CachePoolManager.SaveCache:input_type -> v1alpha1.SaveCacheRequest 3, // 5: v1alpha1.EnclavePoolManager.SaveCache:input_type -> v1alpha1.SaveCacheRequest
5, // 6: v1alpha1.CachePoolManager.ListCache:input_type -> v1alpha1.ListCacheRequest 5, // 6: v1alpha1.EnclavePoolManager.ListCache:input_type -> v1alpha1.ListCacheRequest
7, // 7: v1alpha1.CachePoolManager.DeleteCache:input_type -> v1alpha1.DeleteCacheRequest 7, // 7: v1alpha1.EnclavePoolManager.DeleteCache:input_type -> v1alpha1.DeleteCacheRequest
9, // 8: v1alpha1.CachePoolManager.LoadCache:input_type -> v1alpha1.LoadCacheRequest 9, // 8: v1alpha1.EnclavePoolManager.LoadCache:input_type -> v1alpha1.LoadCacheRequest
2, // 9: v1alpha1.CachePoolManager.GetCache:output_type -> v1alpha1.GetCacheResponse 2, // 9: v1alpha1.EnclavePoolManager.GetCache:output_type -> v1alpha1.GetCacheResponse
4, // 10: v1alpha1.CachePoolManager.SaveCache:output_type -> v1alpha1.SaveCacheResponse 4, // 10: v1alpha1.EnclavePoolManager.SaveCache:output_type -> v1alpha1.SaveCacheResponse
6, // 11: v1alpha1.CachePoolManager.ListCache:output_type -> v1alpha1.ListCacheResponse 6, // 11: v1alpha1.EnclavePoolManager.ListCache:output_type -> v1alpha1.ListCacheResponse
8, // 12: v1alpha1.CachePoolManager.DeleteCache:output_type -> v1alpha1.DeleteCacheResponse 8, // 12: v1alpha1.EnclavePoolManager.DeleteCache:output_type -> v1alpha1.DeleteCacheResponse
10, // 13: v1alpha1.CachePoolManager.LoadCache:output_type -> v1alpha1.LoadCacheResponse 10, // 13: v1alpha1.EnclavePoolManager.LoadCache:output_type -> v1alpha1.LoadCacheResponse
9, // [9:14] is the sub-list for method output_type 9, // [9:14] is the sub-list for method output_type
4, // [4:9] is the sub-list for method input_type 4, // [4:9] is the sub-list for method input_type
4, // [4:4] is the sub-list for extension type_name 4, // [4:4] is the sub-list for extension type_name
......
...@@ -2,11 +2,11 @@ syntax = 'proto3'; ...@@ -2,11 +2,11 @@ syntax = 'proto3';
package v1alpha1; package v1alpha1;
// Cache represents the metadata of a cache managed by cache pool manager. // Cache represents the metadata of a cache managed by enclave pool.
message Cache { message Cache {
// Type represents the type of cache pool manager // Type represents the type of enclave pool
string type = 1; string type = 1;
// ID represents the id of the cache and the id is unique in the same type of cache // ID represents the id of the cache and the id is unique in the same type of enclave pool
string ID = 2; string ID = 2;
// SavePath represents the absolute path to store the cache // SavePath represents the absolute path to store the cache
string savePath = 3; string savePath = 3;
...@@ -18,8 +18,8 @@ message Cache { ...@@ -18,8 +18,8 @@ message Cache {
int64 created = 6; int64 created = 6;
} }
// CachePoolManager represents a cache pool manager. // EnclavePoolManager represents an enclave pool
service CachePoolManager { service EnclavePoolManager {
// GetCache represents get the specified cache metadata // GetCache represents get the specified cache metadata
rpc GetCache(GetCacheRequest) returns (GetCacheResponse) {} rpc GetCache(GetCacheRequest) returns (GetCacheResponse) {}
// SaveCache represents save the data to a cache directory and record the cache metadata // SaveCache represents save the data to a cache directory and record the cache metadata
...@@ -34,7 +34,7 @@ service CachePoolManager { ...@@ -34,7 +34,7 @@ service CachePoolManager {
// GetCacheRequest // GetCacheRequest
message GetCacheRequest { message GetCacheRequest {
// Type represents the type of cache pool manager // Type represents the type of enclave pool
string type = 1; string type = 1;
// ID represents the id of the cache // ID represents the id of the cache
string ID = 2; string ID = 2;
...@@ -58,7 +58,7 @@ message SaveCacheResponse { ...@@ -58,7 +58,7 @@ message SaveCacheResponse {
} }
message ListCacheRequest { message ListCacheRequest {
// Type represents the type of cache pool manager // Type represents the type of enclave pool
string type = 1; string type = 1;
// LastCacheID represents the id of the last cache metadata in the most recent query list, // LastCacheID represents the id of the last cache metadata in the most recent query list,
// if the value is "", query the cache metadata from the starting point of DB, // if the value is "", query the cache metadata from the starting point of DB,
...@@ -73,7 +73,7 @@ message ListCacheResponse { ...@@ -73,7 +73,7 @@ message ListCacheResponse {
} }
message DeleteCacheRequest { message DeleteCacheRequest {
// Type represents the type of cache pool manager // Type represents the type of enclave pool
string type = 1; string type = 1;
// ID represents the id of the cache // ID represents the id of the cache
string ID = 2; string ID = 2;
...@@ -84,7 +84,7 @@ message DeleteCacheResponse { ...@@ -84,7 +84,7 @@ message DeleteCacheResponse {
} }
message LoadCacheRequest { message LoadCacheRequest {
// Type represents the type of cache pool manager // Type represents the type of enclave pool
string type = 1; string type = 1;
// ID represents the id of the cache // ID represents the id of the cache
string ID = 3; string ID = 3;
......
...@@ -13,10 +13,10 @@ import ( ...@@ -13,10 +13,10 @@ import (
// is compatible with the grpc package it is being compiled against. // is compatible with the grpc package it is being compiled against.
const _ = grpc.SupportPackageIsVersion6 const _ = grpc.SupportPackageIsVersion6
// CachePoolManagerClient is the client API for CachePoolManager service. // EnclavePoolManagerClient is the client API for EnclavePoolManager service.
// //
// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream. // For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream.
type CachePoolManagerClient interface { type EnclavePoolManagerClient interface {
// GetCache represents get the specified cache metadata // GetCache represents get the specified cache metadata
GetCache(ctx context.Context, in *GetCacheRequest, opts ...grpc.CallOption) (*GetCacheResponse, error) GetCache(ctx context.Context, in *GetCacheRequest, opts ...grpc.CallOption) (*GetCacheResponse, error)
// SaveCache represents save the data to a cache directory and record the cache metadata // SaveCache represents save the data to a cache directory and record the cache metadata
...@@ -29,63 +29,63 @@ type CachePoolManagerClient interface { ...@@ -29,63 +29,63 @@ type CachePoolManagerClient interface {
LoadCache(ctx context.Context, in *LoadCacheRequest, opts ...grpc.CallOption) (*LoadCacheResponse, error) LoadCache(ctx context.Context, in *LoadCacheRequest, opts ...grpc.CallOption) (*LoadCacheResponse, error)
} }
type cachePoolManagerClient struct { type enclavePoolManagerClient struct {
cc grpc.ClientConnInterface cc grpc.ClientConnInterface
} }
func NewCachePoolManagerClient(cc grpc.ClientConnInterface) CachePoolManagerClient { func NewEnclavePoolManagerClient(cc grpc.ClientConnInterface) EnclavePoolManagerClient {
return &cachePoolManagerClient{cc} return &enclavePoolManagerClient{cc}
} }
func (c *cachePoolManagerClient) GetCache(ctx context.Context, in *GetCacheRequest, opts ...grpc.CallOption) (*GetCacheResponse, error) { func (c *enclavePoolManagerClient) GetCache(ctx context.Context, in *GetCacheRequest, opts ...grpc.CallOption) (*GetCacheResponse, error) {
out := new(GetCacheResponse) out := new(GetCacheResponse)
err := c.cc.Invoke(ctx, "/v1alpha1.CachePoolManager/GetCache", in, out, opts...) err := c.cc.Invoke(ctx, "/v1alpha1.EnclavePoolManager/GetCache", in, out, opts...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return out, nil return out, nil
} }
func (c *cachePoolManagerClient) SaveCache(ctx context.Context, in *SaveCacheRequest, opts ...grpc.CallOption) (*SaveCacheResponse, error) { func (c *enclavePoolManagerClient) SaveCache(ctx context.Context, in *SaveCacheRequest, opts ...grpc.CallOption) (*SaveCacheResponse, error) {
out := new(SaveCacheResponse) out := new(SaveCacheResponse)
err := c.cc.Invoke(ctx, "/v1alpha1.CachePoolManager/SaveCache", in, out, opts...) err := c.cc.Invoke(ctx, "/v1alpha1.EnclavePoolManager/SaveCache", in, out, opts...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return out, nil return out, nil
} }
func (c *cachePoolManagerClient) ListCache(ctx context.Context, in *ListCacheRequest, opts ...grpc.CallOption) (*ListCacheResponse, error) { func (c *enclavePoolManagerClient) ListCache(ctx context.Context, in *ListCacheRequest, opts ...grpc.CallOption) (*ListCacheResponse, error) {
out := new(ListCacheResponse) out := new(ListCacheResponse)
err := c.cc.Invoke(ctx, "/v1alpha1.CachePoolManager/ListCache", in, out, opts...) err := c.cc.Invoke(ctx, "/v1alpha1.EnclavePoolManager/ListCache", in, out, opts...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return out, nil return out, nil
} }
func (c *cachePoolManagerClient) DeleteCache(ctx context.Context, in *DeleteCacheRequest, opts ...grpc.CallOption) (*DeleteCacheResponse, error) { func (c *enclavePoolManagerClient) DeleteCache(ctx context.Context, in *DeleteCacheRequest, opts ...grpc.CallOption) (*DeleteCacheResponse, error) {
out := new(DeleteCacheResponse) out := new(DeleteCacheResponse)
err := c.cc.Invoke(ctx, "/v1alpha1.CachePoolManager/DeleteCache", in, out, opts...) err := c.cc.Invoke(ctx, "/v1alpha1.EnclavePoolManager/DeleteCache", in, out, opts...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return out, nil return out, nil
} }
func (c *cachePoolManagerClient) LoadCache(ctx context.Context, in *LoadCacheRequest, opts ...grpc.CallOption) (*LoadCacheResponse, error) { func (c *enclavePoolManagerClient) LoadCache(ctx context.Context, in *LoadCacheRequest, opts ...grpc.CallOption) (*LoadCacheResponse, error) {
out := new(LoadCacheResponse) out := new(LoadCacheResponse)
err := c.cc.Invoke(ctx, "/v1alpha1.CachePoolManager/LoadCache", in, out, opts...) err := c.cc.Invoke(ctx, "/v1alpha1.EnclavePoolManager/LoadCache", in, out, opts...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return out, nil return out, nil
} }
// CachePoolManagerServer is the server API for CachePoolManager service. // EnclavePoolManagerServer is the server API for EnclavePoolManager service.
// All implementations must embed UnimplementedCachePoolManagerServer // All implementations must embed UnimplementedEnclavePoolManagerServer
// for forward compatibility // for forward compatibility
type CachePoolManagerServer interface { type EnclavePoolManagerServer interface {
// GetCache represents get the specified cache metadata // GetCache represents get the specified cache metadata
GetCache(context.Context, *GetCacheRequest) (*GetCacheResponse, error) GetCache(context.Context, *GetCacheRequest) (*GetCacheResponse, error)
// SaveCache represents save the data to a cache directory and record the cache metadata // SaveCache represents save the data to a cache directory and record the cache metadata
...@@ -96,147 +96,147 @@ type CachePoolManagerServer interface { ...@@ -96,147 +96,147 @@ type CachePoolManagerServer interface {
DeleteCache(context.Context, *DeleteCacheRequest) (*DeleteCacheResponse, error) DeleteCache(context.Context, *DeleteCacheRequest) (*DeleteCacheResponse, error)
// LoadCache represents load the specified cache data to work directory // LoadCache represents load the specified cache data to work directory
LoadCache(context.Context, *LoadCacheRequest) (*LoadCacheResponse, error) LoadCache(context.Context, *LoadCacheRequest) (*LoadCacheResponse, error)
mustEmbedUnimplementedCachePoolManagerServer() mustEmbedUnimplementedEnclavePoolManagerServer()
} }
// UnimplementedCachePoolManagerServer must be embedded to have forward compatible implementations. // UnimplementedEnclavePoolManagerServer must be embedded to have forward compatible implementations.
type UnimplementedCachePoolManagerServer struct { type UnimplementedEnclavePoolManagerServer struct {
} }
func (*UnimplementedCachePoolManagerServer) GetCache(context.Context, *GetCacheRequest) (*GetCacheResponse, error) { func (*UnimplementedEnclavePoolManagerServer) GetCache(context.Context, *GetCacheRequest) (*GetCacheResponse, error) {
return nil, status.Errorf(codes.Unimplemented, "method GetCache not implemented") return nil, status.Errorf(codes.Unimplemented, "method GetCache not implemented")
} }
func (*UnimplementedCachePoolManagerServer) SaveCache(context.Context, *SaveCacheRequest) (*SaveCacheResponse, error) { func (*UnimplementedEnclavePoolManagerServer) SaveCache(context.Context, *SaveCacheRequest) (*SaveCacheResponse, error) {
return nil, status.Errorf(codes.Unimplemented, "method SaveCache not implemented") return nil, status.Errorf(codes.Unimplemented, "method SaveCache not implemented")
} }
func (*UnimplementedCachePoolManagerServer) ListCache(context.Context, *ListCacheRequest) (*ListCacheResponse, error) { func (*UnimplementedEnclavePoolManagerServer) ListCache(context.Context, *ListCacheRequest) (*ListCacheResponse, error) {
return nil, status.Errorf(codes.Unimplemented, "method ListCache not implemented") return nil, status.Errorf(codes.Unimplemented, "method ListCache not implemented")
} }
func (*UnimplementedCachePoolManagerServer) DeleteCache(context.Context, *DeleteCacheRequest) (*DeleteCacheResponse, error) { func (*UnimplementedEnclavePoolManagerServer) DeleteCache(context.Context, *DeleteCacheRequest) (*DeleteCacheResponse, error) {
return nil, status.Errorf(codes.Unimplemented, "method DeleteCache not implemented") return nil, status.Errorf(codes.Unimplemented, "method DeleteCache not implemented")
} }
func (*UnimplementedCachePoolManagerServer) LoadCache(context.Context, *LoadCacheRequest) (*LoadCacheResponse, error) { func (*UnimplementedEnclavePoolManagerServer) LoadCache(context.Context, *LoadCacheRequest) (*LoadCacheResponse, error) {
return nil, status.Errorf(codes.Unimplemented, "method LoadCache not implemented") return nil, status.Errorf(codes.Unimplemented, "method LoadCache not implemented")
} }
func (*UnimplementedCachePoolManagerServer) mustEmbedUnimplementedCachePoolManagerServer() {} func (*UnimplementedEnclavePoolManagerServer) mustEmbedUnimplementedEnclavePoolManagerServer() {}
func RegisterCachePoolManagerServer(s *grpc.Server, srv CachePoolManagerServer) { func RegisterEnclavePoolManagerServer(s *grpc.Server, srv EnclavePoolManagerServer) {
s.RegisterService(&_CachePoolManager_serviceDesc, srv) s.RegisterService(&_EnclavePoolManager_serviceDesc, srv)
} }
func _CachePoolManager_GetCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { func _EnclavePoolManager_GetCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(GetCacheRequest) in := new(GetCacheRequest)
if err := dec(in); err != nil { if err := dec(in); err != nil {
return nil, err return nil, err
} }
if interceptor == nil { if interceptor == nil {
return srv.(CachePoolManagerServer).GetCache(ctx, in) return srv.(EnclavePoolManagerServer).GetCache(ctx, in)
} }
info := &grpc.UnaryServerInfo{ info := &grpc.UnaryServerInfo{
Server: srv, Server: srv,
FullMethod: "/v1alpha1.CachePoolManager/GetCache", FullMethod: "/v1alpha1.EnclavePoolManager/GetCache",
} }
handler := func(ctx context.Context, req interface{}) (interface{}, error) { handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(CachePoolManagerServer).GetCache(ctx, req.(*GetCacheRequest)) return srv.(EnclavePoolManagerServer).GetCache(ctx, req.(*GetCacheRequest))
} }
return interceptor(ctx, in, info, handler) return interceptor(ctx, in, info, handler)
} }
func _CachePoolManager_SaveCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { func _EnclavePoolManager_SaveCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(SaveCacheRequest) in := new(SaveCacheRequest)
if err := dec(in); err != nil { if err := dec(in); err != nil {
return nil, err return nil, err
} }
if interceptor == nil { if interceptor == nil {
return srv.(CachePoolManagerServer).SaveCache(ctx, in) return srv.(EnclavePoolManagerServer).SaveCache(ctx, in)
} }
info := &grpc.UnaryServerInfo{ info := &grpc.UnaryServerInfo{
Server: srv, Server: srv,
FullMethod: "/v1alpha1.CachePoolManager/SaveCache", FullMethod: "/v1alpha1.EnclavePoolManager/SaveCache",
} }
handler := func(ctx context.Context, req interface{}) (interface{}, error) { handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(CachePoolManagerServer).SaveCache(ctx, req.(*SaveCacheRequest)) return srv.(EnclavePoolManagerServer).SaveCache(ctx, req.(*SaveCacheRequest))
} }
return interceptor(ctx, in, info, handler) return interceptor(ctx, in, info, handler)
} }
func _CachePoolManager_ListCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { func _EnclavePoolManager_ListCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(ListCacheRequest) in := new(ListCacheRequest)
if err := dec(in); err != nil { if err := dec(in); err != nil {
return nil, err return nil, err
} }
if interceptor == nil { if interceptor == nil {
return srv.(CachePoolManagerServer).ListCache(ctx, in) return srv.(EnclavePoolManagerServer).ListCache(ctx, in)
} }
info := &grpc.UnaryServerInfo{ info := &grpc.UnaryServerInfo{
Server: srv, Server: srv,
FullMethod: "/v1alpha1.CachePoolManager/ListCache", FullMethod: "/v1alpha1.EnclavePoolManager/ListCache",
} }
handler := func(ctx context.Context, req interface{}) (interface{}, error) { handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(CachePoolManagerServer).ListCache(ctx, req.(*ListCacheRequest)) return srv.(EnclavePoolManagerServer).ListCache(ctx, req.(*ListCacheRequest))
} }
return interceptor(ctx, in, info, handler) return interceptor(ctx, in, info, handler)
} }
func _CachePoolManager_DeleteCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { func _EnclavePoolManager_DeleteCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(DeleteCacheRequest) in := new(DeleteCacheRequest)
if err := dec(in); err != nil { if err := dec(in); err != nil {
return nil, err return nil, err
} }
if interceptor == nil { if interceptor == nil {
return srv.(CachePoolManagerServer).DeleteCache(ctx, in) return srv.(EnclavePoolManagerServer).DeleteCache(ctx, in)
} }
info := &grpc.UnaryServerInfo{ info := &grpc.UnaryServerInfo{
Server: srv, Server: srv,
FullMethod: "/v1alpha1.CachePoolManager/DeleteCache", FullMethod: "/v1alpha1.EnclavePoolManager/DeleteCache",
} }
handler := func(ctx context.Context, req interface{}) (interface{}, error) { handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(CachePoolManagerServer).DeleteCache(ctx, req.(*DeleteCacheRequest)) return srv.(EnclavePoolManagerServer).DeleteCache(ctx, req.(*DeleteCacheRequest))
} }
return interceptor(ctx, in, info, handler) return interceptor(ctx, in, info, handler)
} }
func _CachePoolManager_LoadCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { func _EnclavePoolManager_LoadCache_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
in := new(LoadCacheRequest) in := new(LoadCacheRequest)
if err := dec(in); err != nil { if err := dec(in); err != nil {
return nil, err return nil, err
} }
if interceptor == nil { if interceptor == nil {
return srv.(CachePoolManagerServer).LoadCache(ctx, in) return srv.(EnclavePoolManagerServer).LoadCache(ctx, in)
} }
info := &grpc.UnaryServerInfo{ info := &grpc.UnaryServerInfo{
Server: srv, Server: srv,
FullMethod: "/v1alpha1.CachePoolManager/LoadCache", FullMethod: "/v1alpha1.EnclavePoolManager/LoadCache",
} }
handler := func(ctx context.Context, req interface{}) (interface{}, error) { handler := func(ctx context.Context, req interface{}) (interface{}, error) {
return srv.(CachePoolManagerServer).LoadCache(ctx, req.(*LoadCacheRequest)) return srv.(EnclavePoolManagerServer).LoadCache(ctx, req.(*LoadCacheRequest))
} }
return interceptor(ctx, in, info, handler) return interceptor(ctx, in, info, handler)
} }
var _CachePoolManager_serviceDesc = grpc.ServiceDesc{ var _EnclavePoolManager_serviceDesc = grpc.ServiceDesc{
ServiceName: "v1alpha1.CachePoolManager", ServiceName: "v1alpha1.EnclavePoolManager",
HandlerType: (*CachePoolManagerServer)(nil), HandlerType: (*EnclavePoolManagerServer)(nil),
Methods: []grpc.MethodDesc{ Methods: []grpc.MethodDesc{
{ {
MethodName: "GetCache", MethodName: "GetCache",
Handler: _CachePoolManager_GetCache_Handler, Handler: _EnclavePoolManager_GetCache_Handler,
}, },
{ {
MethodName: "SaveCache", MethodName: "SaveCache",
Handler: _CachePoolManager_SaveCache_Handler, Handler: _EnclavePoolManager_SaveCache_Handler,
}, },
{ {
MethodName: "ListCache", MethodName: "ListCache",
Handler: _CachePoolManager_ListCache_Handler, Handler: _EnclavePoolManager_ListCache_Handler,
}, },
{ {
MethodName: "DeleteCache", MethodName: "DeleteCache",
Handler: _CachePoolManager_DeleteCache_Handler, Handler: _EnclavePoolManager_DeleteCache_Handler,
}, },
{ {
MethodName: "LoadCache", MethodName: "LoadCache",
Handler: _CachePoolManager_LoadCache_Handler, Handler: _EnclavePoolManager_LoadCache_Handler,
}, },
}, },
Streams: []grpc.StreamDesc{}, Streams: []grpc.StreamDesc{},
......
...@@ -4,26 +4,26 @@ import ( ...@@ -4,26 +4,26 @@ import (
cache_manager "github.com/alibaba/inclavare-containers/epm/pkg/epm" cache_manager "github.com/alibaba/inclavare-containers/epm/pkg/epm"
) )
type Cach0Manager struct { type BundleCach0Manager struct {
cache_manager.DefaultCachePoolManager cache_manager.DefaultEnclavePool
} }
func (d *Cach0Manager) GetCacheType() string { func (d *BundleCach0Manager) GetPoolType() string {
return "bundle-cache-pool.occlum.cache0" return "bundle-cache.occlum.cache0"
} }
type Cach1Manager struct { type BundleCach1Manager struct {
cache_manager.DefaultCachePoolManager cache_manager.DefaultEnclavePool
} }
func (d *Cach1Manager) GetCacheType() string { func (d *BundleCach1Manager) GetPoolType() string {
return "bundle-cache-pool.occlum.cache1" return "bundle-cache.occlum.cache1"
} }
type Cach2Manager struct { type BundleCach2Manager struct {
cache_manager.DefaultCachePoolManager cache_manager.DefaultEnclavePool
} }
func (d *Cach2Manager) GetCacheType() string { func (d *BundleCach2Manager) GetPoolType() string {
return "bundle-cache-pool.occlum.cache2" return "bundle-cache.occlum.cache2"
} }
...@@ -9,15 +9,15 @@ import ( ...@@ -9,15 +9,15 @@ import (
"google.golang.org/grpc/status" "google.golang.org/grpc/status"
) )
// CachePoolManagerServer represents the service that manages the cache pool managers // EnclavePoolManagerServer represents the service that manages the enclave pools
type CachePoolManagerServer struct { type EnclavePoolManagerServer struct {
v1alpha1.UnimplementedCachePoolManagerServer v1alpha1.UnimplementedEnclavePoolManagerServer
// cachePoolManagers containers the mapping of the cache type and cache pool manager // cachePools containers the mapping of the cache type and enclave pool
cachePoolManagers map[string]CachePoolManager cachePools map[string]EnclavePool
} }
// GetCache gets the specified cache metadata // GetCache gets the specified cache metadata
func (s *CachePoolManagerServer) GetCache(ctx context.Context, req *v1alpha1.GetCacheRequest) (*v1alpha1.GetCacheResponse, error) { func (s *EnclavePoolManagerServer) GetCache(ctx context.Context, req *v1alpha1.GetCacheRequest) (*v1alpha1.GetCacheResponse, error) {
manager, err := s.getCachePoolManager(req.Type) manager, err := s.getCachePoolManager(req.Type)
if err != nil { if err != nil {
return nil, status.Errorf(codes.InvalidArgument, err.Error()) return nil, status.Errorf(codes.InvalidArgument, err.Error())
...@@ -30,7 +30,7 @@ func (s *CachePoolManagerServer) GetCache(ctx context.Context, req *v1alpha1.Get ...@@ -30,7 +30,7 @@ func (s *CachePoolManagerServer) GetCache(ctx context.Context, req *v1alpha1.Get
} }
// SaveCache saves the data to a cache directory and record the cache metadata // SaveCache saves the data to a cache directory and record the cache metadata
func (s *CachePoolManagerServer) SaveCache(ctx context.Context, req *v1alpha1.SaveCacheRequest) (*v1alpha1.SaveCacheResponse, error) { func (s *EnclavePoolManagerServer) SaveCache(ctx context.Context, req *v1alpha1.SaveCacheRequest) (*v1alpha1.SaveCacheResponse, error) {
cache := req.Cache cache := req.Cache
manager, err := s.getCachePoolManager(cache.Type) manager, err := s.getCachePoolManager(cache.Type)
if err != nil { if err != nil {
...@@ -43,7 +43,7 @@ func (s *CachePoolManagerServer) SaveCache(ctx context.Context, req *v1alpha1.Sa ...@@ -43,7 +43,7 @@ func (s *CachePoolManagerServer) SaveCache(ctx context.Context, req *v1alpha1.Sa
} }
// ListCache lists part of or all of the cache metadata // ListCache lists part of or all of the cache metadata
func (s *CachePoolManagerServer) ListCache(ctx context.Context, req *v1alpha1.ListCacheRequest) (*v1alpha1.ListCacheResponse, error) { func (s *EnclavePoolManagerServer) ListCache(ctx context.Context, req *v1alpha1.ListCacheRequest) (*v1alpha1.ListCacheResponse, error) {
manager, err := s.getCachePoolManager(req.Type) manager, err := s.getCachePoolManager(req.Type)
if err != nil { if err != nil {
return nil, status.Errorf(codes.InvalidArgument, err.Error()) return nil, status.Errorf(codes.InvalidArgument, err.Error())
...@@ -56,7 +56,7 @@ func (s *CachePoolManagerServer) ListCache(ctx context.Context, req *v1alpha1.Li ...@@ -56,7 +56,7 @@ func (s *CachePoolManagerServer) ListCache(ctx context.Context, req *v1alpha1.Li
} }
// DeleteCache deletes the specified cached data and remove the corresponding cache metadata // DeleteCache deletes the specified cached data and remove the corresponding cache metadata
func (s *CachePoolManagerServer) DeleteCache(ctx context.Context, req *v1alpha1.DeleteCacheRequest) (*v1alpha1.DeleteCacheResponse, error) { func (s *EnclavePoolManagerServer) DeleteCache(ctx context.Context, req *v1alpha1.DeleteCacheRequest) (*v1alpha1.DeleteCacheResponse, error) {
manager, err := s.getCachePoolManager(req.Type) manager, err := s.getCachePoolManager(req.Type)
if err != nil { if err != nil {
return nil, status.Errorf(codes.InvalidArgument, err.Error()) return nil, status.Errorf(codes.InvalidArgument, err.Error())
...@@ -68,7 +68,7 @@ func (s *CachePoolManagerServer) DeleteCache(ctx context.Context, req *v1alpha1. ...@@ -68,7 +68,7 @@ func (s *CachePoolManagerServer) DeleteCache(ctx context.Context, req *v1alpha1.
} }
// LoadCache loads the specified cache data to work directory // LoadCache loads the specified cache data to work directory
func (s *CachePoolManagerServer) LoadCache(ctx context.Context, req *v1alpha1.LoadCacheRequest) (*v1alpha1.LoadCacheResponse, error) { func (s *EnclavePoolManagerServer) LoadCache(ctx context.Context, req *v1alpha1.LoadCacheRequest) (*v1alpha1.LoadCacheResponse, error) {
manager, err := s.getCachePoolManager(req.Type) manager, err := s.getCachePoolManager(req.Type)
if err != nil { if err != nil {
return nil, status.Errorf(codes.InvalidArgument, err.Error()) return nil, status.Errorf(codes.InvalidArgument, err.Error())
...@@ -79,17 +79,17 @@ func (s *CachePoolManagerServer) LoadCache(ctx context.Context, req *v1alpha1.Lo ...@@ -79,17 +79,17 @@ func (s *CachePoolManagerServer) LoadCache(ctx context.Context, req *v1alpha1.Lo
return &v1alpha1.LoadCacheResponse{Ok: true}, nil return &v1alpha1.LoadCacheResponse{Ok: true}, nil
} }
// RegistryCachePoolManager registry the cache pool manager to the cache pool manager server // RegisterCachePoolManager register the cache pool manager to the cache pool manager server
func (s *CachePoolManagerServer) RegistryCachePoolManager(m CachePoolManager) { func (s *EnclavePoolManagerServer) RegisterCachePoolManager(m EnclavePool) {
if s.cachePoolManagers == nil { if s.cachePools == nil {
s.cachePoolManagers = make(map[string]CachePoolManager) s.cachePools = make(map[string]EnclavePool)
} }
s.cachePoolManagers[m.GetCacheType()] = m s.cachePools[m.GetPoolType()] = m
} }
// getCachePoolManager gets the cache pool manager by the cache type // getCachePoolManager gets the cache pool manager by the cache type
func (s *CachePoolManagerServer) getCachePoolManager(cacheType string) (CachePoolManager, error) { func (s *EnclavePoolManagerServer) getCachePoolManager(cacheType string) (EnclavePool, error) {
manager, ok := s.cachePoolManagers[cacheType] manager, ok := s.cachePools[cacheType]
if ok && manager != nil { if ok && manager != nil {
return manager, nil return manager, nil
} }
......
...@@ -13,8 +13,8 @@ import ( ...@@ -13,8 +13,8 @@ import (
cache_metadata "github.com/alibaba/inclavare-containers/epm/pkg/metadata" cache_metadata "github.com/alibaba/inclavare-containers/epm/pkg/metadata"
) )
// CachePoolManager represents a cache manager // EnclavePool represents a kind of enclave pool
type CachePoolManager interface { type EnclavePool interface {
// GetCache gets the cache by ID // GetCache gets the cache by ID
GetCache(ID string) (*v1alpha1.Cache, error) GetCache(ID string) (*v1alpha1.Cache, error)
// SaveCache saves the data to a cache directory and record the cache metadata // SaveCache saves the data to a cache directory and record the cache metadata
...@@ -25,21 +25,21 @@ type CachePoolManager interface { ...@@ -25,21 +25,21 @@ type CachePoolManager interface {
DeleteCache(ID string) error DeleteCache(ID string) error
// LoadCache loads the specified cache data to work directory // LoadCache loads the specified cache data to work directory
LoadCache(ID, targetPath string) error LoadCache(ID, targetPath string) error
// GetCacheType gets the cache type of current cache pool manager // GetPoolType gets the pool type of current pool
GetCacheType() string GetPoolType() string
} }
// DefaultCachePoolManager is the default implementation of CachePoolManager // DefaultEnclavePool is the default implementation of EnclavePool
type DefaultCachePoolManager struct { type DefaultEnclavePool struct {
Root string Root string
CacheMetadata *cache_metadata.Metadata CacheMetadata *cache_metadata.Metadata
} }
func (d *DefaultCachePoolManager) GetCache(ID string) (*v1alpha1.Cache, error) { func (d *DefaultEnclavePool) GetCache(ID string) (*v1alpha1.Cache, error) {
return d.CacheMetadata.GetCache(d.GetCacheType(), ID) return d.CacheMetadata.GetCache(d.GetPoolType(), ID)
} }
func (d *DefaultCachePoolManager) SaveCache(sourcePath string, cache *v1alpha1.Cache) error { func (d *DefaultEnclavePool) SaveCache(sourcePath string, cache *v1alpha1.Cache) error {
savePath, err := d.BuildCacheSavePath(d.Root, cache) savePath, err := d.BuildCacheSavePath(d.Root, cache)
if err != nil { if err != nil {
return err return err
...@@ -64,14 +64,14 @@ func (d *DefaultCachePoolManager) SaveCache(sourcePath string, cache *v1alpha1.C ...@@ -64,14 +64,14 @@ func (d *DefaultCachePoolManager) SaveCache(sourcePath string, cache *v1alpha1.C
cache.SavePath = savePath cache.SavePath = savePath
cache.Size = size cache.Size = size
cache.Created = time.Now().Unix() cache.Created = time.Now().Unix()
return d.CacheMetadata.SaveCache(d.GetCacheType(), cache.ID, cache) return d.CacheMetadata.SaveCache(d.GetPoolType(), cache.ID, cache)
} }
func (d *DefaultCachePoolManager) ListCache(lastCacheID string, limit int32) ([]*v1alpha1.Cache, error) { func (d *DefaultEnclavePool) ListCache(lastCacheID string, limit int32) ([]*v1alpha1.Cache, error) {
return d.CacheMetadata.ListCache(d.GetCacheType(), lastCacheID, limit) return d.CacheMetadata.ListCache(d.GetPoolType(), lastCacheID, limit)
} }
func (d *DefaultCachePoolManager) DeleteCache(ID string) error { func (d *DefaultEnclavePool) DeleteCache(ID string) error {
cache, err := d.GetCache(ID) cache, err := d.GetCache(ID)
if err != nil { if err != nil {
return err return err
...@@ -79,10 +79,10 @@ func (d *DefaultCachePoolManager) DeleteCache(ID string) error { ...@@ -79,10 +79,10 @@ func (d *DefaultCachePoolManager) DeleteCache(ID string) error {
if err := os.RemoveAll(cache.SavePath); err != nil { if err := os.RemoveAll(cache.SavePath); err != nil {
return err return err
} }
return d.CacheMetadata.DeleteCache(d.GetCacheType(), ID) return d.CacheMetadata.DeleteCache(d.GetPoolType(), ID)
} }
func (d *DefaultCachePoolManager) LoadCache(ID, targetPath string) error { func (d *DefaultEnclavePool) LoadCache(ID, targetPath string) error {
cache, err := d.GetCache(ID) cache, err := d.GetCache(ID)
if err != nil { if err != nil {
return err return err
...@@ -96,11 +96,11 @@ func (d *DefaultCachePoolManager) LoadCache(ID, targetPath string) error { ...@@ -96,11 +96,11 @@ func (d *DefaultCachePoolManager) LoadCache(ID, targetPath string) error {
return nil return nil
} }
func (d *DefaultCachePoolManager) GetCacheType() string { func (d *DefaultEnclavePool) GetPoolType() string {
return "default" return "default"
} }
func (d *DefaultCachePoolManager) BuildCacheSavePath(rootDir string, cache *v1alpha1.Cache) (string, error) { func (d *DefaultEnclavePool) BuildCacheSavePath(rootDir string, cache *v1alpha1.Cache) (string, error) {
caches, err := d.CacheMetadata.GetAncestorCaches(cache) caches, err := d.CacheMetadata.GetAncestorCaches(cache)
if err != nil { if err != nil {
return "", err return "", err
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册