From 0eb1b3f9a83dfbe2f3001fd3d9cec497a352b9af Mon Sep 17 00:00:00 2001 From: Phil Sutter Date: Wed, 24 Oct 2018 12:35:03 +0200 Subject: json: Fix osf ttl support Having to use numerical values for ttl property in JSON is not practical as these values are arbitrary and meaningful only in netfilter. Instead align JSON output/input with standard API, accepting names for TTL matching strategy. Also add missing documentation in libnftables-json man page and fix JSON equivalent in tests/py. Fixes: 03eafe098d5ee ("osf: add ttl option support") Signed-off-by: Phil Sutter Signed-off-by: Pablo Neira Ayuso --- doc/libnftables-json.adoc | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'doc/libnftables-json.adoc') diff --git a/doc/libnftables-json.adoc b/doc/libnftables-json.adoc index 98303b35..ea5fbe81 100644 --- a/doc/libnftables-json.adoc +++ b/doc/libnftables-json.adoc @@ -1288,3 +1288,27 @@ ____ ____ Construct a reference to packet's socket. + +=== OSF +[verse] +____ +*{ "osf": { + "key":* 'OSF_KEY'*, + "ttl":* 'OSF_TTL' +*}}* + +'OSF_KEY' := *"name"* +'OSF_TTL' := *"loose"* | *"skip"* +____ + +Perform OS fingerprinting. This expression is typically used in LHS of a *match* +statement. + +*key*:: + What part of the fingerprint info to match against. At this point, only + the OS name is supported. +*ttl*:: + Define how packet's TTL value is to be matched. This property is + optional. If omitted, TTL value has to match exactly. A value of *loose* + accepts TTL values less than the fingerprint one. A value of *skip* + omits TTL value comparison entirely. -- cgit v1.2.3