diff options
| author | Luiz Augusto von Dentz <luiz.dentz@indt.org.br> | 2008-09-02 19:17:55 -0300 | 
|---|---|---|
| committer | Luiz Augusto von Dentz <luiz.dentz@indt.org.br> | 2008-09-02 19:17:55 -0300 | 
| commit | 694f01921120bb2584b09b4ba502703cd8afd3f6 (patch) | |
| tree | 8a0197a6d24b13541dfc1c4e56626538a853d09e /src | |
| parent | e3c0f1dabde976043b02858bd135b2081a9cbe90 (diff) | |
Make methods related to external services into service plugin.
Diffstat (limited to 'src')
| -rw-r--r-- | src/adapter.c | 213 | 
1 files changed, 0 insertions, 213 deletions
diff --git a/src/adapter.c b/src/adapter.c index 98dc8ce2..1f050d9b 100644 --- a/src/adapter.c +++ b/src/adapter.c @@ -1908,213 +1908,6 @@ static DBusMessage *unregister_agent(DBusConnection *conn,  	return dbus_message_new_method_return(msg);  } -static void exit_callback(void *user_data) -{ -	struct record_data *user_record = user_data; - -	debug("remove record"); - -	records = g_slist_remove(records, user_record); - -	remove_record_from_server(user_record->handle); - -	g_free(user_record->sender); -	g_free(user_record); -} - -static int add_xml_record(DBusConnection *conn, const char *sender, -		bdaddr_t *src, const char *record, dbus_uint32_t *handle) -{ -	struct record_data *user_record; -	sdp_record_t *sdp_record; - -	sdp_record = sdp_xml_parse_record(record, strlen(record)); -	if (!sdp_record) { -		error("Parsing of XML service record failed"); -		return -EIO; -	} - -	if (add_record_to_server(src, sdp_record) < 0) { -		error("Failed to register service record"); -		sdp_record_free(sdp_record); -		return -EIO; -	} - -	user_record = g_new0(struct record_data, 1); - -	user_record->handle = sdp_record->handle; - -	user_record->sender = g_strdup(sender); - -	records = g_slist_append(records, user_record); - -	user_record->listener_id = g_dbus_add_disconnect_watch(conn, sender, -					exit_callback, user_record, NULL); - -	debug("listener_id %d", user_record->listener_id); - -	*handle = user_record->handle; - -	return 0; -} - -static DBusMessage *add_service_record(DBusConnection *conn, -						DBusMessage *msg, void *data) -{ -	struct adapter *adapter = data; -	DBusMessage *reply; -	const char *sender, *record; -	dbus_uint32_t handle; -	bdaddr_t src; -	int err; - -	if (dbus_message_get_args(msg, NULL, -			DBUS_TYPE_STRING, &record, DBUS_TYPE_INVALID) == FALSE) -		return NULL; - -	sender = dbus_message_get_sender(msg); -	str2ba(adapter->address, &src); -	err = add_xml_record(conn, sender, &src, record, &handle); -	if (err < 0) -		return failed_strerror(msg, err); - -	reply = dbus_message_new_method_return(msg); -	if (!reply) -		return NULL; - -	dbus_message_append_args(reply, DBUS_TYPE_UINT32, &handle, -							DBUS_TYPE_INVALID); - -	return reply; -} - -static DBusMessage *update_record(DBusConnection *conn, DBusMessage *msg, -		bdaddr_t *src, dbus_uint32_t handle, sdp_record_t *sdp_record) -{ -	int err; - -	if (remove_record_from_server(handle) < 0) { -		sdp_record_free(sdp_record); -		return g_dbus_create_error(msg, -				ERROR_INTERFACE ".NotAvailable", -				"Not Available"); -	} - -	sdp_record->handle = handle; -	err = add_record_to_server(src, sdp_record); -	if (err < 0) { -		sdp_record_free(sdp_record); -		error("Failed to update the service record"); -		return g_dbus_create_error(msg, -				ERROR_INTERFACE ".Failed", -				strerror(EIO)); -	} - -	return dbus_message_new_method_return(msg); -} - -static DBusMessage *update_xml_record(DBusConnection *conn, -					DBusMessage *msg, bdaddr_t *src) -{ -	struct record_data *user_record; -	sdp_record_t *sdp_record; -	const char *record; -	dbus_uint32_t handle; -	int len; - -	if (dbus_message_get_args(msg, NULL, -				DBUS_TYPE_UINT32, &handle, -				DBUS_TYPE_STRING, &record, -				DBUS_TYPE_INVALID) == FALSE) -		return NULL; - -	len = (record ? strlen(record) : 0); -	if (len == 0) -		return invalid_args(msg); - -	user_record = find_record(handle, dbus_message_get_sender(msg)); -	if (!user_record) -		return g_dbus_create_error(msg, -				ERROR_INTERFACE ".NotAvailable", -				"Not Available"); - -	sdp_record = sdp_xml_parse_record(record, len); -	if (!sdp_record) { -		error("Parsing of XML service record failed"); -		sdp_record_free(sdp_record); -		return g_dbus_create_error(msg, -				ERROR_INTERFACE ".Failed", -				strerror(EIO)); -	} - -	return update_record(conn, msg, src, handle, sdp_record); -} - -static DBusMessage *update_service_record(DBusConnection *conn, -						DBusMessage *msg, void *data) -{ -	struct adapter *adapter = data; -	bdaddr_t src; - -	str2ba(adapter->address, &src); - -	return update_xml_record(conn, msg, &src); -} - -static int remove_record(DBusConnection *conn, const char *sender, -							dbus_uint32_t handle) -{ -	struct record_data *user_record; - -	debug("remove record 0x%x", handle); - -	user_record = find_record(handle, sender); -	if (!user_record) -		return -1; - -	debug("listner_id %d", user_record->listener_id); - -	g_dbus_remove_watch(conn, user_record->listener_id); - -	exit_callback(user_record); - -	return 0; -} - -static DBusMessage *remove_service_record(DBusConnection *conn, -						DBusMessage *msg, void *data) -{ -	dbus_uint32_t handle; -	const char *sender; - -	if (dbus_message_get_args(msg, NULL, DBUS_TYPE_UINT32, &handle, -						DBUS_TYPE_INVALID) == FALSE) -		return NULL; - -	sender = dbus_message_get_sender(msg); - -	if (remove_record(conn, sender, handle) < 0) -		return not_available(msg); - -	return dbus_message_new_method_return(msg); -} - -static DBusMessage *request_authorization(DBusConnection *conn, -						DBusMessage *msg, void *data) -{ -	/* FIXME implement the request */ - -	return NULL; -} - -static DBusMessage *cancel_authorization(DBusConnection *conn, -						DBusMessage *msg, void *data) -{ -	/* FIXME implement cancel request */ - -	return dbus_message_new_method_return(msg); -} -  /* BlueZ 4.0 API */  static GDBusMethodTable adapter_methods[] = {  	{ "GetProperties",	"",	"a{sv}",get_properties		}, @@ -2135,12 +1928,6 @@ static GDBusMethodTable adapter_methods[] = {  	{ "FindDevice",		"s",	"o",	find_device		},  	{ "RegisterAgent",	"os",	"",	register_agent		},  	{ "UnregisterAgent",	"o",	"",	unregister_agent	}, -	{ "AddServiceRecord",	"s",	"u",	add_service_record	}, -	{ "UpdateServiceRecord","us",	"",	update_service_record	}, -	{ "RemoveServiceRecord","u",	"",	remove_service_record	}, -	{ "RequestAuthorization","su",	"",	request_authorization, -						G_DBUS_METHOD_FLAG_ASYNC}, -	{ "CancelAuthorization","",	"",	cancel_authorization	},  	{ }  };  | 
