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.
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.
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.
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.