Nimkerberos is a Nim wrapper for the WinKerberos library.
Nimkerberos is distributed as a Nimble package and depends on nimgen and c2nim to generate the wrappers. The WinKerberos source code is downloaded using Git so having git
in the path is required.
Installation
Nimkerberos can be installed via Nimble:
> nimble install nimkerberos
This will download, wrap and install nimkerberos in the standard Nimble package location, typically ~/.nimble. Once installed, it can be imported into any Nim program.
Usage
Module documentation can be found here.
import nimkerberos/kerberos_sspi
var ctxt: sspi_client_state
var ret = auth_sspi_client_init(
newWideCString("NTLM"), 0, nil, 0, nil, 0, nil, 0, newWideCString("Negotiate"), addr ctxt)
assert ret == AUTH_GSS_COMPLETE
ret = auth_sspi_client_step(addr ctxt, "".cstring, nil)
assert ret == 0
echo ctxt.response
destroy_sspi_client_state(addr ctxt)
The kerberos_sspi.h functions are directly accessible at this time. A higher level API as provided by WinKerberos for Python is still TBD.
Refer to the tests
directory for examples on how the library can be used.
Credits
Nimkerberos wraps the WinKerberos source code and all licensing terms of WinKerberos apply to the usage of this package.
Credits go out to c2nim as well without which this package would be greatly limited in its abilities.
Feedback
Nimkerberos is a work in progress and any feedback or suggestions are welcome. It is hosted on GitHub with an MIT license so issues, forks and PRs are most appreciated.