示例#1
0
smcp_curl_proxy_node_t
smcp_curl_proxy_node_init(
    smcp_curl_proxy_node_t	self,
    smcp_node_t			parent,
    const char*			name
) {
    require(self || (self = smcp_smcp_curl_proxy_node_alloc()), bail);

    require(smcp_node_init(
                &self->node,
                (void*)parent,
                name
            ), bail);

    curl_global_init(CURL_GLOBAL_ALL);
    self->curl_multi_handle = curl_multi_init();
    ((smcp_node_t)&self->node)->request_handler = (void*)&smcp_curl_proxy_request_handler;

    // Now set the proxy path
//	char path[64];
//	if(0==smcp_node_get_path(&self->node,path,sizeof(path))) {
//		smcp_set_proxy_url(smcp_node_get_interface(&self->node), path);
//	}

bail:
    return self;
}
示例#2
0
int
main(int argc, char * argv[]) {
	smcp_t smcp = smcp_create(0);
	struct plugtest_server_s plugtest_server = {};
	struct smcp_node_s root_node = {};

	// Set up the root node.
	smcp_node_init(&root_node,NULL,NULL);

	// Set up the node router.
	smcp_set_default_request_handler(smcp, &smcp_node_router_handler, &root_node);

#if DEBUG
	fprintf(stderr,"DEBUG = %d\n",DEBUG);
#endif
#if VERBOSE_DEBUG
	fprintf(stderr,"VERBOSE_DEBUG = %d\n",VERBOSE_DEBUG);
#endif
	fprintf(stderr,"SMCP_EMBEDDED = %d\n",SMCP_EMBEDDED);
	fprintf(stderr,"SMCP_USE_BSD_SOCKETS = %d\n",SMCP_USE_BSD_SOCKETS);
	fprintf(stderr,"SMCP_DEFAULT_PORT = %d\n",SMCP_DEFAULT_PORT);
	fprintf(stderr,"SMCP_MAX_PATH_LENGTH = %d\n",SMCP_MAX_PATH_LENGTH);
	fprintf(stderr,"SMCP_MAX_URI_LENGTH = %d\n",SMCP_MAX_URI_LENGTH);
	fprintf(stderr,"SMCP_MAX_PACKET_LENGTH = %d\n",(int)SMCP_MAX_PACKET_LENGTH);
	fprintf(stderr,"SMCP_MAX_CONTENT_LENGTH = %d\n",SMCP_MAX_CONTENT_LENGTH);
	fprintf(stderr,"SMCP_USE_CASCADE_COUNT = %d\n",SMCP_USE_CASCADE_COUNT);
	fprintf(stderr,"SMCP_MAX_CASCADE_COUNT = %d\n",SMCP_MAX_CASCADE_COUNT);
	fprintf(stderr,"SMCP_ADD_NEWLINES_TO_LIST_OUTPUT = %d\n",SMCP_ADD_NEWLINES_TO_LIST_OUTPUT);
	fprintf(stderr,"SMCP_AVOID_PRINTF = %d\n",SMCP_AVOID_PRINTF);
	fprintf(stderr,"SMCP_AVOID_MALLOC = %d\n",SMCP_AVOID_MALLOC);
	fprintf(stderr,"SMCP_CONF_USE_DNS = %d\n",SMCP_CONF_USE_DNS);
	fprintf(stderr,"SMCP_CONF_MAX_TRANSACTIONS = %d\n",SMCP_CONF_MAX_TRANSACTIONS);
	fprintf(stderr,"SMCP_CONF_MAX_ALLOCED_NODES = %d\n",SMCP_CONF_MAX_ALLOCED_NODES);
	fprintf(stderr,"SMCP_CONF_MAX_TIMEOUT = %d\n",SMCP_CONF_MAX_TIMEOUT);
	fprintf(stderr,"SMCP_CONF_DUPE_BUFFER_SIZE = %d\n",SMCP_CONF_DUPE_BUFFER_SIZE);
	fprintf(stderr,"SMCP_OBSERVATION_KEEPALIVE_INTERVAL = %d\n",SMCP_OBSERVATION_KEEPALIVE_INTERVAL);
	fprintf(stderr,"SMCP_OBSERVATION_DEFAULT_MAX_AGE = %d\n",SMCP_OBSERVATION_DEFAULT_MAX_AGE);
	fprintf(stderr,"SMCP_VARIABLE_MAX_VALUE_LENGTH = %d\n",SMCP_VARIABLE_MAX_VALUE_LENGTH);
	fprintf(stderr,"SMCP_VARIABLE_MAX_KEY_LENGTH = %d\n",SMCP_VARIABLE_MAX_KEY_LENGTH);
#ifdef SMCP_DEBUG_OUTBOUND_DROP_PERCENT
	fprintf(stderr,"SMCP_DEBUG_OUTBOUND_DROP_PERCENT = %.1f%%\n",SMCP_DEBUG_OUTBOUND_DROP_PERCENT*100.0);
#endif
#ifdef SMCP_DEBUG_INBOUND_DROP_PERCENT
	fprintf(stderr,"SMCP_DEBUG_INBOUND_DROP_PERCENT = %.1f%%\n",SMCP_DEBUG_INBOUND_DROP_PERCENT*100.0);
#endif


	plugtest_server_init(&plugtest_server,&root_node);

	fprintf(stderr,"\nPlugtest server listening on port %d.\n", smcp_get_port(smcp));

	while(1)
		smcp_process(smcp,30*MSEC_PER_SEC);

	return 0;
}
示例#3
0
smcp_status_t
plugtest_server_init(struct plugtest_server_s *self,smcp_node_t root) {

	memset(self,0,sizeof(*self));

	smcp_node_init(&self->test,root,"test");
	self->test.request_handler = (smcp_callback_func)&plugtest_test_handler;

	smcp_node_init(&self->seg1,root,"seg1");
	smcp_node_init(&self->seg2,&self->seg1,"seg2");
	smcp_node_init(&self->seg3,&self->seg2,"seg3");
	self->seg3.request_handler = (smcp_callback_func)&plugtest_test_handler;

	smcp_node_init(&self->separate,root,"separate");
	self->separate.request_handler = (smcp_callback_func)&plugtest_separate_handler;

	smcp_node_init(&self->query,root,"query");
	self->query.request_handler = (smcp_callback_func)&plugtest_test_handler;

	smcp_node_init(&self->large,root,"large");
	self->large.request_handler = (smcp_callback_func)&plugtest_large_handler;

/*
	// Not yet implemented.
	smcp_node_init(&self->large_update,root,"large_update");
	self->large_update.request_handler = &plugtest_large_update_handler;

	smcp_node_init(&self->large_create,root,"large_create");
	self->large_create.request_handler = &plugtest_large_create_handler;
*/

	smcp_node_init(&self->obs,root,"obs");
	self->obs.request_handler = (smcp_callback_func)&plugtest_obs_handler;
	self->obs.context = (void*)self;
	self->obs.is_observable = true;

	smcp_timer_init(&self->obs_timer,&plugtest_obs_timer_callback,NULL,(void*)self);

	return SMCP_STATUS_OK;
}
示例#4
0
int
tool_cmd_test(
	smcp_t smcp_instance, int argc, char* argv[]
) {
	if((2 == argc) && (0 == strcmp(argv[1], "--help"))) {
		printf("Help not yet implemented for this command.\n");
		return ERRORCODE_HELP;
	}

	smcp_t smcp;
	smcp_t smcp2;

	struct smcp_timer_node_s timer_node = {};
	struct smcp_variable_node_s device_node = {};
	struct smcp_node_s async_response_node = {};

	smcp2 = smcp_create(12345);
	if(smcp_get_port(smcp_instance) == SMCP_DEFAULT_PORT)
		smcp = smcp_instance;
	else
		smcp = smcp_create(SMCP_DEFAULT_PORT);

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

#if HAVE_LIBCURL
	struct smcp_curl_proxy_node_s proxy_node = {};
//	curl_global_init(CURL_GLOBAL_ALL);

//	CURLM* curl_multi_handle = curl_multi_init();
	smcp_curl_proxy_node_init(
		&proxy_node,
		smcp_get_root_node(smcp),
		"proxy"
	);
#endif

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

//	smcp_pairing_init(
//		smcp_get_root_node(smcp),
//		SMCP_PAIRING_DEFAULT_ROOT_PATH
//	);
//
//	smcp_pairing_init(
//		smcp_get_root_node(smcp2),
//		SMCP_PAIRING_DEFAULT_ROOT_PATH
//	);

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	smcp_variable_node_init(
		&device_node,
		smcp_get_root_node(smcp),
		"device"
	);
	device_node.func = device_func;

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	smcp_variable_node_init(
		NULL,
		smcp_get_root_node(smcp2),
		"device"
	)->func = device_func;

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	smcp_timer_node_init(
		&timer_node,
		smcp_get_root_node(smcp),
		"timer"
	);

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	smcp_node_init((smcp_node_t)&async_response_node,
		smcp_get_root_node(smcp),
		"async_response"
	);
	async_response_node.request_handler = &async_request_handler;

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

#if !SMCP_CONF_OBSERVING_ONLY
	{
		char url[256];
		snprintf(url,
			sizeof(url),
			"smcp://127.0.0.1:%d/device/action",
			smcp_get_port(smcp2));
		smcp_pair_with_uri(smcp,
			"device/loadavg",
			url,
			0,
			NULL);
		printf("EVENT_NODE PAIRED WITH %s\n", url);
	}

	{
		char url[256];
		snprintf(url,
			sizeof(url),
			"smcp://[::1]:%d/device/loadavg",
			smcp_get_port(smcp));
		smcp_pair_with_uri(smcp2, "device/action", url, 0, NULL);
		printf("ACTION_NODE PAIRED WITH %s\n", url);
	}
#endif

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	// Just adding some random nodes so we can browse thru them with another process...
	{
		smcp_node_t subdevice = smcp_node_init(NULL,
			smcp_get_root_node(smcp),
			"lots_of_devices");
		unsigned char i = 0;
#if 1
		for(i = i * 97 + 101; i; i = i * 97 + 101) {
#else
		for(i = 0; i != 255; i++) {
#endif
			char *name = NULL;
			asprintf(&name, "subdevice_%d", i); // Will leak, but we don't care.
			smcp_node_init(NULL, (smcp_node_t)subdevice, name);
		}
//		{
//			unsigned int i = bt_rebalance(
//				    (void**)&((smcp_node_t)subdevice)->children);
//			printf("Balance operation took %u rotations\n", i);
//		}
//		{
//			unsigned int i = bt_rebalance(
//				    (void**)&((smcp_node_t)subdevice)->children);
//			printf("Second balance operation took %u rotations\n", i);
//		}
//		{
//			unsigned int i = bt_rebalance(
//				    (void**)&((smcp_node_t)subdevice)->children);
//			printf("Third balance operation took %u rotations\n", i);
//		}
//		{
//			unsigned int i = bt_rebalance(
//				    (void**)&((smcp_node_t)subdevice)->children);
//			printf("Fourth balance operation took %u rotations\n", i);
//		}
	}

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	{
		coap_msg_id_t tid = smcp_get_next_msg_id(smcp2);

		char url[256];

#if 0
		snprintf(url,
			sizeof(url),
			"smcp://["COAP_MULTICAST_IP6_ALLDEVICES"]:%d/device/",
			smcp_get_port(smcp));
#else
		snprintf(url,
			sizeof(url),
			"smcp://[::1]:%d/device/",
			smcp_get_port(smcp));
#endif

		smcp_begin_transaction_old(
			smcp2,
			tid,
			5 * MSEC_PER_SEC,
			0, // Flags
			NULL,
			&list_response_handler,
			NULL
		);

		smcp_outbound_begin(smcp2,COAP_METHOD_GET,COAP_TRANS_TYPE_CONFIRMABLE);
			smcp_outbound_set_msg_id(tid);
			smcp_outbound_set_uri(url, 0);
		smcp_outbound_send();

		fprintf(stderr, " *** Sent LIST request...\n");
	}

	//printf(__FILE__":%d: root node child count = %d\n",__LINE__,(int)bt_count(&smcp_get_root_node(smcp)->children));

	int i;
	for(i = 0; 1/*i < 3000000*/; i++) {
#if 1
		if((i - 1) % 250 == 0) {
			fprintf(stderr, " *** Forcing variable refresh...\n");
			smcp_variable_node_did_change(&device_node,0,NULL);
		}
#endif
		smcp_process(smcp);
		smcp_process(smcp2);
#if HAVE_LIBCURL
		smcp_curl_proxy_node_process(&proxy_node);
#endif
	}

bail:

	return 0;
}