1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
package examples
import (
"bufio"
"fmt"
"log"
"net/url"
"os"
"github.com/packethost/packngo"
)
func GetPacketOtpSms(c *packngo.Client) (string, error) {
_, err := c.TwoFactorAuth.ReceiveSms()
if err != nil {
return "", err
}
reader := bufio.NewReader(os.Stdin)
fmt.Print("Enter SMS code: ")
otp, err := reader.ReadString('\n')
if err != nil {
return "", err
}
return otp[:len(otp)-1], nil
}
func SeedPacketOtpApp(c *packngo.Client) (string, error) {
otpUri, _, err := c.TwoFactorAuth.SeedApp()
if err != nil {
return "", err
}
log.Println("OTP URI:", otpUri)
u, err := url.Parse(otpUri)
if err != nil {
return "", err
}
q := u.Query()
log.Println("Secret for 2FA App:", q["secret"][0])
reader := bufio.NewReader(os.Stdin)
fmt.Print("Enter Packet 2FA App code: ")
otp, err := reader.ReadString('\n')
if err != nil {
return "", err
}
return otp[:len(otp)-1], nil
}
func GetOtpApp(c *packngo.Client) (string, error) {
reader := bufio.NewReader(os.Stdin)
fmt.Print("Enter 2FA App code: ")
otp, err := reader.ReadString('\n')
if err != nil {
return "", err
}
return otp[:len(otp)-1], nil
}
func TestSMSEnable() {
c, err := packngo.NewClient()
if err != nil {
log.Fatal(err)
}
otp, err := GetPacketOtpSms(c)
if err != nil {
log.Fatal(err)
}
_, err = c.TwoFactorAuth.EnableSms(otp)
if err != nil {
log.Fatal(err)
}
log.Println("SMS enabled")
otp, err = GetPacketOtpSms(c)
if err != nil {
log.Fatal(err)
}
_, err = c.TwoFactorAuth.DisableSms(otp)
if err != nil {
log.Fatal(err)
}
log.Println("SMS disabled")
}
func TestAppEnable() {
c, err := packngo.NewClient()
if err != nil {
log.Fatal(err)
}
otp, err := SeedPacketOtpApp(c)
if err != nil {
log.Fatal(err)
}
_, err = c.TwoFactorAuth.EnableApp(otp)
if err != nil {
log.Fatal(err)
}
log.Println("App enabled")
otp, err = GetOtpApp(c)
if err != nil {
log.Fatal(err)
}
_, err = c.TwoFactorAuth.DisableApp(otp)
if err != nil {
log.Fatal(err)
}
log.Println("App disabled")
}
|