czmq-ffi-gen 0.13.0-x86-mingw32 → 0.14.1-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGES.md +13 -0
- data/lib/czmq-ffi-gen/czmq/ffi.rb +224 -698
- data/lib/czmq-ffi-gen/czmq/ffi/zactor.rb +40 -7
- data/lib/czmq-ffi-gen/czmq/ffi/zargs.rb +259 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zarmour.rb +3 -3
- data/lib/czmq-ffi-gen/czmq/ffi/zcert.rb +15 -6
- data/lib/czmq-ffi-gen/czmq/ffi/zcertstore.rb +25 -11
- data/lib/czmq-ffi-gen/czmq/ffi/zchunk.rb +18 -18
- data/lib/czmq-ffi-gen/czmq/ffi/zclock.rb +6 -6
- data/lib/czmq-ffi-gen/czmq/ffi/zconfig.rb +27 -17
- data/lib/czmq-ffi-gen/czmq/ffi/zdigest.rb +4 -4
- data/lib/czmq-ffi-gen/czmq/ffi/zdir.rb +36 -36
- data/lib/czmq-ffi-gen/czmq/ffi/zdir_patch.rb +1 -1
- data/lib/czmq-ffi-gen/czmq/ffi/zfile.rb +27 -19
- data/lib/czmq-ffi-gen/czmq/ffi/zframe.rb +22 -21
- data/lib/czmq-ffi-gen/czmq/ffi/zhash.rb +54 -54
- data/lib/czmq-ffi-gen/czmq/ffi/zhashx.rb +82 -80
- data/lib/czmq-ffi-gen/czmq/ffi/ziflist.rb +30 -0
- data/lib/czmq-ffi-gen/czmq/ffi/zlist.rb +30 -30
- data/lib/czmq-ffi-gen/czmq/ffi/zlistx.rb +44 -44
- data/lib/czmq-ffi-gen/czmq/ffi/zloop.rb +39 -39
- data/lib/czmq-ffi-gen/czmq/ffi/zmsg.rb +46 -46
- data/lib/czmq-ffi-gen/czmq/ffi/zpoller.rb +16 -16
- data/lib/czmq-ffi-gen/czmq/ffi/zproc.rb +237 -34
- data/lib/czmq-ffi-gen/czmq/ffi/zsock.rb +1201 -973
- data/lib/czmq-ffi-gen/czmq/ffi/zstr.rb +58 -19
- data/lib/czmq-ffi-gen/czmq/ffi/zsys.rb +836 -0
- data/lib/czmq-ffi-gen/czmq/ffi/ztimerset.rb +6 -6
- data/lib/czmq-ffi-gen/czmq/ffi/ztrie.rb +10 -10
- data/lib/czmq-ffi-gen/czmq/ffi/zuuid.rb +4 -4
- data/lib/czmq-ffi-gen/gem_version.rb +1 -1
- data/lib/czmq-ffi-gen/vendor.rb +9 -1
- data/vendor/local/bin/inproc_lat.exe +0 -0
- data/vendor/local/bin/inproc_thr.exe +0 -0
- data/vendor/local/bin/libczmq.dll +0 -0
- data/vendor/local/bin/libzmq.dll +0 -0
- data/vendor/local/bin/local_lat.exe +0 -0
- data/vendor/local/bin/local_thr.exe +0 -0
- data/vendor/local/bin/remote_lat.exe +0 -0
- data/vendor/local/bin/remote_thr.exe +0 -0
- data/vendor/local/bin/zmakecert.exe +0 -0
- data/vendor/local/include/czmq_library.h +18 -9
- data/vendor/local/include/czmq_prelude.h +104 -16
- data/vendor/local/include/zactor.h +25 -7
- data/vendor/local/include/zarmour.h +3 -3
- data/vendor/local/include/zcert.h +11 -6
- data/vendor/local/include/zcertstore.h +18 -9
- data/vendor/local/include/zchunk.h +18 -18
- data/vendor/local/include/zclock.h +6 -6
- data/vendor/local/include/zconfig.h +25 -16
- data/vendor/local/include/zdigest.h +4 -4
- data/vendor/local/include/zdir.h +36 -36
- data/vendor/local/include/zdir_patch.h +1 -1
- data/vendor/local/include/zfile.h +27 -19
- data/vendor/local/include/zframe.h +22 -21
- data/vendor/local/include/zgossip.h +5 -5
- data/vendor/local/include/zgossip_engine.inc +103 -22
- data/vendor/local/include/zgossip_msg.h +28 -30
- data/vendor/local/include/zhash.h +53 -53
- data/vendor/local/include/zhashx.h +75 -73
- data/vendor/local/include/ziflist.h +22 -1
- data/vendor/local/include/zlist.h +28 -28
- data/vendor/local/include/zlistx.h +41 -41
- data/vendor/local/include/zloop.h +36 -36
- data/vendor/local/include/zmsg.h +46 -46
- data/vendor/local/include/zpoller.h +16 -16
- data/vendor/local/include/zsock.h +414 -364
- data/vendor/local/include/zsock_option.inc +234 -1062
- data/vendor/local/include/zstr.h +44 -19
- data/vendor/local/include/zsys.h +63 -19
- data/vendor/local/include/zuuid.h +4 -4
- data/vendor/local/lib/libczmq.dll.a +0 -0
- data/vendor/local/lib/liblibzmq.dll.a +0 -0
- data/vendor/local/lib/pkgconfig/libczmq.pc +1 -1
- metadata +6 -3
@@ -39,7 +39,7 @@ CZMQ_EXPORT void
|
|
39
39
|
zdir_patch_destroy (zdir_patch_t **self_p);
|
40
40
|
|
41
41
|
// Create copy of a patch. If the patch is null, or memory was exhausted,
|
42
|
-
// returns null.
|
42
|
+
// returns null.
|
43
43
|
// Caller owns return value and must destroy it when done.
|
44
44
|
CZMQ_EXPORT zdir_patch_t *
|
45
45
|
zdir_patch_dup (zdir_patch_t *self);
|
@@ -27,7 +27,7 @@ extern "C" {
|
|
27
27
|
// links, which are files with the extension ".ln". A symbolic link is a
|
28
28
|
// text file containing one line, the filename of a target file. Reading
|
29
29
|
// data from the symbolic link actually reads from the target file. Path
|
30
|
-
// may be NULL, in which case it is not used.
|
30
|
+
// may be NULL, in which case it is not used.
|
31
31
|
CZMQ_EXPORT zfile_t *
|
32
32
|
zfile_new (const char *path, const char *name);
|
33
33
|
|
@@ -36,7 +36,7 @@ CZMQ_EXPORT void
|
|
36
36
|
zfile_destroy (zfile_t **self_p);
|
37
37
|
|
38
38
|
// Duplicate a file item, returns a newly constructed item. If the file
|
39
|
-
// is null, or memory was exhausted, returns null.
|
39
|
+
// is null, or memory was exhausted, returns null.
|
40
40
|
// Caller owns return value and must destroy it when done.
|
41
41
|
CZMQ_EXPORT zfile_t *
|
42
42
|
zfile_dup (zfile_t *self);
|
@@ -45,23 +45,23 @@ CZMQ_EXPORT zfile_t *
|
|
45
45
|
CZMQ_EXPORT const char *
|
46
46
|
zfile_filename (zfile_t *self, const char *path);
|
47
47
|
|
48
|
-
// Refresh file properties from disk; this is not done automatically
|
48
|
+
// Refresh file properties from disk; this is not done automatically
|
49
49
|
// on access methods, otherwise it is not possible to compare directory
|
50
|
-
// snapshots.
|
50
|
+
// snapshots.
|
51
51
|
CZMQ_EXPORT void
|
52
52
|
zfile_restat (zfile_t *self);
|
53
53
|
|
54
54
|
// Return when the file was last modified. If you want this to reflect the
|
55
|
-
// current situation, call zfile_restat before checking this property.
|
55
|
+
// current situation, call zfile_restat before checking this property.
|
56
56
|
CZMQ_EXPORT time_t
|
57
57
|
zfile_modified (zfile_t *self);
|
58
58
|
|
59
59
|
// Return the last-known size of the file. If you want this to reflect the
|
60
|
-
// current situation, call zfile_restat before checking this property.
|
60
|
+
// current situation, call zfile_restat before checking this property.
|
61
61
|
CZMQ_EXPORT off_t
|
62
62
|
zfile_cursize (zfile_t *self);
|
63
63
|
|
64
|
-
// Return true if the file is a directory. If you want this to reflect
|
64
|
+
// Return true if the file is a directory. If you want this to reflect
|
65
65
|
// any external changes, call zfile_restat before checking this property.
|
66
66
|
CZMQ_EXPORT bool
|
67
67
|
zfile_is_directory (zfile_t *self);
|
@@ -72,24 +72,24 @@ CZMQ_EXPORT bool
|
|
72
72
|
zfile_is_regular (zfile_t *self);
|
73
73
|
|
74
74
|
// Return true if the file is readable by this process. If you want this to
|
75
|
-
// reflect any external changes, call zfile_restat before checking this
|
76
|
-
// property.
|
75
|
+
// reflect any external changes, call zfile_restat before checking this
|
76
|
+
// property.
|
77
77
|
CZMQ_EXPORT bool
|
78
78
|
zfile_is_readable (zfile_t *self);
|
79
79
|
|
80
|
-
// Return true if the file is writeable by this process. If you want this
|
80
|
+
// Return true if the file is writeable by this process. If you want this
|
81
81
|
// to reflect any external changes, call zfile_restat before checking this
|
82
|
-
// property.
|
82
|
+
// property.
|
83
83
|
CZMQ_EXPORT bool
|
84
84
|
zfile_is_writeable (zfile_t *self);
|
85
85
|
|
86
86
|
// Check if file has stopped changing and can be safely processed.
|
87
|
-
// Updates the file statistics from disk at every call.
|
87
|
+
// Updates the file statistics from disk at every call.
|
88
88
|
CZMQ_EXPORT bool
|
89
89
|
zfile_is_stable (zfile_t *self);
|
90
90
|
|
91
91
|
// Return true if the file was changed on disk since the zfile_t object
|
92
|
-
// was created, or the last zfile_restat() call made on it.
|
92
|
+
// was created, or the last zfile_restat() call made on it.
|
93
93
|
CZMQ_EXPORT bool
|
94
94
|
zfile_has_changed (zfile_t *self);
|
95
95
|
|
@@ -97,19 +97,19 @@ CZMQ_EXPORT bool
|
|
97
97
|
CZMQ_EXPORT void
|
98
98
|
zfile_remove (zfile_t *self);
|
99
99
|
|
100
|
-
// Open file for reading
|
100
|
+
// Open file for reading
|
101
101
|
// Returns 0 if OK, -1 if not found or not accessible
|
102
102
|
CZMQ_EXPORT int
|
103
103
|
zfile_input (zfile_t *self);
|
104
104
|
|
105
|
-
// Open file for writing, creating directory if needed
|
105
|
+
// Open file for writing, creating directory if needed
|
106
106
|
// File is created if necessary; chunks can be written to file at any
|
107
|
-
// location. Returns 0 if OK, -1 if error.
|
107
|
+
// location. Returns 0 if OK, -1 if error.
|
108
108
|
CZMQ_EXPORT int
|
109
109
|
zfile_output (zfile_t *self);
|
110
110
|
|
111
111
|
// Read chunk from file at specified position. If this was the last chunk,
|
112
|
-
// sets the eof property. Returns a null chunk in case of error.
|
112
|
+
// sets the eof property. Returns a null chunk in case of error.
|
113
113
|
// Caller owns return value and must destroy it when done.
|
114
114
|
CZMQ_EXPORT zchunk_t *
|
115
115
|
zfile_read (zfile_t *self, size_t bytes, off_t offset);
|
@@ -119,12 +119,12 @@ CZMQ_EXPORT bool
|
|
119
119
|
zfile_eof (zfile_t *self);
|
120
120
|
|
121
121
|
// Write chunk to file at specified position
|
122
|
-
// Return 0 if OK, else -1
|
122
|
+
// Return 0 if OK, else -1
|
123
123
|
CZMQ_EXPORT int
|
124
124
|
zfile_write (zfile_t *self, zchunk_t *chunk, off_t offset);
|
125
125
|
|
126
126
|
// Read next line of text from file. Returns a pointer to the text line,
|
127
|
-
// or NULL if there was nothing more to read from the file.
|
127
|
+
// or NULL if there was nothing more to read from the file.
|
128
128
|
CZMQ_EXPORT const char *
|
129
129
|
zfile_readln (zfile_t *self);
|
130
130
|
|
@@ -144,6 +144,14 @@ CZMQ_EXPORT const char *
|
|
144
144
|
CZMQ_EXPORT void
|
145
145
|
zfile_test (bool verbose);
|
146
146
|
|
147
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
148
|
+
// *** Draft method, for development use, may change without warning ***
|
149
|
+
// Create new temporary file for writing via tmpfile. File is automaticaly
|
150
|
+
// deleted on destroy
|
151
|
+
CZMQ_EXPORT zfile_t *
|
152
|
+
zfile_tmp (void);
|
153
|
+
|
154
|
+
#endif // CZMQ_BUILD_DRAFT_API
|
147
155
|
// @end
|
148
156
|
|
149
157
|
|
@@ -25,13 +25,13 @@ extern "C" {
|
|
25
25
|
// is provided in stable builds.
|
26
26
|
// This class has draft methods, which may change over time. They are not
|
27
27
|
// in stable releases, by default. Use --enable-drafts to enable.
|
28
|
-
#define ZFRAME_MORE 1 //
|
29
|
-
#define ZFRAME_REUSE 2 //
|
30
|
-
#define ZFRAME_DONTWAIT 4 //
|
28
|
+
#define ZFRAME_MORE 1 //
|
29
|
+
#define ZFRAME_REUSE 2 //
|
30
|
+
#define ZFRAME_DONTWAIT 4 //
|
31
31
|
|
32
32
|
// Create a new frame. If size is not null, allocates the frame data
|
33
|
-
// to the specified size. If additionally, data is not null, copies
|
34
|
-
// size octets from the specified data into the frame body.
|
33
|
+
// to the specified size. If additionally, data is not null, copies
|
34
|
+
// size octets from the specified data into the frame body.
|
35
35
|
CZMQ_EXPORT zframe_t *
|
36
36
|
zframe_new (const void *data, size_t size);
|
37
37
|
|
@@ -43,9 +43,9 @@ CZMQ_EXPORT zframe_t *
|
|
43
43
|
CZMQ_EXPORT zframe_t *
|
44
44
|
zframe_from (const char *string);
|
45
45
|
|
46
|
-
// Receive frame from socket, returns zframe_t object or NULL if the recv
|
46
|
+
// Receive frame from socket, returns zframe_t object or NULL if the recv
|
47
47
|
// was interrupted. Does a blocking recv, if you want to not block then use
|
48
|
-
// zpoller or zloop.
|
48
|
+
// zpoller or zloop.
|
49
49
|
CZMQ_EXPORT zframe_t *
|
50
50
|
zframe_recv (void *source);
|
51
51
|
|
@@ -54,7 +54,7 @@ CZMQ_EXPORT void
|
|
54
54
|
zframe_destroy (zframe_t **self_p);
|
55
55
|
|
56
56
|
// Send a frame to a socket, destroy frame after sending.
|
57
|
-
// Return -1 on error, 0 on success.
|
57
|
+
// Return -1 on error, 0 on success.
|
58
58
|
CZMQ_EXPORT int
|
59
59
|
zframe_send (zframe_t **self_p, void *dest, int flags);
|
60
60
|
|
@@ -66,25 +66,26 @@ CZMQ_EXPORT size_t
|
|
66
66
|
CZMQ_EXPORT byte *
|
67
67
|
zframe_data (zframe_t *self);
|
68
68
|
|
69
|
-
// Return meta data property for frame
|
70
|
-
//
|
69
|
+
// Return meta data property for frame
|
70
|
+
// The caller shall not modify or free the returned value, which shall be
|
71
|
+
// owned by the message.
|
71
72
|
CZMQ_EXPORT const char *
|
72
73
|
zframe_meta (zframe_t *self, const char *property);
|
73
74
|
|
74
75
|
// Create a new frame that duplicates an existing frame. If frame is null,
|
75
|
-
// or memory was exhausted, returns null.
|
76
|
+
// or memory was exhausted, returns null.
|
76
77
|
// Caller owns return value and must destroy it when done.
|
77
78
|
CZMQ_EXPORT zframe_t *
|
78
79
|
zframe_dup (zframe_t *self);
|
79
80
|
|
80
81
|
// Return frame data encoded as printable hex string, useful for 0MQ UUIDs.
|
81
|
-
// Caller must free string when finished with it.
|
82
|
+
// Caller must free string when finished with it.
|
82
83
|
// Caller owns return value and must destroy it when done.
|
83
84
|
CZMQ_EXPORT char *
|
84
85
|
zframe_strhex (zframe_t *self);
|
85
86
|
|
86
87
|
// Return frame data copied into freshly allocated string
|
87
|
-
// Caller must free string when finished with it.
|
88
|
+
// Caller must free string when finished with it.
|
88
89
|
// Caller owns return value and must destroy it when done.
|
89
90
|
CZMQ_EXPORT char *
|
90
91
|
zframe_strdup (zframe_t *self);
|
@@ -94,17 +95,17 @@ CZMQ_EXPORT bool
|
|
94
95
|
zframe_streq (zframe_t *self, const char *string);
|
95
96
|
|
96
97
|
// Return frame MORE indicator (1 or 0), set when reading frame from socket
|
97
|
-
// or by the zframe_set_more() method
|
98
|
+
// or by the zframe_set_more() method
|
98
99
|
CZMQ_EXPORT int
|
99
100
|
zframe_more (zframe_t *self);
|
100
101
|
|
101
102
|
// Set frame MORE indicator (1 or 0). Note this is NOT used when sending
|
102
|
-
// frame to socket, you have to specify flag explicitly.
|
103
|
+
// frame to socket, you have to specify flag explicitly.
|
103
104
|
CZMQ_EXPORT void
|
104
105
|
zframe_set_more (zframe_t *self, int more);
|
105
106
|
|
106
107
|
// Return TRUE if two frames have identical size and data
|
107
|
-
// If either frame is NULL, equality is always false.
|
108
|
+
// If either frame is NULL, equality is always false.
|
108
109
|
CZMQ_EXPORT bool
|
109
110
|
zframe_eq (zframe_t *self, zframe_t *other);
|
110
111
|
|
@@ -112,7 +113,7 @@ CZMQ_EXPORT bool
|
|
112
113
|
CZMQ_EXPORT void
|
113
114
|
zframe_reset (zframe_t *self, const void *data, size_t size);
|
114
115
|
|
115
|
-
// Send message to zsys log sink (may be stdout, or system facility as
|
116
|
+
// Send message to zsys log sink (may be stdout, or system facility as
|
116
117
|
// configured by zsys_set_logstream). Prefix shows before frame, if not null.
|
117
118
|
CZMQ_EXPORT void
|
118
119
|
zframe_print (zframe_t *self, const char *prefix);
|
@@ -128,13 +129,13 @@ CZMQ_EXPORT void
|
|
128
129
|
#ifdef CZMQ_BUILD_DRAFT_API
|
129
130
|
// *** Draft method, for development use, may change without warning ***
|
130
131
|
// Return frame routing ID, if the frame came from a ZMQ_SERVER socket.
|
131
|
-
// Else returns zero.
|
132
|
+
// Else returns zero.
|
132
133
|
CZMQ_EXPORT uint32_t
|
133
134
|
zframe_routing_id (zframe_t *self);
|
134
135
|
|
135
136
|
// *** Draft method, for development use, may change without warning ***
|
136
137
|
// Set routing ID on frame. This is used if/when the frame is sent to a
|
137
|
-
// ZMQ_SERVER socket.
|
138
|
+
// ZMQ_SERVER socket.
|
138
139
|
CZMQ_EXPORT void
|
139
140
|
zframe_set_routing_id (zframe_t *self, uint32_t routing_id);
|
140
141
|
|
@@ -145,8 +146,8 @@ CZMQ_EXPORT const char *
|
|
145
146
|
|
146
147
|
// *** Draft method, for development use, may change without warning ***
|
147
148
|
// Set group on frame. This is used if/when the frame is sent to a
|
148
|
-
// ZMQ_RADIO socket.
|
149
|
-
// Return -1 on error, 0 on success.
|
149
|
+
// ZMQ_RADIO socket.
|
150
|
+
// Return -1 on error, 0 on success.
|
150
151
|
CZMQ_EXPORT int
|
151
152
|
zframe_set_group (zframe_t *self, const char *group);
|
152
153
|
|
@@ -10,13 +10,13 @@
|
|
10
10
|
* The XML model used for this code generation: zgossip.xml, or
|
11
11
|
* The code generation script that built this file: zproto_server_c
|
12
12
|
************************************************************************
|
13
|
-
Copyright (c) the Contributors as noted in the AUTHORS file.
|
14
|
-
This file is part of CZMQ, the high-level C binding for 0MQ:
|
15
|
-
http://czmq.zeromq.org.
|
16
|
-
|
13
|
+
Copyright (c) the Contributors as noted in the AUTHORS file.
|
14
|
+
This file is part of CZMQ, the high-level C binding for 0MQ:
|
15
|
+
http://czmq.zeromq.org.
|
16
|
+
|
17
17
|
This Source Code Form is subject to the terms of the Mozilla Public
|
18
18
|
License, v. 2.0. If a copy of the MPL was not distributed with this
|
19
|
-
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
19
|
+
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
20
20
|
=========================================================================
|
21
21
|
*/
|
22
22
|
|
@@ -10,16 +10,22 @@
|
|
10
10
|
* The XML model used for this code generation: zgossip.xml, or
|
11
11
|
* The code generation script that built this file: zproto_server_c
|
12
12
|
************************************************************************
|
13
|
-
Copyright (c) the Contributors as noted in the AUTHORS file.
|
14
|
-
This file is part of CZMQ, the high-level C binding for 0MQ:
|
15
|
-
http://czmq.zeromq.org.
|
16
|
-
|
13
|
+
Copyright (c) the Contributors as noted in the AUTHORS file.
|
14
|
+
This file is part of CZMQ, the high-level C binding for 0MQ:
|
15
|
+
http://czmq.zeromq.org.
|
16
|
+
|
17
17
|
This Source Code Form is subject to the terms of the Mozilla Public
|
18
18
|
License, v. 2.0. If a copy of the MPL was not distributed with this
|
19
|
-
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
19
|
+
file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
20
20
|
=========================================================================
|
21
21
|
*/
|
22
22
|
|
23
|
+
#ifdef NDEBUG
|
24
|
+
#undef NDEBUG
|
25
|
+
#endif
|
26
|
+
|
27
|
+
#define ZPROTO_UNUSED(object) (void)object
|
28
|
+
|
23
29
|
// ---------------------------------------------------------------------------
|
24
30
|
// State machine constants
|
25
31
|
|
@@ -113,10 +119,14 @@ static void
|
|
113
119
|
server_terminate (server_t *self);
|
114
120
|
static zmsg_t *
|
115
121
|
server_method (server_t *self, const char *method, zmsg_t *msg);
|
122
|
+
static void
|
123
|
+
server_configuration (server_t *self, zconfig_t *config);
|
116
124
|
static int
|
117
125
|
client_initialize (client_t *self);
|
118
126
|
static void
|
119
127
|
client_terminate (client_t *self);
|
128
|
+
static void
|
129
|
+
s_server_config_global (s_server_t *server);
|
120
130
|
static void
|
121
131
|
s_client_execute (s_client_t *client, event_t event);
|
122
132
|
static int
|
@@ -237,15 +247,29 @@ engine_handle_socket (server_t *server, void *sock, zloop_reader_fn handler)
|
|
237
247
|
}
|
238
248
|
|
239
249
|
// Register monitor function that will be called at regular intervals
|
240
|
-
// by the server engine
|
250
|
+
// by the server engine. Returns an identifier that can be used to cancel it.
|
241
251
|
|
242
|
-
static
|
252
|
+
static int
|
243
253
|
engine_set_monitor (server_t *server, size_t interval, zloop_timer_fn monitor)
|
244
254
|
{
|
245
255
|
if (server) {
|
246
256
|
s_server_t *self = (s_server_t *) server;
|
247
257
|
int rc = zloop_timer (self->loop, interval, 0, monitor, self);
|
248
258
|
assert (rc >= 0);
|
259
|
+
return rc;
|
260
|
+
}
|
261
|
+
|
262
|
+
return -1;
|
263
|
+
}
|
264
|
+
|
265
|
+
// Cancel the monitor function with the given identifier.
|
266
|
+
static void
|
267
|
+
engine_cancel_monitor (server_t *server, int identifier)
|
268
|
+
{
|
269
|
+
if (server) {
|
270
|
+
s_server_t *self = (s_server_t *) server;
|
271
|
+
int rc = zloop_timer_end (self->loop, identifier);
|
272
|
+
assert (rc >= 0);
|
249
273
|
}
|
250
274
|
}
|
251
275
|
|
@@ -257,7 +281,7 @@ engine_set_log_prefix (client_t *client, const char *string)
|
|
257
281
|
{
|
258
282
|
if (client) {
|
259
283
|
s_client_t *self = (s_client_t *) client;
|
260
|
-
snprintf (self->log_prefix, sizeof (self->log_prefix)
|
284
|
+
snprintf (self->log_prefix, sizeof (self->log_prefix),
|
261
285
|
"%6d:%-33s", self->unique_id, string);
|
262
286
|
}
|
263
287
|
}
|
@@ -272,6 +296,7 @@ engine_configure (server_t *server, const char *path, const char *value)
|
|
272
296
|
if (server) {
|
273
297
|
s_server_t *self = (s_server_t *) server;
|
274
298
|
zconfig_put (self->config, path, value);
|
299
|
+
s_server_config_global (self);
|
275
300
|
}
|
276
301
|
}
|
277
302
|
|
@@ -300,6 +325,7 @@ s_satisfy_pedantic_compilers (void)
|
|
300
325
|
engine_broadcast_event (NULL, NULL, NULL_event);
|
301
326
|
engine_handle_socket (NULL, 0, NULL);
|
302
327
|
engine_set_monitor (NULL, 0, NULL);
|
328
|
+
engine_cancel_monitor (NULL, 0);
|
303
329
|
engine_set_log_prefix (NULL, NULL);
|
304
330
|
engine_configure (NULL, NULL, NULL);
|
305
331
|
engine_verbose (NULL);
|
@@ -641,6 +667,8 @@ s_client_handle_ticket (zloop_t *loop, int timer_id, void *argument)
|
|
641
667
|
static int
|
642
668
|
s_client_handle_wakeup (zloop_t *loop, int timer_id, void *argument)
|
643
669
|
{
|
670
|
+
ZPROTO_UNUSED(loop);
|
671
|
+
ZPROTO_UNUSED(timer_id);
|
644
672
|
s_client_t *self = (s_client_t *) argument;
|
645
673
|
s_client_execute (self, self->wakeup_event);
|
646
674
|
return 0;
|
@@ -656,17 +684,17 @@ s_server_config_global (s_server_t *self)
|
|
656
684
|
//
|
657
685
|
// If we didn't already set verbose, check if the config tree wants it
|
658
686
|
if (!self->verbose
|
659
|
-
&& atoi (
|
687
|
+
&& atoi (zconfig_get (self->config, "server/verbose", "0")))
|
660
688
|
self->verbose = true;
|
661
689
|
|
662
690
|
// Default client timeout is 60 seconds
|
663
691
|
self->timeout = atoi (
|
664
|
-
|
692
|
+
zconfig_get (self->config, "server/timeout", "60000"));
|
665
693
|
zloop_set_ticket_delay (self->loop, self->timeout);
|
666
694
|
|
667
695
|
// Do we want to run server in the background?
|
668
696
|
int background = atoi (
|
669
|
-
|
697
|
+
zconfig_get (self->config, "server/background", "0"));
|
670
698
|
if (!background)
|
671
699
|
zsys_set_logstream (stdout);
|
672
700
|
}
|
@@ -740,15 +768,15 @@ s_server_config_service (s_server_t *self)
|
|
740
768
|
zsys_notice ("%s", zconfig_value (section));
|
741
769
|
else
|
742
770
|
if (streq (zconfig_name (section), "bind")) {
|
743
|
-
char *endpoint =
|
771
|
+
char *endpoint = zconfig_get (section, "endpoint", "?");
|
744
772
|
if (zsock_bind (self->router, "%s", endpoint) == -1)
|
745
773
|
zsys_warning ("could not bind to %s (%s)", endpoint, zmq_strerror (zmq_errno ()));
|
746
774
|
}
|
747
775
|
#if (ZMQ_VERSION_MAJOR >= 4)
|
748
776
|
else
|
749
777
|
if (streq (zconfig_name (section), "security")) {
|
750
|
-
char *mechanism =
|
751
|
-
char *domain =
|
778
|
+
char *mechanism = zconfig_get (section, "mechanism", "null");
|
779
|
+
char *domain = zconfig_get (section, "domain", NULL);
|
752
780
|
if (streq (mechanism, "null")) {
|
753
781
|
zsys_notice ("server is using NULL security");
|
754
782
|
if (domain)
|
@@ -759,6 +787,22 @@ s_server_config_service (s_server_t *self)
|
|
759
787
|
zsys_notice ("server is using PLAIN security");
|
760
788
|
zsock_set_plain_server (self->router, 1);
|
761
789
|
}
|
790
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
791
|
+
// TODO- zproto
|
792
|
+
// https://github.com/zeromq/zproto/blob/master/src/zproto_server_c.gsl#L883
|
793
|
+
else
|
794
|
+
if (streq (mechanism, "curve")) {
|
795
|
+
zsys_notice ("using CURVE security");
|
796
|
+
const char *keyfile = zconfig_get (section, "secret-key", NULL);
|
797
|
+
assert (keyfile);
|
798
|
+
|
799
|
+
zcert_t *server_cert = zcert_load(keyfile);
|
800
|
+
assert (server_cert);
|
801
|
+
|
802
|
+
zcert_apply (server_cert, self->router);
|
803
|
+
zsock_set_curve_server (self->router, 1);
|
804
|
+
}
|
805
|
+
#endif
|
762
806
|
else
|
763
807
|
zsys_warning ("mechanism=%s is not supported", mechanism);
|
764
808
|
}
|
@@ -773,6 +817,9 @@ s_server_config_service (s_server_t *self)
|
|
773
817
|
static int
|
774
818
|
s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
775
819
|
{
|
820
|
+
ZPROTO_UNUSED(loop);
|
821
|
+
ZPROTO_UNUSED(reader);
|
822
|
+
|
776
823
|
s_server_t *self = (s_server_t *) argument;
|
777
824
|
zmsg_t *msg = zmsg_recv (self->pipe);
|
778
825
|
if (!msg)
|
@@ -786,7 +833,7 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
786
833
|
else
|
787
834
|
if (streq (method, "$TERM")) {
|
788
835
|
// Shutdown the engine
|
789
|
-
|
836
|
+
zstr_free (&method);
|
790
837
|
zmsg_destroy (&msg);
|
791
838
|
return -1;
|
792
839
|
}
|
@@ -794,10 +841,30 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
794
841
|
if (streq (method, "BIND")) {
|
795
842
|
// Bind to a specified endpoint, which may use an ephemeral port
|
796
843
|
char *endpoint = zmsg_popstr (msg);
|
844
|
+
|
845
|
+
#ifdef CZMQ_BUILD_DRAFT_API
|
846
|
+
// TODO- expose self->router to application context ?
|
847
|
+
// Add secret|public|zap to gsl(?)
|
848
|
+
// move this block to custom server function when both keys are present
|
849
|
+
if (self->server.secret_key) {
|
850
|
+
zsock_set_zap_domain (self->router, self->server.zap_domain);
|
851
|
+
zcert_t *cert = zcert_new_from_txt(self->server.public_key, self->server.secret_key);
|
852
|
+
zcert_apply(cert, self->router);
|
853
|
+
zsock_set_curve_server (self->router, 1);
|
854
|
+
zcert_destroy(&cert);
|
855
|
+
}
|
856
|
+
// TODO- add this test in zproto_server_c.gsl
|
857
|
+
#ifndef ZMQ_CURVE
|
858
|
+
// zmq legacy
|
859
|
+
bool ZMQ_CURVE = false;
|
860
|
+
#endif
|
861
|
+
if (self->server.secret_key)
|
862
|
+
assert (zsock_mechanism (self->router) == ZMQ_CURVE);
|
863
|
+
#endif
|
797
864
|
self->port = zsock_bind (self->router, "%s", endpoint);
|
798
865
|
if (self->port == -1)
|
799
866
|
zsys_warning ("could not bind to %s", endpoint);
|
800
|
-
|
867
|
+
zstr_free (&endpoint);
|
801
868
|
}
|
802
869
|
else
|
803
870
|
if (streq (method, "PORT")) {
|
@@ -813,12 +880,13 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
813
880
|
if (self->config) {
|
814
881
|
s_server_config_service (self);
|
815
882
|
self->server.config = self->config;
|
883
|
+
server_configuration (&self->server, self->config);
|
816
884
|
}
|
817
885
|
else {
|
818
886
|
zsys_warning ("cannot load config file '%s'", filename);
|
819
887
|
self->config = zconfig_new ("root", NULL);
|
820
888
|
}
|
821
|
-
|
889
|
+
zstr_free (&filename);
|
822
890
|
}
|
823
891
|
else
|
824
892
|
if (streq (method, "SET")) {
|
@@ -830,15 +898,15 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
830
898
|
self->verbose = (atoi (value) == 1);
|
831
899
|
}
|
832
900
|
s_server_config_global (self);
|
833
|
-
|
834
|
-
|
901
|
+
zstr_free (&value);
|
902
|
+
zstr_free (&path);
|
835
903
|
}
|
836
904
|
else
|
837
905
|
if (streq (method, "SAVE")) {
|
838
906
|
char *filename = zmsg_popstr (msg);
|
839
907
|
if (zconfig_save (self->config, filename))
|
840
908
|
zsys_warning ("cannot save config file '%s'", filename);
|
841
|
-
|
909
|
+
zstr_free (&filename);
|
842
910
|
}
|
843
911
|
else {
|
844
912
|
// Execute custom method
|
@@ -846,7 +914,7 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
846
914
|
// If reply isn't null, send it to caller
|
847
915
|
zmsg_send (&reply, self->pipe);
|
848
916
|
}
|
849
|
-
|
917
|
+
zstr_free (&method);
|
850
918
|
zmsg_destroy (&msg);
|
851
919
|
return 0;
|
852
920
|
}
|
@@ -856,13 +924,18 @@ s_server_handle_pipe (zloop_t *loop, zsock_t *reader, void *argument)
|
|
856
924
|
static int
|
857
925
|
s_server_handle_protocol (zloop_t *loop, zsock_t *reader, void *argument)
|
858
926
|
{
|
927
|
+
ZPROTO_UNUSED(loop);
|
928
|
+
ZPROTO_UNUSED(reader);
|
929
|
+
|
859
930
|
s_server_t *self = (s_server_t *) argument;
|
860
931
|
// We process as many messages as we can, to reduce the overhead
|
861
932
|
// of polling and the reactor:
|
862
933
|
while (zsock_events (self->router) & ZMQ_POLLIN) {
|
863
|
-
|
934
|
+
int rc = zgossip_msg_recv (self->message, self->router);
|
935
|
+
if (rc == -1)
|
864
936
|
return -1; // Interrupted; exit zloop
|
865
937
|
|
938
|
+
|
866
939
|
// TODO: use binary hashing on routing_id
|
867
940
|
char *hashkey = zframe_strhex (zgossip_msg_routing_id (self->message));
|
868
941
|
s_client_t *client = (s_client_t *) zhash_lookup (self->clients, hashkey);
|
@@ -876,6 +949,10 @@ s_server_handle_protocol (zloop_t *loop, zsock_t *reader, void *argument)
|
|
876
949
|
if (client->ticket)
|
877
950
|
zloop_ticket_reset (self->loop, client->ticket);
|
878
951
|
|
952
|
+
if (rc == -2) {
|
953
|
+
continue; // Malformed, but malformed_event doesn't exist
|
954
|
+
// -> discard the message
|
955
|
+
}
|
879
956
|
// Pass to client state machine
|
880
957
|
s_client_execute (client, s_protocol_event (self->message));
|
881
958
|
}
|
@@ -887,11 +964,15 @@ s_server_handle_protocol (zloop_t *loop, zsock_t *reader, void *argument)
|
|
887
964
|
static int
|
888
965
|
s_watch_server_config (zloop_t *loop, int timer_id, void *argument)
|
889
966
|
{
|
967
|
+
ZPROTO_UNUSED(loop);
|
968
|
+
ZPROTO_UNUSED(timer_id);
|
969
|
+
|
890
970
|
s_server_t *self = (s_server_t *) argument;
|
891
971
|
if (zconfig_has_changed (self->config)
|
892
972
|
&& zconfig_reload (&self->config) == 0) {
|
893
973
|
s_server_config_service (self);
|
894
974
|
self->server.config = self->config;
|
975
|
+
server_configuration (&self->server, self->config);
|
895
976
|
zsys_notice ("reloaded configuration from %s",
|
896
977
|
zconfig_filename (self->config));
|
897
978
|
}
|