4 #include <readline/readline.h>
5 #include "opensrf/utils.h"
6 #include "opensrf/osrf_system.h"
7 #include "opensrf/osrf_app_session.h"
8 #include "openils/oils_event.h"
9 #include "openils/oils_utils.h"
12 char* authtoken = NULL;
14 int do_request( char* request );
15 char* format_response( jsonObject* o );
17 int main( int argc, char* argv[] ) {
20 char* username = NULL;
21 char* password = NULL;
24 char* idl_filename = NULL;
27 while( (c = getopt( argc, argv, "f:u:p:s:c:i:" )) != -1 ) {
30 case 'f': config = strdup(optarg);
31 case 'c': context = strdup(optarg);
32 case 'u': username = strdup(optarg);
33 case 'p': password = strdup(optarg);
34 case 's': script = strdup(optarg);
35 case 'i': idl_filename = strdup(optarg);
40 fprintf(stderr, "IDL file not provided. Exiting...\n");
44 if (!oilsInitIDL( idl_filename )) {
45 fprintf(stderr, "IDL file could not be loaded. Exiting...\n");
49 if(!(config && context)) {
50 fprintf(stderr, "Config or config context not provided. Exiting...\n");
54 if( ! osrf_system_bootstrap_client(config, context) ) {
55 fprintf(stderr, "Unable to connect to OpenSRF network... [config:%s : context:%s]\n", config, context);
59 printf("Connected to OpenSRF network...\n");
61 if( username && password &&
62 ( authtoken = oilsUtilsLogin(username, password, "staff", -1 )) ) {
63 printf("Login Session: %s\n", authtoken);
66 while((request=readline("oils# ")))
67 if(do_request(request)) break;
75 int do_request( char* request ) {
77 if(!strcasecmp(request, "exit") || !strcasecmp(request,"quit"))
80 if(!strcmp(request,"")) return 0;
86 growing_buffer* buffer = buffer_init(256);
88 service = strtok_r(request, " ", &tmp);
89 method = strtok_r(NULL, " ", &tmp);
90 while( (item = strtok_r(NULL, " ", &tmp)) )
91 buffer_fadd(buffer, "%s", item);
93 if( service && method ) {
95 jsonObject* params = NULL;
96 if(buffer->n_used > 0)
97 params = jsonParseStringFmt("[%s]", buffer->buf);
99 osrfAppSession* session = osrf_app_client_session_init(service);
100 int req_id = osrf_app_session_make_req( session, params, method, 1, NULL );
103 while( (omsg = osrfAppSessionRequestRecv( session, req_id, 120 )) ) {
104 jsonObject* res = osrfMessageGetResult(omsg);
105 char* data = format_response(res);
106 printf("\n%s\n", data);
108 osrfMessageFree(omsg);
111 osrfAppSessionFree(session);
112 jsonObjectFree(params);
115 fprintf(stderr, "STATMENT DOES NOT PARSE: %s\n", request);
123 char* format_response( jsonObject* o ) {
128 if( o->classname && isFieldmapper(o->classname) ) {
132 growing_buffer* buffer = buffer_init(256);
134 buffer_fadd(buffer, " FM Class: %s\n", o->classname);
136 while( (key = fm_pton(o->classname, i++)) ) {
137 char* val = oilsFMGetString(o, key);
140 int l = strlen(key + 2);
141 buffer_fadd(buffer, " %s: ", key);
145 while( l++ < width ) buffer_add(buffer, "-");
146 buffer_fadd(buffer, " %s\n", val);
149 } else if( (item = oilsFMGetObject(o, key))) {
151 if(item->type != JSON_NULL ) {
152 char* d = format_response(item);
153 buffer_add(buffer, "\n====================================\n");
154 buffer_fadd(buffer, "%s\n", d);
155 buffer_add(buffer, "====================================\n");
158 while( l++ < width ) buffer_add(buffer, "-");
159 buffer_add(buffer," NULL \n");
164 while( l++ < width ) buffer_add(buffer, "-");
165 buffer_add(buffer," NULL \n");
171 char* data = buffer_data(buffer);
177 if( o->type == JSON_ARRAY ) {
179 growing_buffer* arrb = buffer_init(256);
180 for( i = 0; i != o->size; i++ ) {
181 char* d = format_response(jsonObjectGetIndex(o, i));
182 buffer_fadd(arrb, "%s\n", d);
185 jjson = buffer_data(arrb);
189 char* json = jsonObjectToJSON(o);
190 jjson = jsonFormatString(json);