Tweaked README, fixed links.
This commit is contained in:
parent
d10dcab100
commit
d6193777c9
5 changed files with 329 additions and 14 deletions
|
@ -38,6 +38,7 @@ add_library(tox MODULE
|
||||||
src/twc-commands.c
|
src/twc-commands.c
|
||||||
src/twc-completion.c
|
src/twc-completion.c
|
||||||
src/twc-config.c
|
src/twc-config.c
|
||||||
|
src/twc-data.c
|
||||||
src/twc-friend-request.c
|
src/twc-friend-request.c
|
||||||
src/twc-gui.c
|
src/twc-gui.c
|
||||||
src/twc-list.c
|
src/twc-list.c
|
||||||
|
@ -50,6 +51,7 @@ add_library(tox MODULE
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99 -Wall -Wextra -Werror-implicit-function-declaration -Wno-unused-parameter")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99 -Wall -Wextra -Werror-implicit-function-declaration -Wno-unused-parameter")
|
||||||
|
|
||||||
target_link_libraries(tox toxcore)
|
target_link_libraries(tox toxcore)
|
||||||
|
target_link_libraries(tox jansson)
|
||||||
|
|
||||||
# remove lib prefix (libtox.so -> tox.so)
|
# remove lib prefix (libtox.so -> tox.so)
|
||||||
set_target_properties(tox PROPERTIES PREFIX "")
|
set_target_properties(tox PROPERTIES PREFIX "")
|
||||||
|
|
26
README.md
26
README.md
|
@ -1,25 +1,24 @@
|
||||||
Tox-WeeChat
|
Tox-WeeChat
|
||||||
===========
|
===========
|
||||||
Tox-WeeChat is a plugin for [WeeChat][1] that enables it to connect to the [Tox][2] network. It is functional, but currently only intended for experimental use.
|
Tox-WeeChat is a [Tox][1] protocol plugin for [WeeChat][2]. It is functional, but lacks certain features like Tox DNS (e.g. user@toxme.se) and group chats.
|
||||||
|
|
||||||
Current build status: [![Build Status](https://travis-ci.org/haavardp/tox-weechat.svg?branch=master)](https://travis-ci.org/haavardp/tox-weechat)
|
Current build status: [![Build Status](https://travis-ci.org/haavardp/tox-weechat.svg?branch=master)][3]
|
||||||
|
|
||||||
Installation
|
Installation
|
||||||
------------
|
------------
|
||||||
> Tox-WeeChat is available in the [AUR][3].
|
> Tox-WeeChat is available in the [AUR][4].
|
||||||
|
|
||||||
Tox-WeeChat requires [WeeChat][1] >= 1.0.1, [libjansson][4] >= 2.5 and the latest-ish [libtoxcore][5]. It also requires CMake to be built. Installation is fairly simple; after getting the source, compile and install using CMake:
|
Tox-WeeChat requires [WeeChat][1] >= 1.0.1, [libjansson][5] >= 2.5 and the latest-ish [libtoxcore][6]. It also requires CMake to be built. Installation is fairly simple; after getting the source, compile and install using CMake:
|
||||||
|
|
||||||
$ mkdir build && cd build
|
$ mkdir build && cd build
|
||||||
$ cmake -DHOME_FOLDER_INSTALL=ON ..
|
$ cmake -DHOME_FOLDER_INSTALL=ON ..
|
||||||
$ make
|
|
||||||
$ make install
|
$ make install
|
||||||
|
|
||||||
This installs the plugin binary `tox.so` to the recommended location `~/.weechat/plugins`. Without the home folder flag, the binary is placed in `/usr/local/lib/weechat/plugins`. Installing to a custom WeeChat folder or elsewhere is achieved by setting `INSTALL_PATH`.
|
This installs the plugin binary `tox.so` to the recommended location `~/.weechat/plugins`. Without the home folder flag, the binary is placed in `/usr/local/lib/weechat/plugins`. Installing to a custom WeeChat folder or elsewhere is achieved by setting `INSTALL_PATH`.
|
||||||
|
|
||||||
Usage
|
Usage
|
||||||
-----
|
-----
|
||||||
- If the plugin does not automatically load, load it with `/plugin load tox`. You may have to specify the full path to the plugin binary.
|
- If the plugin does not load automatically, load it with `/plugin load tox`. You may have to specify the full path to the plugin binary.
|
||||||
- Create a new profile with `/tox create <name>`. The data file is stored in `~/.weechat/tox/` by default.
|
- Create a new profile with `/tox create <name>`. The data file is stored in `~/.weechat/tox/` by default.
|
||||||
- Load your profile and connect to the Tox network with `/tox load <name>`.
|
- Load your profile and connect to the Tox network with `/tox load <name>`.
|
||||||
- Change your name with `/name <new name>`.
|
- Change your name with `/name <new name>`.
|
||||||
|
@ -27,7 +26,7 @@ Usage
|
||||||
- To add friends or respond to friend requests, `/help friend` will get you started.
|
- To add friends or respond to friend requests, `/help friend` will get you started.
|
||||||
- Message a friend with `/msg <friend number>`. Get their friend number with `/friend list`.
|
- Message a friend with `/msg <friend number>`. Get their friend number with `/friend list`.
|
||||||
|
|
||||||
Run `/help -list tox` to get a list of all available commands.
|
Run `/help -listfull tox` to get a list of all available commands.
|
||||||
|
|
||||||
TODO
|
TODO
|
||||||
----
|
----
|
||||||
|
@ -37,7 +36,7 @@ TODO
|
||||||
- Group chats
|
- Group chats
|
||||||
- Support proxies (e.g. TOR)
|
- Support proxies (e.g. TOR)
|
||||||
- Support WeeChat `/upgrade`
|
- Support WeeChat `/upgrade`
|
||||||
- A/V
|
- Audio/video chats
|
||||||
|
|
||||||
License
|
License
|
||||||
---------
|
---------
|
||||||
|
@ -58,9 +57,10 @@ GNU General Public License for more details.
|
||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
||||||
along with Tox-WeeChat. If not, see <http://www.gnu.org/licenses/>.
|
along with Tox-WeeChat. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
[1]: http://weechat.org
|
[1]: http://tox.im
|
||||||
[2]: http://tox.im
|
[2]: http://weechat.org
|
||||||
[3]: https://aur.archlinux.org/packages/tox-weechat-git
|
[3]: https://travis-ci.org/haavardp/tox-weechat
|
||||||
[3]: http://www.digip.org/jansson
|
[4]: https://aur.archlinux.org/packages/tox-weechat-git
|
||||||
[5]: https://github.com/irungentoo/toxcore
|
[5]: http://www.digip.org/jansson
|
||||||
|
[6]: https://github.com/irungentoo/toxcore
|
||||||
|
|
||||||
|
|
291
src/twc-data.c
291
src/twc-data.c
|
@ -17,3 +17,294 @@
|
||||||
* along with Tox-WeeChat. If not, see <http://www.gnu.org/licenses/>.
|
* along with Tox-WeeChat. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <weechat/weechat-plugin.h>
|
||||||
|
#include <tox/tox.h>
|
||||||
|
#include <jansson.h>
|
||||||
|
|
||||||
|
#include "twc.h"
|
||||||
|
#include "twc-list.h"
|
||||||
|
#include "twc-profile.h"
|
||||||
|
#include "twc-friend-request.h"
|
||||||
|
#include "twc-message-queue.h"
|
||||||
|
#include "twc-utils.h"
|
||||||
|
|
||||||
|
#include "twc-data.h"
|
||||||
|
|
||||||
|
// TODO: move to config
|
||||||
|
#define twc_JSON_CONFIG_PATH "%h/tox/data.json"
|
||||||
|
|
||||||
|
const char *twc_json_key_friend_requests = "freqs";
|
||||||
|
const char *twc_json_friend_request_key_tox_id = "tox_id";
|
||||||
|
const char *twc_json_friend_request_key_message = "msg";
|
||||||
|
const char *twc_json_key_message_queues = "msg_q";
|
||||||
|
const char *twc_json_key_message_queue_key_message = "msg";
|
||||||
|
const char *twc_json_key_message_queue_key_message_type = "type";
|
||||||
|
const char *twc_json_key_message_queue_key_message_timestamp = "time";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The object holding the JSON config data.
|
||||||
|
*/
|
||||||
|
json_t *twc_json_data = NULL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the full path to the config file. Return value must be freed.
|
||||||
|
*/
|
||||||
|
char *
|
||||||
|
twc_data_json_path()
|
||||||
|
{
|
||||||
|
const char *weechat_dir = weechat_info_get("weechat_dir", NULL);
|
||||||
|
return weechat_string_replace(twc_JSON_CONFIG_PATH, "%h", weechat_dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the key used for a profile in the JSON data file. Must be freed.
|
||||||
|
*/
|
||||||
|
char *
|
||||||
|
twc_data_profile_key(struct t_twc_profile *profile)
|
||||||
|
{
|
||||||
|
uint8_t address[TOX_FRIEND_ADDRESS_SIZE];
|
||||||
|
tox_get_address(profile->tox, address);
|
||||||
|
|
||||||
|
char *hex_id = malloc(TOX_CLIENT_ID_SIZE * 2 + 1);
|
||||||
|
twc_bin2hex(address, TOX_CLIENT_ID_SIZE, hex_id);
|
||||||
|
|
||||||
|
return hex_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Save an profile's friend requests to a json array. Returns a new
|
||||||
|
* reference.
|
||||||
|
*/
|
||||||
|
json_t *
|
||||||
|
twc_data_save_profile_friend_requests(struct t_twc_profile *profile)
|
||||||
|
{
|
||||||
|
json_t *friend_request_array = json_array();
|
||||||
|
if (!friend_request_array)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
size_t index;
|
||||||
|
struct t_twc_list_item *item;
|
||||||
|
twc_list_foreach(profile->friend_requests, index, item)
|
||||||
|
{
|
||||||
|
char hex_id[TOX_CLIENT_ID_SIZE * 2 + 1];
|
||||||
|
twc_bin2hex(item->friend_request->tox_id, TOX_CLIENT_ID_SIZE, hex_id);
|
||||||
|
|
||||||
|
json_t *json_request = json_object();
|
||||||
|
json_t *json_id = json_string(hex_id);
|
||||||
|
json_t *json_message = json_string(item->friend_request->message);
|
||||||
|
if (!json_request || !json_id || !json_message)
|
||||||
|
break;
|
||||||
|
|
||||||
|
json_object_set_new(json_request,
|
||||||
|
twc_json_friend_request_key_tox_id,
|
||||||
|
json_id);
|
||||||
|
|
||||||
|
json_object_set_new(json_request,
|
||||||
|
twc_json_friend_request_key_message,
|
||||||
|
json_message);
|
||||||
|
|
||||||
|
json_array_append_new(friend_request_array, json_request);
|
||||||
|
}
|
||||||
|
|
||||||
|
return friend_request_array;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_save_profile_message_queues_map_callback(void *data,
|
||||||
|
struct t_hashtable *hashtable,
|
||||||
|
const void *key, const void *value)
|
||||||
|
{
|
||||||
|
struct t_twc_list *message_queue = ((struct t_twc_list *)value);
|
||||||
|
json_t *json_message_queues = data;
|
||||||
|
|
||||||
|
json_t *json_message_queue = json_array();
|
||||||
|
if (!json_message_queue)
|
||||||
|
return;
|
||||||
|
|
||||||
|
size_t index;
|
||||||
|
struct t_twc_list_item *item;
|
||||||
|
twc_list_foreach(message_queue, index, item)
|
||||||
|
{
|
||||||
|
struct t_twc_queued_message *queued_message = item->queued_message;
|
||||||
|
|
||||||
|
json_t *message = json_string(queued_message->message);
|
||||||
|
json_t *message_type = json_integer(queued_message->message_type);
|
||||||
|
json_t *timestamp = json_integer(mktime(queued_message->time));
|
||||||
|
json_t *message_object = json_object();
|
||||||
|
|
||||||
|
if (!message || !message_type || !timestamp || !message_object)
|
||||||
|
return;
|
||||||
|
|
||||||
|
json_object_set_new(message_object,
|
||||||
|
twc_json_key_message_queue_key_message,
|
||||||
|
message);
|
||||||
|
json_object_set_new(message_object,
|
||||||
|
twc_json_key_message_queue_key_message_type,
|
||||||
|
message_type);
|
||||||
|
json_object_set_new(message_object,
|
||||||
|
twc_json_key_message_queue_key_message_timestamp,
|
||||||
|
timestamp);
|
||||||
|
|
||||||
|
json_array_append_new(json_message_queue, message_object);
|
||||||
|
}
|
||||||
|
|
||||||
|
json_object_set_new(json_message_queues, key, json_message_queue);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Save a profile's message queue to a json object. Returns a new reference.
|
||||||
|
*/
|
||||||
|
json_t *
|
||||||
|
twc_data_save_profile_message_queues(struct t_twc_profile *profile)
|
||||||
|
{
|
||||||
|
json_t *message_queues = json_object();
|
||||||
|
|
||||||
|
weechat_hashtable_map(profile->message_queues,
|
||||||
|
twc_data_save_profile_message_queues_map_callback,
|
||||||
|
message_queues);
|
||||||
|
|
||||||
|
return message_queues;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Save a profile's data.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_save_profile(struct t_twc_profile *profile)
|
||||||
|
{
|
||||||
|
json_t *json_data = json_object();
|
||||||
|
if (!json_data)
|
||||||
|
return;
|
||||||
|
|
||||||
|
json_t *friend_requests = twc_data_save_profile_friend_requests(profile);
|
||||||
|
json_object_set_new(json_data,
|
||||||
|
twc_json_key_friend_requests,
|
||||||
|
friend_requests);
|
||||||
|
|
||||||
|
json_t *message_queues = twc_data_save_profile_message_queues(profile);
|
||||||
|
json_object_set_new(json_data,
|
||||||
|
twc_json_key_message_queues,
|
||||||
|
message_queues);
|
||||||
|
|
||||||
|
char *profile_key = twc_data_profile_key(profile);
|
||||||
|
json_object_set_new(twc_json_data, profile_key, json_data);
|
||||||
|
free(profile_key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load friend requests from a json array.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_load_profile_friend_requests(struct t_twc_profile *profile,
|
||||||
|
json_t *friend_requests)
|
||||||
|
{
|
||||||
|
twc_friend_request_free_profile(profile);
|
||||||
|
|
||||||
|
size_t index;
|
||||||
|
json_t *json_request;
|
||||||
|
json_array_foreach(friend_requests, index, json_request)
|
||||||
|
{
|
||||||
|
char client_id[TOX_CLIENT_ID_SIZE];
|
||||||
|
const char *message;
|
||||||
|
|
||||||
|
json_t *json_id = json_object_get(json_request,
|
||||||
|
twc_json_friend_request_key_tox_id);
|
||||||
|
json_t *json_message = json_object_get(json_request,
|
||||||
|
twc_json_friend_request_key_message);
|
||||||
|
|
||||||
|
twc_hex2bin(json_string_value(json_id), TOX_CLIENT_ID_SIZE, client_id);
|
||||||
|
message = json_string_value(json_message);
|
||||||
|
|
||||||
|
twc_friend_request_add(profile,
|
||||||
|
(uint8_t *)client_id,
|
||||||
|
message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load message queues from a json object.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_load_profile_message_queues(struct t_twc_profile *profile,
|
||||||
|
json_t *message_queues)
|
||||||
|
{
|
||||||
|
twc_message_queue_free_profile(profile);
|
||||||
|
|
||||||
|
const char *key;
|
||||||
|
json_t *message_queue;
|
||||||
|
json_object_foreach(message_queues, key, message_queue)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load an profile's data from a JSON object.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_profile_load(struct t_twc_identity *identity)
|
||||||
|
{
|
||||||
|
char *profile_key = twc_json_get_identity_key(identity);
|
||||||
|
json_t *profile_data = json_object_get(twc_json_data, identity_key);
|
||||||
|
free(profile_key);
|
||||||
|
|
||||||
|
json_t *friend_requests = json_object_get(profile_data,
|
||||||
|
twc_json_key_friend_requests);
|
||||||
|
if (friend_requests)
|
||||||
|
twc_data_load_friend_requests(profile, friend_requests);
|
||||||
|
|
||||||
|
json_t *unsent_messages = json_object_get(profile_data,
|
||||||
|
twc_json_key_unsent_messages);
|
||||||
|
if (unsent_messages)
|
||||||
|
twc_data_load_unsent_messages(profile, unsent_messages);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load the data on disk into memory.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_load()
|
||||||
|
{
|
||||||
|
char *full_path = twc_json_data_file_path();
|
||||||
|
|
||||||
|
|
||||||
|
json_error_t error;
|
||||||
|
twc_json_data = json_load_file(full_path, 0, &error);
|
||||||
|
free(full_path);
|
||||||
|
|
||||||
|
if (!twc_json_data)
|
||||||
|
{
|
||||||
|
weechat_printf(NULL,
|
||||||
|
"%s%s: could not load on-disk data",
|
||||||
|
weechat_prefix("error"),
|
||||||
|
weechat_plugin->name);
|
||||||
|
|
||||||
|
twc_json_data = json_object();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Save all in-memory data to data on disk. Return 0 on success, -1 on
|
||||||
|
* error.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
twc_data_save()
|
||||||
|
{
|
||||||
|
char *full_path = twc_json_data_file_path();
|
||||||
|
int rc = json_dump_file(twc_json_data,
|
||||||
|
full_path,
|
||||||
|
0);
|
||||||
|
free(full_path);
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Free in-memory JSON data.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
twc_data_free()
|
||||||
|
{
|
||||||
|
json_decref(twc_json_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,5 +20,24 @@
|
||||||
#ifndef TOX_WEECHAT_DATA_H
|
#ifndef TOX_WEECHAT_DATA_H
|
||||||
#define TOX_WEECHAT_DATA_H
|
#define TOX_WEECHAT_DATA_H
|
||||||
|
|
||||||
#endif // TOX_WEECHAT_DATA_H
|
struct t_twc_profile;
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_read();
|
||||||
|
|
||||||
|
int
|
||||||
|
twc_data_write();
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_load_profile(struct t_twc_profile *profile);
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_save_profile(struct t_twc_profile *profile);
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_delete_profile(struct t_twc_profile *profile);
|
||||||
|
|
||||||
|
void
|
||||||
|
twc_data_free();
|
||||||
|
|
||||||
|
#endif // TOX_WEECHAT_DATA_H
|
||||||
|
|
|
@ -155,6 +155,9 @@ twc_message_queue_free_map_callback(void *data, struct t_hashtable *hashtable,
|
||||||
free(message_queue);
|
free(message_queue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Free the entire message queue for a profile.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
twc_message_queue_free_profile(struct t_twc_profile *profile)
|
twc_message_queue_free_profile(struct t_twc_profile *profile)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue