diff --git a/obexd/plugins/bluetooth.c b/obexd/plugins/bluetooth.c
index 1c9d92e..1a57654 100644
--- a/obexd/plugins/bluetooth.c
+++ b/obexd/plugins/bluetooth.c
}
static GIOChannel *start(struct obex_server *server,
- struct obex_service_driver *service,
- BtIOSecLevel sec_level)
+ struct obex_service_driver *service)
{
+ BtIOSecLevel sec_level;
GIOChannel *io;
GError *err = NULL;
+ if (service->secure == TRUE)
+ sec_level = BT_IO_SEC_MEDIUM;
+ else
+ sec_level = BT_IO_SEC_LOW;
+
+
io = bt_io_listen(BT_IO_RFCOMM, NULL, confirm_event,
service, NULL, &err,
BT_IO_OPT_CHANNEL, service->channel,
static void *bluetooth_start(struct obex_server *server, int *err)
{
- BtIOSecLevel sec_level;
GSList *ios = NULL;
const GSList *l;
- if (server->secure == TRUE)
- sec_level = BT_IO_SEC_MEDIUM;
- else
- sec_level = BT_IO_SEC_LOW;
-
for (l = server->drivers; l; l = l->next) {
struct obex_service_driver *service = l->data;
GIOChannel *io;
- io = start(server, service, sec_level);
+ io = start(server, service);
if (io == NULL)
continue;
diff --git a/obexd/plugins/ftp.c b/obexd/plugins/ftp.c
index 3f32563..aebe411 100644
--- a/obexd/plugins/ftp.c
+++ b/obexd/plugins/ftp.c
.name = "File Transfer server",
.service = OBEX_FTP,
.channel = FTP_CHANNEL,
+ .secure = TRUE,
.record = FTP_RECORD,
.target = FTP_TARGET,
.target_size = TARGET_SIZE,
diff --git a/obexd/plugins/irmc.c b/obexd/plugins/irmc.c
index 3499ca7..4ea76c5 100644
--- a/obexd/plugins/irmc.c
+++ b/obexd/plugins/irmc.c
.name = "IRMC Sync server",
.service = OBEX_IRMC,
.channel = IRMC_CHANNEL,
+ .secure = TRUE,
.record = IRMC_RECORD,
.target = IRMC_TARGET,
.target_size = IRMC_TARGET_SIZE,
diff --git a/obexd/plugins/mas.c b/obexd/plugins/mas.c
index 3e3670f..7d3d553 100644
--- a/obexd/plugins/mas.c
+++ b/obexd/plugins/mas.c
.name = "Message Access server",
.service = OBEX_MAS,
.channel = MAS_CHANNEL,
+ .secure = TRUE,
.record = MAS_RECORD,
.target = MAS_TARGET,
.target_size = TARGET_SIZE,
diff --git a/obexd/plugins/pbap.c b/obexd/plugins/pbap.c
index 066e37e..997b5bd 100644
--- a/obexd/plugins/pbap.c
+++ b/obexd/plugins/pbap.c
.name = "Phonebook Access server",
.service = OBEX_PBAP,
.channel = PBAP_CHANNEL,
+ .secure = TRUE,
.record = PBAP_RECORD,
.target = PBAP_TARGET,
.target_size = TARGET_SIZE,
diff --git a/obexd/plugins/pcsuite.c b/obexd/plugins/pcsuite.c
index b93bd65..27a3496 100644
--- a/obexd/plugins/pcsuite.c
+++ b/obexd/plugins/pcsuite.c
.name = "Nokia OBEX PC Suite Services",
.service = OBEX_PCSUITE,
.channel = PCSUITE_CHANNEL,
+ .secure = TRUE,
.record = PCSUITE_RECORD,
.target = FTP_TARGET,
.target_size = TARGET_SIZE,
diff --git a/obexd/plugins/syncevolution.c b/obexd/plugins/syncevolution.c
index a389783..fcf6d2b 100644
--- a/obexd/plugins/syncevolution.c
+++ b/obexd/plugins/syncevolution.c
.name = "OBEX server for SyncML, using SyncEvolution",
.service = OBEX_SYNCEVOLUTION,
.channel = SYNCEVOLUTION_CHANNEL,
+ .secure = TRUE,
.record = SYNCEVOLUTION_RECORD,
.target = SYNCML_TARGET,
.target_size = SYNCML_TARGET_SIZE,
diff --git a/obexd/src/main.c b/obexd/src/main.c
index 73c1db5..114c215 100644
--- a/obexd/src/main.c
+++ b/obexd/src/main.c
plugin_init(option_plugin, option_noplugin);
- obex_server_init(OBEX_OPP, FALSE);
+ obex_server_init(OBEX_OPP);
- obex_server_init(OBEX_FTP, TRUE);
+ obex_server_init(OBEX_FTP);
- obex_server_init(OBEX_PCSUITE, TRUE);
+ obex_server_init(OBEX_PCSUITE);
- obex_server_init(OBEX_PBAP, TRUE);
+ obex_server_init(OBEX_PBAP);
- obex_server_init(OBEX_IRMC, TRUE);
+ obex_server_init(OBEX_IRMC);
- obex_server_init(OBEX_SYNCEVOLUTION, TRUE);
+ obex_server_init(OBEX_SYNCEVOLUTION);
- obex_server_init(OBEX_MAS, TRUE);
+ obex_server_init(OBEX_MAS);
if (!root_folder_setup(option_root, option_root_setup)) {
error("Unable to setup root folder %s", option_root);
diff --git a/obexd/src/server.c b/obexd/src/server.c
index dc1ad6d..bf234ea 100644
--- a/obexd/src/server.c
+++ b/obexd/src/server.c
static GSList *servers = NULL;
-int obex_server_init(uint16_t service, gboolean secure)
+int obex_server_init(uint16_t service)
{
GSList *drivers;
GSList *transports;
server = g_new0(struct obex_server, 1);
server->transport = transport;
server->drivers = drivers;
- server->secure = secure;
server->transport_data = transport->start(server, &err);
if (server->transport_data == NULL) {
diff --git a/obexd/src/server.h b/obexd/src/server.h
index beb8a9c..dd0df00 100644
--- a/obexd/src/server.h
+++ b/obexd/src/server.h
struct obex_server {
struct obex_transport_driver *transport;
void *transport_data;
- gboolean secure;
GSList *drivers;
};
-int obex_server_init(uint16_t service, gboolean secure);
+int obex_server_init(uint16_t service);
void obex_server_exit(void);
diff --git a/obexd/src/service.h b/obexd/src/service.h
index 6633be3..68c4474 100644
--- a/obexd/src/service.h
+++ b/obexd/src/service.h
const char *name;
uint16_t service;
uint8_t channel;
+ gboolean secure;
const uint8_t *target;
unsigned int target_size;
const uint8_t *who;