debug.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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/service"
  9. "github.com/jcmturner/gokrb5/testdata"
  10. "io/ioutil"
  11. "log"
  12. "net/http"
  13. "net/http/httptest"
  14. "os"
  15. "time"
  16. )
  17. const krb5conf = `[libdefaults]
  18. default_realm = TEST.GOKRB5
  19. dns_lookup_realm = false
  20. dns_lookup_kdc = false
  21. ticket_lifetime = 3m
  22. renew_lifetime = 7m
  23. forwardable = yes
  24. default_tkt_enctypes = aes256-cts-hmac-sha1-96
  25. [realms]
  26. TEST.GOKRB5 = {
  27. kdc = 10.80.88.88:88
  28. admin_server = 10.80.88.88:749
  29. default_domain = test.gokrb5
  30. }
  31. [domain_realm]
  32. .test.gokrb5 = TEST.GOKRB5
  33. test.gokrb5 = TEST.GOKRB5
  34. `
  35. func main() {
  36. s := httpServer(false)
  37. defer s.Close()
  38. //httpRequest("http://host.test.gokrb5/index.html")
  39. httpRequest(s.URL)
  40. //runClient()
  41. }
  42. func runClient() {
  43. b, err := hex.DecodeString(testdata.TESTUSER1_KEYTAB)
  44. kt, _ := keytab.Parse(b)
  45. c, _ := config.NewConfigFromString(krb5conf)
  46. cl := client.NewClientWithKeytab("testuser1", "TEST.GOKRB5", kt)
  47. cl.WithConfig(c)
  48. err = cl.Login()
  49. if err != nil {
  50. fmt.Fprintf(os.Stderr, "Error on AS_REQ: %v\n", err)
  51. }
  52. cl.EnableAutoSessionRenewal()
  53. for i := 0; i < 15; i++ {
  54. tkt, _, err := cl.GetServiceTicket("HTTP/host.test.gokrb5")
  55. if err != nil {
  56. fmt.Fprintf(os.Stderr, "Error on TGS_REQ: %v\n", err)
  57. } else {
  58. fmt.Fprintf(os.Stdout, "Service Ticket: %+v\n", tkt)
  59. }
  60. time.Sleep(time.Duration(1) * time.Minute)
  61. }
  62. }
  63. func httpRequest(url string) {
  64. b, err := hex.DecodeString(testdata.TESTUSER1_KEYTAB)
  65. kt, _ := keytab.Parse(b)
  66. c, _ := config.NewConfigFromString(krb5conf)
  67. cl := client.NewClientWithKeytab("testuser1", "TEST.GOKRB5", kt)
  68. cl.WithConfig(c)
  69. err = cl.Login()
  70. if err != nil {
  71. fmt.Fprintf(os.Stderr, "Error on AS_REQ: %v\n", err)
  72. }
  73. r, _ := http.NewRequest("GET", url, nil)
  74. err = cl.SetSPNEGOHeader(r, "HTTP/host.test.gokrb5")
  75. if err != nil {
  76. fmt.Fprintf(os.Stderr, "Error setting client SPNEGO header: %v", err)
  77. }
  78. httpResp, err := http.DefaultClient.Do(r)
  79. fmt.Fprintf(os.Stderr, "Request error: %v\n", err)
  80. fmt.Fprintf(os.Stdout, "RESPONSE CODE: %v\n", httpResp.StatusCode)
  81. content, _ := ioutil.ReadAll(httpResp.Body)
  82. fmt.Fprintf(os.Stdout, "ResponseBody: %s\n", content)
  83. }
  84. func httpServer(tls bool) *httptest.Server {
  85. l := log.New(os.Stderr, "GOKRB5: ", log.Ldate|log.Ltime|log.Lshortfile)
  86. ks := "0502000000580002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d0360300120020c2bcd4abcde0d2608d5f505e7ab5dc92df5f627e5819703c0b0f1d2c05d51c1600000003000000480002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d0360300110010da152175c7a73f49e5ce4ece7068856400000003000000500002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d03603001000187fc8ef5276e083da6bf89e676d7f98fd1acb9ec2cb20083d00000003000000480002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d0360300170010011f2ef8e75e8378a94154beb002163200000003000000580002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d03603001a0020f9db4e36aad9688d9ea30dbcc269c7ee46bf4f8bd6250f203a9f3836f0a673a600000003000000480002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d0360300190010434981c9dce61ae1012f808bb60fc1c900000003000000400002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d03603000800080b0d4f31e061529800000003000000400002000b544553542e474f4b5242350004485454500010686f73742e746573742e676f6b7262350000000158e7d0360300030008f7df40f457aec42c00000003"
  87. b, _ := hex.DecodeString(ks)
  88. kt, _ := keytab.Parse(b)
  89. th := http.HandlerFunc(testAppHandler)
  90. if tls {
  91. s := httptest.NewTLSServer(service.SPNEGOKRB5Authenticate(th, kt, l))
  92. return s
  93. } else {
  94. s := httptest.NewServer(service.SPNEGOKRB5Authenticate(th, kt, l))
  95. return s
  96. }
  97. }
  98. func testAppHandler(w http.ResponseWriter, r *http.Request) {
  99. w.WriteHeader(http.StatusOK)
  100. fmt.Fprintln(w, "TEST.GOKRB5 Handler")
  101. }