⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 storage.c

📁 BlueZ源码
💻 C
📖 第 1 页 / 共 2 页
字号:
	if (type) {		memcpy(tmp, str + 33, 2);		*type = (uint8_t) strtol(tmp, NULL, 10);	}	free(str);	return 0;}int read_pin_length(bdaddr_t *local, bdaddr_t *peer){	char filename[PATH_MAX + 1], addr[18], *str;	int len;	create_filename(filename, PATH_MAX, local, "linkkeys");	ba2str(peer, addr);	str = textfile_get(filename, addr);	if (!str)		return -ENOENT;	if (strlen(str) < 36) {		free(str);		return -ENOENT;	}	len = atoi(str + 35);	free(str);	return len;}int read_pin_code(bdaddr_t *local, bdaddr_t *peer, char *pin){	char filename[PATH_MAX + 1], addr[18], *str;	int len;	create_filename(filename, PATH_MAX, local, "pincodes");	ba2str(peer, addr);	str = textfile_get(filename, addr);	if (!str)		return -ENOENT;	strncpy(pin, str, 16);	len = strlen(pin);	free(str);	return len;}static GSList *service_string_to_list(char *services){	GSList *l = NULL;	char *start = services;	int i, finished = 0;	for (i = 0; !finished; i++) {		if (services[i] == '\0')			finished = 1;		if (services[i] == ' ' || services[i] == '\0') {			services[i] = '\0';			l = g_slist_append(l, start);			start = services + i + 1;		}	}	return l;}static char *service_list_to_string(GSList *services){	char str[1024];	int len = 0;	if (!services)		return g_strdup("");	memset(str, 0, sizeof(str));	while (services) {		int ret;		char *ident = services->data;		ret = snprintf(str + len, sizeof(str) - len - 1, "%s%s",				ident, services->next ? " " : "");		if (ret > 0)			len += ret;		services = services->next;	}	return g_strdup(str);}int write_trust(const char *src, const char *addr, const char *service,		gboolean trust){	char filename[PATH_MAX + 1], *str;	GSList *services = NULL, *match;	gboolean trusted;	int ret;	create_name(filename, PATH_MAX, STORAGEDIR, src, "trusts");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	str = textfile_caseget(filename, addr);	if (str)		services = service_string_to_list(str);	match = g_slist_find_custom(services, service, (GCompareFunc) strcmp);	trusted = match ? TRUE : FALSE;	/* If the old setting is the same as the requested one, we're done */	if (trusted == trust) {		g_slist_free(services);		if (str)			free(str);		return 0;	}	if (trust)		services = g_slist_append(services, (void *) service);	else		services = g_slist_remove(services, match->data);	/* Remove the entry if the last trusted service was removed */	if (!trust && !services)		ret = textfile_casedel(filename, addr);	else {		char *new_str = service_list_to_string(services);		ret = textfile_caseput(filename, addr, new_str);		free(new_str);	}	g_slist_free(services);	if (str)		free(str);	return ret;}gboolean read_trust(const bdaddr_t *local, const char *addr, const char *service){	char filename[PATH_MAX + 1], *str;	GSList *services;	gboolean ret;	create_filename(filename, PATH_MAX, local, "trusts");	str = textfile_caseget(filename, addr);	if (!str)		return FALSE;	services = service_string_to_list(str);	if (g_slist_find_custom(services, service, (GCompareFunc) strcmp))		ret = TRUE;	else		ret = FALSE;	g_slist_free(services);	free(str);	return ret;}struct trust_list {	GSList *trusts;	const char *service;};static void append_trust(char *key, char *value, void *data){	struct trust_list *list = data;	if (strstr(value, list->service))		list->trusts = g_slist_append(list->trusts, g_strdup(key));}GSList *list_trusts(bdaddr_t *local, const char *service){	char filename[PATH_MAX + 1];	struct trust_list list;	create_filename(filename, PATH_MAX, local, "trusts");	list.trusts = NULL;	list.service = service;	if (textfile_foreach(filename, append_trust, &list) < 0)		return NULL;	return list.trusts;}int write_device_profiles(bdaddr_t *src, bdaddr_t *dst, const char *profiles){	char filename[PATH_MAX + 1], addr[18];	if (!profiles)		return -EINVAL;	create_filename(filename, PATH_MAX, src, "profiles");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	ba2str(dst, addr);	return textfile_put(filename, addr, profiles);}int delete_entry(bdaddr_t *src, const char *storage, const char *key){	char filename[PATH_MAX + 1];	create_filename(filename, PATH_MAX, src, storage);	return textfile_del(filename, key);}int store_record(const gchar *src, const gchar *dst, sdp_record_t *rec){	char filename[PATH_MAX + 1], key[28];	sdp_buf_t buf;	int err, size, i;	char *pdata, *str;	create_name(filename, PATH_MAX, STORAGEDIR, src, "sdp");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	snprintf(key, sizeof(key), "%17s#%08X", dst, rec->handle);	if (sdp_gen_record_pdu(rec, &buf) < 0)		return -1;	pdata = (char *)buf.data;	size = buf.data_size;	str = g_malloc0(size*2+1);	for (i = 0; i < size; i++)		sprintf(str + (i * 2), "%02X", buf.data[i]);	err = textfile_put(filename, key, str);	free(buf.data);	free(str);	return err;}sdp_record_t *record_from_string(const gchar *str){	sdp_record_t *rec;	int size, i, len;	uint8_t *pdata;	char tmp[3];	size = strlen(str)/2;	pdata = g_malloc0(size);	tmp[2] = 0;	for (i = 0; i < size; i++) {		 memcpy(tmp, str + (i * 2), 2);		 pdata[i] = (uint8_t) strtol(tmp, NULL, 16);	}	rec = sdp_extract_pdu(pdata, size, &len);	free(pdata);	return rec;}sdp_record_t *fetch_record(const gchar *src, const gchar *dst,						const uint32_t handle){	char filename[PATH_MAX + 1], key[28], *str;	sdp_record_t *rec;	create_name(filename, PATH_MAX, STORAGEDIR, src, "sdp");	snprintf(key, sizeof(key), "%17s#%08X", dst, handle);	str = textfile_get(filename, key);	if (!str)		return NULL;	rec = record_from_string(str);	free(str);	return rec;}int delete_record(const gchar *src, const gchar *dst, const uint32_t handle){	char filename[PATH_MAX + 1], key[28];	create_name(filename, PATH_MAX, STORAGEDIR, src, "sdp");	snprintf(key, sizeof(key), "%17s#%08X", dst, handle);	return textfile_del(filename, key);}struct record_list {	sdp_list_t *recs;	const gchar *addr;};static void create_stored_records_from_keys(char *key, char *value,							void *user_data){	struct record_list *rec_list = user_data;	const gchar *addr = rec_list->addr;	sdp_record_t *rec;	if (strncmp(key, addr, 17))		return;	rec = record_from_string(value);	rec_list->recs = sdp_list_append(rec_list->recs, rec);}sdp_list_t *read_records(bdaddr_t *src, bdaddr_t *dst){	char filename[PATH_MAX + 1];	struct record_list rec_list;	char srcaddr[18], dstaddr[18];	ba2str(src, srcaddr);	ba2str(dst, dstaddr);	rec_list.addr = dstaddr;	rec_list.recs = NULL;	create_name(filename, PATH_MAX, STORAGEDIR, srcaddr, "sdp");	textfile_foreach(filename, create_stored_records_from_keys, &rec_list);	return rec_list.recs;}sdp_record_t *find_record_in_list(sdp_list_t *recs, const char *uuid){	sdp_list_t *seq;	for (seq = recs; seq; seq = seq->next) {		sdp_record_t *rec = (sdp_record_t *) seq->data;		sdp_list_t *svcclass = NULL;		char *uuid_str;		if (sdp_get_service_classes(rec, &svcclass) < 0)			continue;		/* Extract the uuid */		uuid_str = bt_uuid2string(svcclass->data);		if (!uuid_str)			continue;		if (!strcasecmp(uuid_str, uuid)) {			sdp_list_free(svcclass, free);			free(uuid_str);			return rec;		}		sdp_list_free(svcclass, free);		free(uuid_str);	}	return NULL;}int store_device_id(const gchar *src, const gchar *dst,				const uint16_t source, const uint16_t vendor,				const uint16_t product, const uint16_t version){	char filename[PATH_MAX + 1], str[20];	create_name(filename, PATH_MAX, STORAGEDIR, src, "did");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	snprintf(str, sizeof(str), "%04X %04X %04X %04X", source,						vendor, product, version);	return textfile_put(filename, dst, str);}static int read_device_id_from_did(const gchar *src, const gchar *dst,					uint16_t *source, uint16_t *vendor,					uint16_t *product, uint16_t *version){	char filename[PATH_MAX + 1];	char *str, *vendor_str, *product_str, *version_str;	create_name(filename, PATH_MAX, STORAGEDIR, src, "did");	str = textfile_get(filename, dst);	if (!str)		return -ENOENT;	vendor_str = strchr(str, ' ');	if (!vendor_str) {		free(str);		return -ENOENT;	}	*(vendor_str++) = 0;	product_str = strchr(vendor_str, ' ');	if (!product_str) {		free(str);		return -ENOENT;	}	*(product_str++) = 0;	version_str = strchr(product_str, ' ');	if (!version_str) {		free(str);		return -ENOENT;	}	*(version_str++) = 0;	if (source)		*source = (uint16_t) strtol(str, NULL, 16);	if (vendor)		*vendor = (uint16_t) strtol(vendor_str, NULL, 16);	if (product)		*product = (uint16_t) strtol(product_str, NULL, 16);	if (version)		*version = (uint16_t) strtol(version_str, NULL, 16);	free(str);	return 0;}int read_device_id(const gchar *srcaddr, const gchar *dstaddr,					uint16_t *source, uint16_t *vendor,					uint16_t *product, uint16_t *version){	uint16_t lsource, lvendor, lproduct, lversion;	sdp_list_t *recs;	sdp_record_t *rec;	bdaddr_t src, dst;	int err;	err = read_device_id_from_did(srcaddr, dstaddr, &lsource,						vendor, product, version);	if (!err) {		if (lsource == 0xffff)			err = -ENOENT;		return err;	}	str2ba(srcaddr, &src);	str2ba(dstaddr, &dst);	recs = read_records(&src, &dst);	rec = find_record_in_list(recs, PNP_UUID);	if (rec) {		sdp_data_t *pdlist;		pdlist = sdp_data_get(rec, SDP_ATTR_VENDOR_ID_SOURCE);		lsource = pdlist ? pdlist->val.uint16 : 0x0000;		pdlist = sdp_data_get(rec, SDP_ATTR_VENDOR_ID);		lvendor = pdlist ? pdlist->val.uint16 : 0x0000;		pdlist = sdp_data_get(rec, SDP_ATTR_PRODUCT_ID);		lproduct = pdlist ? pdlist->val.uint16 : 0x0000;		pdlist = sdp_data_get(rec, SDP_ATTR_VERSION);		lversion = pdlist ? pdlist->val.uint16 : 0x0000;		err = 0;	}	sdp_list_free(recs, (sdp_free_func_t)sdp_record_free);	if (err) {		/* FIXME: We should try EIR data if we have it, too */		/* If we don't have the data, we don't want to go		   through the above search every time. */		lsource = 0xffff;		lvendor = 0x0000;		lproduct = 0x0000;		lversion = 0x0000;	}	store_device_id(srcaddr, dstaddr, lsource, lvendor, lproduct, lversion);	if (err)		return err;	if (source)		*source = lsource;	if (vendor)		*vendor = lvendor;	if (product)		*product = lproduct;	if (version)		*version = lversion;	return 0;}int write_device_pairable(bdaddr_t *bdaddr, gboolean mode){	char filename[PATH_MAX + 1];	create_filename(filename, PATH_MAX, bdaddr, "config");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	return textfile_put(filename, "pairable", mode ? "yes" : "no");}int read_device_pairable(bdaddr_t *bdaddr, gboolean *mode){	char filename[PATH_MAX + 1], *str;	create_filename(filename, PATH_MAX, bdaddr, "config");	create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);	str = textfile_get(filename, "pairable");	if (!str)		return -ENOENT;	*mode = strcmp(str, "yes") == 0 ? TRUE : FALSE;	free(str);	return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -