// Copyright (C) 2018-2020 LEAP // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . package bonafide import ( "errors" "fmt" "io/ioutil" ) type anonymousAuthentication struct { client httpClient authURI string certURI string } func (a *anonymousAuthentication) needsCredentials() bool { return true } func (a *anonymousAuthentication) getPemCertificate(cred *credentials) ([]byte, error) { resp, err := a.client.Post(certAPI, "", nil) if err != nil { return nil, err } defer resp.Body.Close() if resp.StatusCode == 404 { resp, err = a.client.Post(certAPI3, "", nil) if err != nil { return nil, err } defer resp.Body.Close() } if resp.StatusCode != 200 { return nil, fmt.Errorf("Get vpn cert has failed with status: %s", resp.Status) } return ioutil.ReadAll(resp.Body) } func (a *anonymousAuthentication) getToken(cred *credentials) ([]byte, error) { return []byte(""), errors.New("anon authentication should not call getToken") }