debug.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package main
  2. import (
  3. "encoding/hex"
  4. "fmt"
  5. "github.com/jcmturner/gokrb5/client"
  6. "github.com/jcmturner/gokrb5/config"
  7. "github.com/jcmturner/gokrb5/keytab"
  8. "github.com/jcmturner/gokrb5/testdata"
  9. "os"
  10. "time"
  11. )
  12. const krb5conf = `[libdefaults]
  13. default_realm = TEST.GOKRB5
  14. dns_lookup_realm = false
  15. dns_lookup_kdc = false
  16. ticket_lifetime = 3m
  17. renew_lifetime = 7m
  18. forwardable = yes
  19. default_tkt_enctypes = aes256-cts-hmac-sha1-96
  20. [realms]
  21. TEST.GOKRB5 = {
  22. kdc = 10.80.88.88:88
  23. admin_server = 10.80.88.88:749
  24. default_domain = test.gokrb5
  25. }
  26. [domain_realm]
  27. .test.gokrb5 = TEST.GOKRB5
  28. test.gokrb5 = TEST.GOKRB5
  29. `
  30. func main() {
  31. runClient()
  32. }
  33. func runClient() {
  34. b, err := hex.DecodeString(testdata.TESTUSER1_KEYTAB)
  35. kt, _ := keytab.Parse(b)
  36. c, _ := config.NewConfigFromString(krb5conf)
  37. cl := client.NewClientWithKeytab("testuser1", "TEST.GOKRB5", kt)
  38. cl.WithConfig(c)
  39. err = cl.Login()
  40. if err != nil {
  41. fmt.Fprintf(os.Stderr, "Error on AS_REQ: %v\n", err)
  42. }
  43. cl.EnableAutoSessionRenewal()
  44. for i := 0; i < 15; i++ {
  45. tkt, err := cl.GetServiceTicket("HTTP/host.test.gokrb5")
  46. if err != nil {
  47. fmt.Fprintf(os.Stderr, "Error on TGS_REQ: %v\n", err)
  48. } else {
  49. fmt.Fprintf(os.Stdout, "Service Ticket: %+v\n", tkt)
  50. }
  51. time.Sleep(time.Duration(1) * time.Minute)
  52. }
  53. }