-int send_meta(connection_t *c, char *buffer, int length)
-{
- char *bufp;
- int outlen;
- char outbuf[MAXBUFSIZE];
- int result;
-
- cp();
-
- if(debug_lvl >= DEBUG_META)
- syslog(LOG_DEBUG, _("Sending %d bytes of metadata to %s (%s)"), length,
- c->name, c->hostname);
-
- if(c->status.encryptout) {
- EVP_EncryptUpdate(c->outctx, outbuf, &outlen, buffer, length);
- bufp = outbuf;
- length = outlen;
- } else
- bufp = buffer;
-
- while(length) {
- result = write(c->socket, bufp, length);
- if(result <= 0) {
- if(errno == EINTR)
- continue;
- syslog(LOG_ERR, _("Sending meta data to %s (%s) failed: %s"), c->name,
- c->hostname, strerror(errno));
- return -1;
- }
- bufp += result;
- length -= result;
+bool send_meta_sptps(void *handle, uint8_t type, const void *buffer, size_t length) {
+ (void)type;
+
+ assert(handle);
+ assert(buffer);
+ assert(length);
+
+ connection_t *c = handle;
+ meshlink_handle_t *mesh = c->mesh;
+
+ buffer_add(&c->outbuf, (const char *)buffer, length);
+ io_set(&mesh->loop, &c->io, IO_READ | IO_WRITE);
+
+ return true;
+}
+
+bool send_meta(meshlink_handle_t *mesh, connection_t *c, const char *buffer, int length) {
+ assert(c);
+ assert(buffer);
+ assert(length);
+
+ logger(mesh, MESHLINK_DEBUG, "Sending %d bytes of metadata to %s", length, c->name);
+
+ if(c->allow_request == ID) {
+ buffer_add(&c->outbuf, buffer, length);
+ io_set(&mesh->loop, &c->io, IO_READ | IO_WRITE);
+ return true;