Ticket_test.go 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. package messages
  2. import (
  3. "bytes"
  4. "encoding/hex"
  5. "fmt"
  6. "log"
  7. "testing"
  8. "time"
  9. "github.com/stretchr/testify/assert"
  10. "gopkg.in/jcmturner/gokrb5.v7/iana"
  11. "gopkg.in/jcmturner/gokrb5.v7/iana/addrtype"
  12. "gopkg.in/jcmturner/gokrb5.v7/iana/adtype"
  13. "gopkg.in/jcmturner/gokrb5.v7/iana/nametype"
  14. "gopkg.in/jcmturner/gokrb5.v7/iana/trtype"
  15. "gopkg.in/jcmturner/gokrb5.v7/keytab"
  16. "gopkg.in/jcmturner/gokrb5.v7/test/testdata"
  17. "gopkg.in/jcmturner/gokrb5.v7/types"
  18. )
  19. func TestUnmarshalTicket(t *testing.T) {
  20. t.Parallel()
  21. var a Ticket
  22. b, err := hex.DecodeString(testdata.MarshaledKRB5ticket)
  23. if err != nil {
  24. t.Fatalf("Test vector read error: %v", err)
  25. }
  26. err = a.Unmarshal(b)
  27. if err != nil {
  28. t.Fatalf("Unmarshal error: %v", err)
  29. }
  30. assert.Equal(t, iana.PVNO, a.TktVNO, "Ticket version number not as expected")
  31. assert.Equal(t, testdata.TEST_REALM, a.Realm, "Realm not as expected")
  32. assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.SName.NameType, "CName NameType not as expected")
  33. assert.Equal(t, len(testdata.TEST_PRINCIPALNAME_NAMESTRING), len(a.SName.NameString), "SName does not have the expected number of NameStrings")
  34. assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.SName.NameString, "SName name strings not as expected")
  35. assert.Equal(t, testdata.TEST_ETYPE, a.EncPart.EType, "Etype of Ticket EncPart not as expected")
  36. assert.Equal(t, iana.PVNO, a.EncPart.KVNO, "KNVO of Ticket EncPart not as expected")
  37. assert.Equal(t, []byte(testdata.TEST_CIPHERTEXT), a.EncPart.Cipher, "Cipher of Ticket EncPart not as expected")
  38. }
  39. func TestUnmarshalEncTicketPart(t *testing.T) {
  40. t.Parallel()
  41. var a EncTicketPart
  42. b, err := hex.DecodeString(testdata.MarshaledKRB5enc_tkt_part)
  43. if err != nil {
  44. t.Fatalf("Test vector read error: %v", err)
  45. }
  46. err = a.Unmarshal(b)
  47. if err != nil {
  48. t.Fatalf("Unmarshal error: %v", err)
  49. }
  50. //Parse the test time value into a time.Time type
  51. tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
  52. assert.Equal(t, "fedcba98", hex.EncodeToString(a.Flags.Bytes), "Flags not as expected")
  53. assert.Equal(t, int32(1), a.Key.KeyType, "Key type not as expected")
  54. assert.Equal(t, []byte("12345678"), a.Key.KeyValue, "Key value not as expected")
  55. assert.Equal(t, testdata.TEST_REALM, a.CRealm, "CRealm not as expected")
  56. assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.CName.NameType, "CName type not as expected")
  57. assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.CName.NameString, "CName string entries not as expected")
  58. assert.Equal(t, trtype.DOMAIN_X500_COMPRESS, a.Transited.TRType, "Transisted type not as expected")
  59. assert.Equal(t, []byte("EDU,MIT.,ATHENA.,WASHINGTON.EDU,CS."), a.Transited.Contents, "Transisted content not as expected")
  60. assert.Equal(t, tt, a.AuthTime, "Auth time not as expected")
  61. assert.Equal(t, tt, a.StartTime, "Start time not as expected")
  62. assert.Equal(t, tt, a.EndTime, "End time not as expected")
  63. assert.Equal(t, tt, a.RenewTill, "Renew Till time not as expected")
  64. assert.Equal(t, 2, len(a.CAddr), "Number of client addresses not as expected")
  65. for i, addr := range a.CAddr {
  66. assert.Equal(t, addrtype.IPv4, addr.AddrType, fmt.Sprintf("Host address type not as expected for address item %d", i+1))
  67. assert.Equal(t, "12d00023", hex.EncodeToString(addr.Address), fmt.Sprintf("Host address not as expected for address item %d", i+1))
  68. }
  69. for i, ele := range a.AuthorizationData {
  70. assert.Equal(t, adtype.ADIfRelevant, ele.ADType, fmt.Sprintf("Authorization data type of element %d not as expected", i+1))
  71. assert.Equal(t, []byte(testdata.TEST_AUTHORIZATION_DATA_VALUE), ele.ADData, fmt.Sprintf("Authorization data of element %d not as expected", i+1))
  72. }
  73. }
  74. func TestUnmarshalEncTicketPart_optionalsNULL(t *testing.T) {
  75. t.Parallel()
  76. var a EncTicketPart
  77. b, err := hex.DecodeString(testdata.MarshaledKRB5enc_tkt_partOptionalsNULL)
  78. if err != nil {
  79. t.Fatalf("Test vector read error: %v", err)
  80. }
  81. err = a.Unmarshal(b)
  82. if err != nil {
  83. t.Fatalf("Unmarshal error: %v", err)
  84. }
  85. //Parse the test time value into a time.Time type
  86. tt, _ := time.Parse(testdata.TEST_TIME_FORMAT, testdata.TEST_TIME)
  87. assert.Equal(t, "fedcba98", hex.EncodeToString(a.Flags.Bytes), "Flags not as expected")
  88. assert.Equal(t, int32(1), a.Key.KeyType, "Key type not as expected")
  89. assert.Equal(t, []byte("12345678"), a.Key.KeyValue, "Key value not as expected")
  90. assert.Equal(t, testdata.TEST_REALM, a.CRealm, "CRealm not as expected")
  91. assert.Equal(t, nametype.KRB_NT_PRINCIPAL, a.CName.NameType, "CName type not as expected")
  92. assert.Equal(t, testdata.TEST_PRINCIPALNAME_NAMESTRING, a.CName.NameString, "CName string entries not as expected")
  93. assert.Equal(t, trtype.DOMAIN_X500_COMPRESS, a.Transited.TRType, "Transisted type not as expected")
  94. assert.Equal(t, []byte("EDU,MIT.,ATHENA.,WASHINGTON.EDU,CS."), a.Transited.Contents, "Transisted content not as expected")
  95. assert.Equal(t, tt, a.AuthTime, "Auth time not as expected")
  96. assert.Equal(t, tt, a.EndTime, "End time not as expected")
  97. }
  98. func TestMarshalTicket(t *testing.T) {
  99. t.Parallel()
  100. var a Ticket
  101. b, err := hex.DecodeString(testdata.MarshaledKRB5ticket)
  102. if err != nil {
  103. t.Fatalf("Test vector read error: %v", err)
  104. }
  105. err = a.Unmarshal(b)
  106. if err != nil {
  107. t.Fatalf("Unmarshal error: %v", err)
  108. }
  109. mb, err := a.Marshal()
  110. if err != nil {
  111. t.Fatalf("Marshal of ticket errored: %v", err)
  112. }
  113. assert.Equal(t, b, mb, "Marshalled bytes not as expected")
  114. }
  115. func TestAuthorizationData_GetPACType_GOKRB5TestData(t *testing.T) {
  116. t.Parallel()
  117. b, err := hex.DecodeString(testdata.MarshaledPAC_AuthorizationData_GOKRB5)
  118. if err != nil {
  119. t.Fatalf("Test vector read error: %v", err)
  120. }
  121. var a types.AuthorizationData
  122. err = a.Unmarshal(b)
  123. if err != nil {
  124. t.Fatalf("Error unmarshaling test data: %v", err)
  125. }
  126. tkt := Ticket{
  127. Realm: "TEST.GOKRB5",
  128. EncPart: types.EncryptedData{
  129. EType: 18,
  130. KVNO: 2,
  131. },
  132. DecryptedEncPart: EncTicketPart{
  133. AuthorizationData: a,
  134. },
  135. }
  136. b, _ = hex.DecodeString(testdata.SYSHTTP_KEYTAB)
  137. kt := keytab.New()
  138. kt.Unmarshal(b)
  139. sname := types.PrincipalName{NameType: nametype.KRB_NT_PRINCIPAL, NameString: []string{"sysHTTP"}}
  140. w := bytes.NewBufferString("")
  141. l := log.New(w, "", 0)
  142. isPAC, pac, err := tkt.GetPACType(kt, &sname, l)
  143. if err != nil {
  144. t.Log(w.String())
  145. t.Errorf("error getting PAC: %v", err)
  146. }
  147. assert.True(t, isPAC, "PAC should be present")
  148. assert.Equal(t, 5, len(pac.Buffers), "Number of buffers not as expected")
  149. assert.Equal(t, uint32(5), pac.CBuffers, "Count of buffers not as expected")
  150. assert.Equal(t, uint32(0), pac.Version, "PAC version not as expected")
  151. assert.NotNil(t, pac.KerbValidationInfo, "PAC Kerb Validation info is nil")
  152. assert.NotNil(t, pac.ClientInfo, "PAC Client Info info is nil")
  153. assert.NotNil(t, pac.UPNDNSInfo, "PAC UPN DNS Info info is nil")
  154. assert.NotNil(t, pac.KDCChecksum, "PAC KDC Checksum info is nil")
  155. assert.NotNil(t, pac.ServerChecksum, "PAC Server checksum info is nil")
  156. }