| // Copyright 2020 The Monogon Project Authors. |
| // |
| // SPDX-License-Identifier: Apache-2.0 |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| package api |
| |
| import ( |
| "context" |
| "errors" |
| "fmt" |
| |
| schema "git.monogon.dev/source/nexantic.git/core/generated/api" |
| ) |
| |
| const ( |
| MinNameLength = 3 |
| ) |
| |
| var ( |
| ErrInvalidProvisioningToken = errors.New("invalid provisioning token") |
| ErrInvalidNameLength = fmt.Errorf("name must be at least %d characters long", MinNameLength) |
| ) |
| |
| func (s *Server) Setup(c context.Context, r *schema.SetupRequest) (*schema.SetupResponse, error) { |
| return &schema.SetupResponse{}, nil |
| } |
| |
| func (s *Server) BootstrapNewCluster(context.Context, *schema.BootstrapNewClusterRequest) (*schema.BootstrapNewClusterResponse, error) { |
| err := s.setupService.SetupNewCluster() |
| return &schema.BootstrapNewClusterResponse{}, err |
| } |
| |
| func (s *Server) JoinCluster(ctx context.Context, req *schema.JoinClusterRequest) (*schema.JoinClusterResponse, error) { |
| // Verify provisioning token |
| if s.setupService.GetJoinClusterToken() != req.ProvisioningToken { |
| return nil, ErrInvalidProvisioningToken |
| } |
| |
| // Join cluster |
| err := s.setupService.JoinCluster(req.InitialCluster, req.Certs) |
| if err != nil { |
| return nil, err |
| } |
| |
| return &schema.JoinClusterResponse{}, nil |
| } |
| |
| func (s *Server) Attest(c context.Context, r *schema.AttestRequest) (*schema.AttestResponse, error) { |
| // TODO implement |
| return &schema.AttestResponse{ |
| Response: r.Challenge, |
| }, nil |
| } |