extern "C" {
#endif
-enum OSRF_SESSION_STATE {
+enum OSRF_SESSION_STATE {
OSRF_SESSION_CONNECTING,
OSRF_SESSION_CONNECTED,
OSRF_SESSION_DISCONNECTED
/** Callback function for freeing user's session data. */
void (*userDataFree) (void*);
- int transport_error;
+ int transport_error;
/** Hash table of pending requests. */
osrfAppRequest* request_hash[ OSRF_REQUEST_HASH_SIZE ];
/** Boolean: true if the app wants to terminate the process. Typically this means that */
/** a drone has lost its database connection and can therefore no longer function. */
int panic;
+
+ /** Buffer used by server drone to collect outbound response messages */
+ growing_buffer* outbuf;
};
typedef struct osrf_app_session_struct osrfAppSession;
int osrf_app_session_request_resend( osrfAppSession*, int request_id );
+int osrfSendTransportPayload( osrfAppSession* session, const char* payload );
+
void osrf_app_session_reset_remote( osrfAppSession* );
void osrf_app_session_set_remote( osrfAppSession* session, const char* remote_id );
session->session_locale = NULL;
session->transport_error = 0;
session->panic = 0;
+ session->outbuf = NULL; // Not used by client
#ifdef ASSUME_STATELESS
session->stateless = 1;
// to the compile-time macro ASSUME_STATELESS.
int stateless = 0;
char* statel = osrf_settings_host_value("/apps/%s/stateless", our_app );
- if(statel) stateless = atoi(statel);
+ if( statel )
+ stateless = atoi( statel );
free(statel);
session->remote_id = strdup(remote_id);
session->userData = NULL;
session->userDataFree = NULL;
+ session->transport_error = 0;
// Initialize the hash table
int i;
for( i = 0; i < OSRF_REQUEST_HASH_SIZE; ++i )
session->request_hash[ i ] = NULL;
+ session->panic = 0;
+ session->outbuf = buffer_init( 4096 );
+
_osrf_app_session_push_session( session );
return session;
}
}
}
- // Bundle all the osrfMessages into a single transport_message, then send it.
+ // Translate the collection of osrfMessages into a JSON array
char* string = osrfMessageSerializeBatch(msgs, size);
+ // Send the JSON as the payload of a transport_message
if( string ) {
+ retval = osrfSendTransportPayload( session, string );
+ free(string);
+ }
+
+ return retval;
+}
- transport_message* t_msg = message_init(
- string, "", session->session_id, session->remote_id, NULL );
- message_set_osrf_xid( t_msg, osrfLogGetXid() );
+/**
+ @brief Wrap a given string in a transport message and send it.
+ @param session Pointer to the osrfAppSession responsible for sending the message(s).
+ @param payload A string to be sent via Jabber.
+ @return 0 upon success, or -1 upon failure.
- retval = client_send_message( session->transport_handle, t_msg );
- if( retval )
- osrfLogError(OSRF_LOG_MARK, "client_send_message failed");
+ In practice the payload is normally a JSON string, but this function assumes nothing
+ about it.
+*/
+int osrfSendTransportPayload( osrfAppSession* session, const char* payload ) {
+ transport_message* t_msg = message_init(
+ payload, "", session->session_id, session->remote_id, NULL );
+ message_set_osrf_xid( t_msg, osrfLogGetXid() );
- osrfLogInfo(OSRF_LOG_MARK, "[%s] sent %d bytes of data to %s",
- session->remote_service, strlen(string), t_msg->recipient );
+ int retval = client_send_message( session->transport_handle, t_msg );
+ if( retval )
+ osrfLogError( OSRF_LOG_MARK, "client_send_message failed" );
- osrfLogDebug(OSRF_LOG_MARK, "Sent: %s", string );
+ osrfLogInfo(OSRF_LOG_MARK, "[%s] sent %d bytes of data to %s",
+ session->remote_service, strlen( payload ), t_msg->recipient );
- free(string);
- message_free( t_msg );
- }
+ osrfLogDebug( OSRF_LOG_MARK, "Sent: %s", payload );
+ message_free( t_msg );
return retval;
}
app = next;
}
}
+
+ if( session->outbuf )
+ buffer_free( session->outbuf );
+
free(session);
}