diff --git a/src/storage.c b/src/storage.c
index 248e397..a65cee4 100644
--- a/src/storage.c
+++ b/src/storage.c
create_filename(filename, PATH_MAX, local, "ccc");
delete_by_pattern(filename, addr);
}
+
+int write_longtermkeys(bdaddr_t *local, bdaddr_t *peer, const char *key)
+{
+ char filename[PATH_MAX + 1], addr[18];
+
+ if (!key)
+ return -EINVAL;
+
+ create_filename(filename, PATH_MAX, local, "longtermkeys");
+
+ create_file(filename, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
+
+ ba2str(peer, addr);
+ return textfile_put(filename, addr, key);
+}
+
+gboolean has_longtermkeys(bdaddr_t *local, bdaddr_t *peer)
+{
+ char filename[PATH_MAX + 1], addr[18], *str;
+
+ create_filename(filename, PATH_MAX, local, "longtermkeys");
+
+ ba2str(peer, addr);
+
+ str = textfile_caseget(filename, addr);
+ if (str) {
+ free(str);
+ return TRUE;
+ }
+
+ return FALSE;
+}
diff --git a/src/storage.h b/src/storage.h
index 4046e99..2f145d0 100644
--- a/src/storage.h
+++ b/src/storage.h
int write_device_ccc(bdaddr_t *local, bdaddr_t *peer, uint16_t handle,
uint16_t value);
void delete_device_ccc(bdaddr_t *local, bdaddr_t *peer);
+int write_longtermkeys(bdaddr_t *local, bdaddr_t *peer, const char *key);
+gboolean has_longtermkeys(bdaddr_t *local, bdaddr_t *peer);
#define PNP_UUID "00001200-0000-1000-8000-00805f9b34fb"