github.com/containerd/Containerd@v1.4.13/runtime/v2/example/example.go (about) 1 // +build linux 2 3 /* 4 Copyright The containerd Authors. 5 6 Licensed under the Apache License, Version 2.0 (the "License"); 7 you may not use this file except in compliance with the License. 8 You may obtain a copy of the License at 9 10 http://www.apache.org/licenses/LICENSE-2.0 11 12 Unless required by applicable law or agreed to in writing, software 13 distributed under the License is distributed on an "AS IS" BASIS, 14 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 See the License for the specific language governing permissions and 16 limitations under the License. 17 */ 18 19 package example 20 21 import ( 22 "context" 23 "os" 24 25 "github.com/containerd/containerd/errdefs" 26 "github.com/containerd/containerd/runtime/v2/shim" 27 taskAPI "github.com/containerd/containerd/runtime/v2/task" 28 ptypes "github.com/gogo/protobuf/types" 29 ) 30 31 var ( 32 // check to make sure the *service implements the GRPC API 33 _ = (taskAPI.TaskService)(&service{}) 34 // common response type 35 empty = &ptypes.Empty{} 36 ) 37 38 // New returns a new shim service 39 func New(ctx context.Context, id string, publisher shim.Publisher, shutdown func()) (shim.Shim, error) { 40 return &service{}, nil 41 } 42 43 type service struct { 44 } 45 46 // StartShim is a binary call that executes a new shim returning the address 47 func (s *service) StartShim(ctx context.Context, id, containerdBinary, containerdAddress, containerdTTRPCAddress string) (string, error) { 48 return "", nil 49 } 50 51 // Cleanup is a binary call that cleans up any resources used by the shim when the service crashes 52 func (s *service) Cleanup(ctx context.Context) (*taskAPI.DeleteResponse, error) { 53 return nil, errdefs.ErrNotImplemented 54 } 55 56 // Create a new container 57 func (s *service) Create(ctx context.Context, r *taskAPI.CreateTaskRequest) (_ *taskAPI.CreateTaskResponse, err error) { 58 return nil, errdefs.ErrNotImplemented 59 } 60 61 // Start the primary user process inside the container 62 func (s *service) Start(ctx context.Context, r *taskAPI.StartRequest) (*taskAPI.StartResponse, error) { 63 return nil, errdefs.ErrNotImplemented 64 } 65 66 // Delete a process or container 67 func (s *service) Delete(ctx context.Context, r *taskAPI.DeleteRequest) (*taskAPI.DeleteResponse, error) { 68 return nil, errdefs.ErrNotImplemented 69 } 70 71 // Exec an additional process inside the container 72 func (s *service) Exec(ctx context.Context, r *taskAPI.ExecProcessRequest) (*ptypes.Empty, error) { 73 return nil, errdefs.ErrNotImplemented 74 } 75 76 // ResizePty of a process 77 func (s *service) ResizePty(ctx context.Context, r *taskAPI.ResizePtyRequest) (*ptypes.Empty, error) { 78 return nil, errdefs.ErrNotImplemented 79 } 80 81 // State returns runtime state of a process 82 func (s *service) State(ctx context.Context, r *taskAPI.StateRequest) (*taskAPI.StateResponse, error) { 83 return nil, errdefs.ErrNotImplemented 84 } 85 86 // Pause the container 87 func (s *service) Pause(ctx context.Context, r *taskAPI.PauseRequest) (*ptypes.Empty, error) { 88 return nil, errdefs.ErrNotImplemented 89 } 90 91 // Resume the container 92 func (s *service) Resume(ctx context.Context, r *taskAPI.ResumeRequest) (*ptypes.Empty, error) { 93 return nil, errdefs.ErrNotImplemented 94 } 95 96 // Kill a process 97 func (s *service) Kill(ctx context.Context, r *taskAPI.KillRequest) (*ptypes.Empty, error) { 98 return nil, errdefs.ErrNotImplemented 99 } 100 101 // Pids returns all pids inside the container 102 func (s *service) Pids(ctx context.Context, r *taskAPI.PidsRequest) (*taskAPI.PidsResponse, error) { 103 return nil, errdefs.ErrNotImplemented 104 } 105 106 // CloseIO of a process 107 func (s *service) CloseIO(ctx context.Context, r *taskAPI.CloseIORequest) (*ptypes.Empty, error) { 108 return nil, errdefs.ErrNotImplemented 109 } 110 111 // Checkpoint the container 112 func (s *service) Checkpoint(ctx context.Context, r *taskAPI.CheckpointTaskRequest) (*ptypes.Empty, error) { 113 return nil, errdefs.ErrNotImplemented 114 } 115 116 // Connect returns shim information of the underlying service 117 func (s *service) Connect(ctx context.Context, r *taskAPI.ConnectRequest) (*taskAPI.ConnectResponse, error) { 118 return nil, errdefs.ErrNotImplemented 119 } 120 121 // Shutdown is called after the underlying resources of the shim are cleaned up and the service can be stopped 122 func (s *service) Shutdown(ctx context.Context, r *taskAPI.ShutdownRequest) (*ptypes.Empty, error) { 123 os.Exit(0) 124 return empty, nil 125 } 126 127 // Stats returns container level system stats for a container and its processes 128 func (s *service) Stats(ctx context.Context, r *taskAPI.StatsRequest) (*taskAPI.StatsResponse, error) { 129 return nil, errdefs.ErrNotImplemented 130 } 131 132 // Update the live container 133 func (s *service) Update(ctx context.Context, r *taskAPI.UpdateTaskRequest) (*ptypes.Empty, error) { 134 return nil, errdefs.ErrNotImplemented 135 } 136 137 // Wait for a process to exit 138 func (s *service) Wait(ctx context.Context, r *taskAPI.WaitRequest) (*taskAPI.WaitResponse, error) { 139 return nil, errdefs.ErrNotImplemented 140 }