github.com/sacloud/libsacloud/v2@v2.32.3/helper/service/certificateauthority/utils.go (about) 1 // Copyright 2016-2022 The Libsacloud Authors 2 // 3 // Licensed under the Apache License, Version 2.0 (the "License"); 4 // you may not use this file except in compliance with the License. 5 // You may obtain a copy of the License at 6 // 7 // http://www.apache.org/licenses/LICENSE-2.0 8 // 9 // Unless required by applicable law or agreed to in writing, software 10 // distributed under the License is distributed on an "AS IS" BASIS, 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 // See the License for the specific language governing permissions and 13 // limitations under the License. 14 15 package certificateauthority 16 17 import ( 18 "context" 19 20 "github.com/sacloud/libsacloud/v2/sacloud" 21 "github.com/sacloud/libsacloud/v2/sacloud/types" 22 ) 23 24 func read(ctx context.Context, apiClient sacloud.CertificateAuthorityAPI, id types.ID) (*CertificateAuthority, error) { 25 current, err := apiClient.Read(ctx, id) 26 if err != nil { 27 return nil, err 28 } 29 ca := &CertificateAuthority{CertificateAuthority: *current} 30 31 // detail 32 detail, err := apiClient.Detail(ctx, id) 33 if err != nil { 34 return nil, err 35 } 36 ca.Detail = detail 37 38 // clients 39 clients, err := apiClient.ListClients(ctx, id) 40 if err != nil { 41 return nil, err 42 } 43 for _, c := range clients.CertificateAuthority { 44 if c.IssueState != "revoked" && c.IssueState != "deny" { 45 ca.Clients = append(ca.Clients, c) 46 } 47 } 48 49 // servers 50 servers, err := apiClient.ListServers(ctx, id) 51 if err != nil { 52 return nil, err 53 } 54 for _, s := range servers.CertificateAuthority { 55 if s.IssueState != "revoked" && s.IssueState != "deny" { 56 ca.Servers = append(ca.Servers, s) 57 } 58 } 59 60 return ca, nil 61 }