/
net_discover.lua
113 lines (112 loc) · 5.09 KB
/
net_discover.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
-- net_discover
-- @short: Probe or monitor for compatible hosts or clients on the network
-- @inargs: function:callback
-- @inargs: int:mode, int:trust, function:callback
-- @inargs: int:mode, int:trust, string:description, function:handler(source, status)
-- @outargs:
-- @longdescr: this function is used to find other sources or sinks on the network
-- which implement the a12 protocol. Each time a connection is discovered, the
-- *callback* function is invoked with whatever that could be discerned.
--
-- The short argument form uses whatever implementation defined default detection
-- mechanism that is available, with the TRUST_KNOWN level of trust.
-- For more refined control, the *mode* argument can be set to one of the following:
-- DISCOVER_PASSIVE, DISCOVER_SWEEP, DISCOVER_BROADCAST, DISCOVER_DIRECTORY or
-- DISCOVER_TEST.
--
-- DISCOVER_PASSIVE silently listens on available network interfaces (or ones
-- specified through the *description* argument) for broadcasting clients.
--
-- DISCOVER_BROADCAST periodically announces its presence in a privacy
-- preserving way, assuming that the trust model is set to TRUST_KNOWN.
--
-- DISCOVER_SWEEP cycles through the set of trusted keys, looking for the first
-- possible host for each keyset. The *description* arguments accepts a
-- delay=n:period=m form where the delay is a number in seconds between each
-- attempted keyset, and period delay in seconds between sweeps.
--
-- DISCOVER_DIRECTORY uses a directory server to discover which devices are
-- currently available. This mode can punch through NATed networks and is
-- suitable for wide-area network use where you have access to a remote trusted
-- server. The *description* argument is used to reference the directory server
-- to open.
--
-- DISCOVER_TEST generates fake discovery/lost events, both valid and invalid,
-- at increasingly longer intervals in order to provide testing and automation
-- without causing any network traffic.
--
-- the *trust* argment changes how the discover modes based on a specified
-- trust model, which can be one of the following: TRUST_KNOWN,
-- TRUST_PERMIT_UNKNOWN, TRUST_TRANSITIVE.
--
-- TRUST_KNOWN will only forward and reply to messages that comes from
-- previously known and trusted sources. Known sources are managed through an
-- external keystore, see the arcan-net tool.
--
-- TRUST_PERMIT_UNKNOWN (for broadcast, passive and directory) allows
-- interactive verification whether a certain connection should be trusted or
-- not.
--
-- TRUST_TRANSITIVE (for directory) allows viewing and temporary or permanentily
-- trusting connections that comes from an intermediary dictionary server.
--
-- The callback *handler* provides the source vid as well as a status table.
-- This behaves similar to other ref:launch_target style callbacks. The set of
-- useful events is reduced to kind=terminated, and kind=state as the ones
-- of relevance.
--
-- @tblent: "state" {string:name, string:namespace, bool:lost, bool:discovered,
-- bool:bad, bool:source, bool:sink, bool: directory, bool:appl}.
--
-- Name is a user-presentable identifier for the network resource that has
-- changed state. The interpretation of name is governed by the *namespace*
-- (tag, basename, subname, ipv4, ipv6, a12pub). Tag is a user-defined entry in
-- the local keystore, while basename/subname is a breakdown of components in a
-- fully qualified domain name. Multiple events may be used to provide a
-- complete reverse entry: basename.basename.subname (com.example.local) and is
-- terminated with an zero-length base- or subname.
--
-- If the *namespace* is a12pub, there is also a base64 coded form of the
-- public key presented as 'kpub'. This is useful when requesting to open that
-- as a source specifically where there might be ambiguity (directory) or a
-- change of petname (directory and broadcast discover).
--
-- The (source, sink and directory) states describe the capabilities of the
-- discovered node. If none of them are set, the capabilities could not be
-- derived from the detection method. A source can provide data, a sink expects
-- to be provided data. A directory can be used to launch a new discovery
-- action, as well as proxy a connection to other sources and sinks. It can
-- also provide other arcan appls that can be launched through ref:net_open
-- and act as a state store for appls and launch targets.
--
-- Bad should normally never be set. If it is, it means that the afsrv_net
-- process used to delegate the discovery process has provided events with
-- unexpected values and should be investigated.
--
-- @note: Due to the asynchronous nature of discovery requests, it is possible
-- to receive lost=true without first having discovered the name in question.
--
-- @note: specifying an invalid value for *trust* or *mode* is a terminal state
-- transition.
-- @group: network
-- @cfunction: net_discover
-- @related:
function main()
#ifdef MAIN
net_discover(
function(source, status)
if status.kind == "terminated" then
delete_image(source)
return shutdown()
elseif status.kind ~= "state" then
return
end
for k,v in pairs(status) do
print(k, v)
end
end
)
#endif
#ifdef ERROR1
#endif
end