diff options
author | Claudio Takahasi <claudio.takahasi@openbossa.org> | 2007-08-28 22:45:18 +0000 |
---|---|---|
committer | Claudio Takahasi <claudio.takahasi@openbossa.org> | 2007-08-28 22:45:18 +0000 |
commit | da81fb5e8f0c98791b0749fdde0ac8d06fa74cc9 (patch) | |
tree | 872eb41334061ee6be4ca4487b9dc8fb57885b93 /network/server.c | |
parent | 9c9b10af24ac7b53ef02cecb2b0393cf02b8bd71 (diff) |
network: fixed wrong service record attrs for PANU
Diffstat (limited to 'network/server.c')
-rw-r--r-- | network/server.c | 76 |
1 files changed, 46 insertions, 30 deletions
diff --git a/network/server.c b/network/server.c index 9dc8eb0b..4c5658f6 100644 --- a/network/server.c +++ b/network/server.c @@ -149,6 +149,52 @@ static int create_server_record(sdp_buf_t *buf, const char *name, memset(&record, 0, sizeof(sdp_record_t)); + switch (id) { + case BNEP_SVC_NAP: + sdp_uuid16_create(&pan, NAP_SVCLASS_ID); + svclass = sdp_list_append(NULL, &pan); + sdp_set_service_classes(&record, svclass); + + sdp_uuid16_create(&profile[0].uuid, NAP_PROFILE_ID); + profile[0].version = 0x0100; + pfseq = sdp_list_append(NULL, &profile[0]); + sdp_set_profile_descs(&record, pfseq); + + sdp_set_info_attr(&record, name, NULL, desc); + + sdp_attr_add_new(&record, SDP_ATTR_NET_ACCESS_TYPE, + SDP_UINT16, &net_access_type); + sdp_attr_add_new(&record, SDP_ATTR_MAX_NET_ACCESSRATE, + SDP_UINT32, &max_net_access_rate); + break; + case BNEP_SVC_GN: + sdp_uuid16_create(&pan, GN_SVCLASS_ID); + svclass = sdp_list_append(NULL, &pan); + sdp_set_service_classes(&record, svclass); + + sdp_uuid16_create(&profile[0].uuid, GN_PROFILE_ID); + profile[0].version = 0x0100; + pfseq = sdp_list_append(NULL, &profile[0]); + sdp_set_profile_descs(&record, pfseq); + + sdp_set_info_attr(&record, name, NULL, desc); + break; + case BNEP_SVC_PANU: + sdp_uuid16_create(&pan, PANU_SVCLASS_ID); + svclass = sdp_list_append(NULL, &pan); + sdp_set_service_classes(&record, svclass); + + sdp_uuid16_create(&profile[0].uuid, PANU_PROFILE_ID); + profile[0].version = 0x0100; + pfseq = sdp_list_append(NULL, &profile[0]); + sdp_set_profile_descs(&record, pfseq); + + sdp_set_info_attr(&record, name, NULL, desc); + break; + default: + return -1; + } + sdp_uuid16_create(&root_uuid, PUBLIC_BROWSE_GROUP); root = sdp_list_append(NULL, &root_uuid); sdp_set_browse_groups(&record, root); @@ -194,36 +240,6 @@ static int create_server_record(sdp_buf_t *buf, const char *name, sdp_attr_add_new(&record, SDP_ATTR_SECURITY_DESC, SDP_UINT16, &security_desc); - if (id == BNEP_SVC_NAP) { - sdp_uuid16_create(&pan, NAP_SVCLASS_ID); - svclass = sdp_list_append(NULL, &pan); - sdp_set_service_classes(&record, svclass); - - sdp_uuid16_create(&profile[0].uuid, NAP_PROFILE_ID); - profile[0].version = 0x0100; - pfseq = sdp_list_append(NULL, &profile[0]); - sdp_set_profile_descs(&record, pfseq); - - sdp_set_info_attr(&record, name, NULL, desc); - - sdp_attr_add_new(&record, SDP_ATTR_NET_ACCESS_TYPE, - SDP_UINT16, &net_access_type); - sdp_attr_add_new(&record, SDP_ATTR_MAX_NET_ACCESSRATE, - SDP_UINT32, &max_net_access_rate); - } else { - /* BNEP_SVC_GN */ - sdp_uuid16_create(&pan, GN_SVCLASS_ID); - svclass = sdp_list_append(NULL, &pan); - sdp_set_service_classes(&record, svclass); - - sdp_uuid16_create(&profile[0].uuid, GN_PROFILE_ID); - profile[0].version = 0x0100; - pfseq = sdp_list_append(NULL, &profile[0]); - sdp_set_profile_descs(&record, pfseq); - - sdp_set_info_attr(&record, name, NULL, desc); - } - if (sdp_gen_record_pdu(&record, buf) < 0) ret = -1; else |