설명 없음

Jonathan Turner 4f2d691fa5 readme update 9 년 전
asn1tools b177ae11aa doco comments 9 년 전
client 358e1cbd7f tidy 9 년 전
config a1eb49d00b refactor of crypto package 9 년 전
credentials 0b2e507d9a some refactor 9 년 전
crypto a1eb49d00b refactor of crypto package 9 년 전
iana a1eb49d00b refactor of crypto package 9 년 전
keytab 0b2e507d9a some refactor 9 년 전
messages a1eb49d00b refactor of crypto package 9 년 전
testdata 06e8e417fb encryption work 9 년 전
testenv 8c8a620d09 minor fix 9 년 전
types bc51b2e5b7 FAST negotiation 9 년 전
.gitignore 95ab435b4c initial commit 9 년 전
LICENSE caee2dc83a Initial commit 9 년 전
README.md 4f2d691fa5 readme update 9 년 전
debug.go 0a7b65fa69 tidy 9 년 전

README.md

gokrb5

This is work in progress and does not yet fully work...

GoDoc

Implemented Encryption & Checksum Types

The currently implemented encrytion types are:

Implementation Encryption ID Checksum ID
aes128-cts-hmac-sha1-96 17 15
aes256-cts-hmac-sha1-96 18 16

Usage

Configuration

The gokrb5 libraries use the same krb5.conf configuration file format as MIT Kerberos, described here. Config instances can be created by loading from a file path or by passing a string, io.Reader or bufio.Scanner to the relevant method:

import "github.com/jcmturner/gokrb5/config"
cfg, err := config.Load("/path/to/config/file")
cfg, err := config.NewConfigFromString(krb5Str) //String must have appropriate newline separations
cfg, err := config.NewConfigFromReader(reader)
cfg, err := config.NewConfigFromScanner(scanner)

Keytab files

Standard keytab files can be read from a file or from a slice of bytes:

import 	"github.com/jcmturner/gokrb5/keytab"
ktFromFile, err := keytab.Load("/path/to/file.keytab")
ktFromBytes, err := keytab.Parse(b)

Kerberos Client

Create a client instance with either a password or a keytab:

import 	"github.com/jcmturner/gokrb5/client"
cl := client.NewClientWithPassword("username", "REALM.COM", "password")
cl := client.NewClientWithKeytab("username", "REALM.COM", kt)

Provide configuration to the client:

cl.WithConfig(cfg)

Login:

err := cl.Login

(Optional) Enable automatic refresh of Kerberos Ticket Granting Ticket (TGT):

cl.EnableAutoSessionRenewal()

Request a Serivce ticket for a Service Principal Name (SPN). This method will use the client's cache either returning a valid cached ticket, renewing a cached ticket with the KDC or requesting a new ticket from the KDC. Therefore the GetServiceTicket method can be continually used for the most efficient interation with the KDC.

tkt, err := cl.GetServiceTicket("HTTP/host.test.gokrb5")

References

RFCs

Useful Links

Thanks

  • Greg Hudson from the MIT Consortium for Kerberos and Internet Trust for providing useful advice.

Known Issues

Issue Worked around? References
Golang's ASN1 package cannot unmarshal into slice of asn1.RawValue Yes https://github.com/golang/go/issues/17321
Golang's ASN1 package cannot marshal into a GeneralString Yes - using https://github.com/jcmturner/asn1 https://github.com/golang/go/issues/18832
Golang's ASN1 package cannot marshal into slice of strings and pass stringtype parameter tags to members Yes - using https://github.com/jcmturner/asn1 https://github.com/golang/go/issues/18834
Golang's ASN1 package cannot marshal with application tags Yes