Commit graph

68 commits

Author SHA1 Message Date
Rodolphe Bréard
2070712b50 Add trace logs for handshake registration 2020-12-20 15:10:05 +01:00
Rodolphe Bréard
9fcc02ef5b Register all missing events and filters 2020-12-20 15:01:07 +01:00
Rodolphe Bréard
b33f65fd44 Fix the line buffer that was flooded with extra \0 2020-12-20 14:35:35 +01:00
Rodolphe Bréard
53e5c929ca Render a pretty hexdump in the logs 2020-12-20 14:34:30 +01:00
Rodolphe Bréard
f7edffc6cc Log to a file instead of stderr 2020-12-20 14:31:09 +01:00
Rodolphe Bréard
f7729365e7 Add trace log for each line read 2020-12-20 11:52:56 +01:00
Rodolphe Bréard
5d32a8924c Add some tests 2020-11-28 14:23:15 +01:00
Rodolphe Bréard
1ac792ed6b Add the data-line filter 2020-11-28 12:10:22 +01:00
Rodolphe Bréard
0a4ac5a709 Fix build status 2020-11-26 18:16:54 +01:00
Rodolphe Bréard
8d4d6d9419 Set Rust minimal version to 1.43 2020-11-26 12:20:58 +01:00
Rodolphe Bréard
386d4f3446 Add a minimal documentation 2020-11-25 19:29:33 +01:00
Rodolphe Bréard
dafea54dbb Log exclusively on stderr
OpenSMTPD reads filter responses on stdout, hence there must not be any
log written to this file descriptor.
2020-11-25 18:53:50 +01:00
Rodolphe Bréard
c431d5e9cc Add the Travis CI configuration 2020-11-25 18:48:16 +01:00
Rodolphe Bréard
a6d4dd21c1 Rewrite the project
The previous project architecture was far too complicated and hard to
maintain. The new one is much more simple. Although procedural macros
are cools, they are a no-go on Rust-OpenSMTPD.

Reports and filter are implemented (except data-line) but untested.
2020-11-25 18:04:16 +01:00
Rodolphe Bréard
fc072743ad
Merge pull request #3 from breard-r/dependabot/cargo/nom-6.0
Update nom requirement from 5.0 to 6.0
2020-11-02 19:19:43 +01:00
dependabot-preview[bot]
4447fe2ef9
Update nom requirement from 5.0 to 6.0
Updates the requirements on [nom](https://github.com/Geal/nom) to permit the latest version.
- [Release notes](https://github.com/Geal/nom/releases)
- [Changelog](https://github.com/Geal/nom/blob/master/CHANGELOG.md)
- [Commits](https://github.com/Geal/nom/compare/5.0.0...6.0.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2020-11-02 04:25:43 +00:00
Rodolphe Breard
fdc8bd3dc4 Add filter-level and session-level contexts 2019-09-18 20:43:46 +02:00
Rodolphe Breard
995c0c35c1 Improve the simple_filter macro
The simple_filter macro must accept the two different levels of
contexts. In the same way, it should also accept the log level, and
therefore replace the now removed simple_filter_log_level macro.
2019-09-18 14:52:21 +02:00
Rodolphe Breard
789a41b51e Add the filter proc macro 2019-09-17 20:22:07 +02:00
Rodolphe Breard
2dff22062c Move OpenSmtpdAttributes to a dedicated module 2019-09-17 19:59:06 +02:00
Rodolphe Breard
24c0253f88 Implement the register_events method 2019-09-17 19:38:41 +02:00
Rodolphe Breard
6b532242ef Return an error if end of file is reached on stdin 2019-09-17 17:50:51 +02:00
Rodolphe Breard
dfa61a9eaa Replace .find().is_some() by .any() 2019-09-17 17:45:59 +02:00
Rodolphe Breard
c08c5c0895 Retry read if interrupted
https://doc.rust-lang.org/std/io/trait.Read.html#tymethod.read
2019-09-17 17:43:11 +02:00
Rodolphe Breard
681563934a Reset the "force_read" flag 2019-09-17 17:11:30 +02:00
Rodolphe Breard
45639f18c0 Refactor the library
Threads are a bad idea because for now the filter API is not guaranteed
to be state-less. The interface is now synchronous, which should be
enough for most filters.
The refactoring brought other changes, the most important being the
concept of modular input sources and output destination and the complete
rewrite of the procedural macro.
2019-09-17 16:45:04 +02:00
Rodolphe Breard
988f028c23 Update the readme 2019-07-11 23:58:43 +02:00
Rodolphe Breard
0f917e0132 Parse the token after the session id 2019-07-11 23:42:05 +02:00
Rodolphe Breard
d76d60650a Implement the ToString trait for TimeVal instead of a custon function 2019-07-11 23:32:47 +02:00
Rodolphe Breard
9dbd90a083 Add the link-auth report 2019-07-11 23:05:15 +02:00
Rodolphe Breard
4bfca1411b Add the link-reset report 2019-07-11 23:00:45 +02:00
Rodolphe Breard
40c99af086 Store parameters as a vector of strings instead of an option 2019-07-11 22:42:58 +02:00
Rodolphe Breard
ec5aabcf99 Use more specific structs to represent an entry 2019-07-11 22:19:09 +02:00
Rodolphe Breard
a9fb623791 Add a more complete single events-only session 2019-07-11 19:20:06 +02:00
Rodolphe Breard
1faa101778 Move the response to a dedicated file 2019-07-11 12:25:51 +02:00
Rodolphe Breard
eed8f88e2b Move the session handler to a dedicated file 2019-07-11 12:25:19 +02:00
Rodolphe Breard
a9e4a697f7 Fix clippy warning 2019-06-29 17:35:56 +02:00
Rodolphe Breard
f9dc368137 Improve the coding style 2019-06-29 17:32:31 +02:00
Rodolphe Breard
4a99257263 Upgrading to nom 5 2019-06-29 17:29:52 +02:00
Rodolphe Breard
866298c948 Updating nom to 4.2 2019-03-03 15:23:31 +01:00
Rodolphe Breard
22c376930b Format code with cargo fmt 2019-01-18 19:10:12 +01:00
Rodolphe Breard
8173cb282a Switch to the MIT or Apache 2.0 license 2019-01-18 19:08:40 +01:00
Rodolphe Breard
c20fadf99d Alias event as report
This alias is made so people with OpenSMTPD filters knowledge will
directly understand that events are reports.
2019-01-17 20:05:31 +01:00
Rodolphe Breard
ae8b64941e Add a logger
OpenSMTPD plans to gather all logs from filters. Therefore, a default
logger that implements the smtpd (future) log interface has to be
available.
2019-01-17 19:53:04 +01:00
Rodolphe Breard
4b1f99db7e Allow the use of custom context
The main goal of events/reports is to update a context object, which
will be used in filters to generate a response. It is now possible to
use any object implementing both Clone and Default as a context object.
It is also possible to define no context at all.
2019-01-12 23:43:02 +01:00
Rodolphe Breard
dd7f4d1a86 Remove the Response from the events callback
Events, also known as reports, do not generate responses. Responses must
therefore be limited to filters, which are not implemented yet.
2019-01-12 12:58:01 +01:00
Rodolphe Breard
82fe5e24de Add the report registration 2019-01-12 10:42:37 +01:00
Rodolphe Breard
11f3712138 Add a context object the callbacks
Many filters requires to keep a state within a session. Although it not
currently possible to do so, the callback now accept a mutable object of
type NoContext. This is the first step, the next one will be to accept
any type that implements both Clone and Default.
An other step will be to allow the user to define different callback
parameters depending on his/her needs.
2019-01-12 00:17:59 +01:00
Rodolphe Breard
ea710408d4 Cleanup the code 2019-01-06 17:07:00 +01:00
Rodolphe Breard
45dc882b49 Remove useless use of methods 2019-01-06 16:40:53 +01:00