https://github.com/rusticata/kerberos-parser
Kerberos parser written in rust with nom
https://github.com/rusticata/kerberos-parser
Last synced: 4 months ago
JSON representation
Kerberos parser written in rust with nom
- Host: GitHub
- URL: https://github.com/rusticata/kerberos-parser
- Owner: rusticata
- License: apache-2.0
- Created: 2018-03-11T19:52:01.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2025-11-24T18:16:33.000Z (7 months ago)
- Last Synced: 2026-02-12T09:53:40.613Z (4 months ago)
- Language: Rust
- Size: 84 KB
- Stars: 15
- Watchers: 3
- Forks: 4
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README

[](./LICENSE-MIT)
[](./LICENSE-APACHE)
[](https://travis-ci.org/rusticata/kerberos-parser)
[](https://crates.io/crates/kerberos-parser)
# Kerberos Parser
A Kerberos v5 ([RFC4120]) parser, implemented with the [nom](https://github.com/Geal/nom)
parser combinator framework.
The code is available on [Github](https://github.com/rusticata/kerberos-parser).
Specific parsing functions are provided for Kerberos message types. For ex. to parse a
KRB_AS_REQ message, use [`parse_as_req`](krb5_parser/fn.parse_as_req.html).
# Examples
Parsing a KRB_AS_REQ message:
```rust
use kerberos_parser::krb5::MessageType;
use kerberos_parser::krb5_parser::parse_as_req;
static AS_REQ: &'static [u8] = include_bytes!("../assets/as-req.bin");
let res = parse_as_req(AS_REQ);
match res {
Ok((rem, kdc_req)) => {
assert!(rem.is_empty());
//
assert_eq!(kdc_req.msg_type, MessageType::KRB_AS_REQ);
},
_ => panic!("KRB_AS_REQ parsing failed: {:?}", res),
}
```
[RFC4120]: https://tools.ietf.org/html/rfc4120
## Rusticata
This parser is part of the [rusticata](https://github.com/rusticata) project.
The goal of this project is to provide **safe** parsers, that can be used in other projects.
Testing of the parser is done manually, and also using unit tests and
[cargo-fuzz](https://github.com/rust-fuzz/cargo-fuzz). Please fill a bugreport if you find any issue.
Feel free to contribute: tests, feedback, doc, suggestions (or code) of new parsers etc. are welcome.
## License
Licensed under either of
* Apache License, Version 2.0
([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
## Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.