2014-02-25 08:28:24 +01:00
|
|
|
/* global_commands.c
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Copyright (C) 2014 Toxic All Rights Reserved.
|
|
|
|
*
|
|
|
|
* This file is part of Toxic.
|
|
|
|
*
|
|
|
|
* Toxic is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Toxic is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with Toxic. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
2013-11-10 03:43:56 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2014-06-22 03:41:38 +02:00
|
|
|
#include <arpa/inet.h>
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
#ifdef NO_GETTEXT
|
|
|
|
#define gettext(A) (A)
|
|
|
|
#else
|
|
|
|
#include <libintl.h>
|
|
|
|
#endif
|
|
|
|
|
2014-06-12 00:06:55 +02:00
|
|
|
#include "toxic.h"
|
|
|
|
#include "windows.h"
|
2013-11-10 03:43:56 +01:00
|
|
|
#include "misc_tools.h"
|
2013-11-30 00:52:21 +01:00
|
|
|
#include "friendlist.h"
|
2014-03-25 13:25:10 +01:00
|
|
|
#include "log.h"
|
2014-03-25 08:17:22 +01:00
|
|
|
#include "line_info.h"
|
2014-06-17 03:22:26 +02:00
|
|
|
#include "dns.h"
|
2014-06-22 03:41:38 +02:00
|
|
|
#include "groupchat.h"
|
|
|
|
#include "prompt.h"
|
2014-07-04 09:24:29 +02:00
|
|
|
#include "help.h"
|
2015-03-11 23:38:07 +01:00
|
|
|
#include "term_mplex.h"
|
2015-04-04 09:26:38 +02:00
|
|
|
#include "avatars.h"
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
extern char *DATA_FILE;
|
2013-11-19 21:32:35 +01:00
|
|
|
extern ToxWindow *prompt;
|
2014-09-28 23:49:48 +02:00
|
|
|
extern FriendsList Friends;
|
|
|
|
extern FriendRequests FrndRequests;
|
2013-11-30 00:52:21 +01:00
|
|
|
|
2013-11-10 03:43:56 +01:00
|
|
|
/* command functions */
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_accept(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2014-08-04 20:35:34 +02:00
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Request ID required."));
|
2014-03-25 08:17:22 +01:00
|
|
|
return;
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2013-11-12 08:41:55 +01:00
|
|
|
int req = atoi(argv[1]);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-08-20 02:49:29 +02:00
|
|
|
if ((req == 0 && strcmp(argv[1], "0")) || req < 0 || req > MAX_FRIEND_REQUESTS) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("No pending friend request with that ID."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
if (!FrndRequests.request[req].active) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("No pending friend request with that ID."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
TOX_ERR_FRIEND_ADD err;
|
|
|
|
uint32_t friendnum = tox_friend_add_norequest(m, FrndRequests.request[req].key, &err);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
if (err != TOX_ERR_FRIEND_ADD_OK) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Failed to add friend (error %d)\n"), err);
|
2015-03-26 03:56:45 +01:00
|
|
|
return;
|
|
|
|
} else {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Friend request accepted."));
|
2013-12-04 07:08:26 +01:00
|
|
|
on_friendadded(m, friendnum, true);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
memset(&FrndRequests.request[req], 0, sizeof(struct friend_request));
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
int i;
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
for (i = FrndRequests.max_idx; i > 0; --i) {
|
|
|
|
if (FrndRequests.request[i - 1].active)
|
2013-11-10 03:43:56 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
FrndRequests.max_idx = i;
|
|
|
|
--FrndRequests.num_requests;
|
2015-03-26 03:56:45 +01:00
|
|
|
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
void cmd_add_helper(ToxWindow *self, Tox *m, const char *id_bin, const char *msg)
|
2014-06-18 01:10:25 +02:00
|
|
|
{
|
2014-07-29 20:54:34 +02:00
|
|
|
const char *errmsg;
|
2014-06-18 01:10:25 +02:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
TOX_ERR_FRIEND_ADD err;
|
|
|
|
uint32_t f_num = tox_friend_add(m, (uint8_t *) id_bin, (uint8_t *) msg, strlen(msg), &err);
|
|
|
|
|
|
|
|
switch (err) {
|
|
|
|
case TOX_ERR_FRIEND_ADD_TOO_LONG:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Message is too long.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_NO_MESSAGE:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Please add a message to your request.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_OWN_KEY:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("That appears to be your own ID.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_ALREADY_SENT:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Friend request has already been sent.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_BAD_CHECKSUM:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Bad checksum in address.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_SET_NEW_NOSPAM:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Nospam was different.");
|
2014-06-18 01:10:25 +02:00
|
|
|
break;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
case TOX_ERR_FRIEND_ADD_MALLOC:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Core memory allocation failed.");
|
2015-03-26 03:56:45 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TOX_ERR_FRIEND_ADD_OK:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Friend request sent.");
|
2014-06-18 01:10:25 +02:00
|
|
|
on_friendadded(m, f_num, true);
|
|
|
|
break;
|
2015-03-26 03:56:45 +01:00
|
|
|
|
|
|
|
case TOX_ERR_FRIEND_ADD_NULL:
|
|
|
|
/* fallthrough */
|
|
|
|
default:
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Failed to add friend: Unknown error.");
|
2015-03-28 07:56:54 +01:00
|
|
|
break;
|
|
|
|
}
|
2014-06-18 01:10:25 +02:00
|
|
|
|
2014-07-25 04:43:32 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, errmsg);
|
2014-06-18 01:10:25 +02:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_add(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Tox ID or address required."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
const char *id = argv[1];
|
2014-07-07 04:15:35 +02:00
|
|
|
char msg[MAX_STR_SIZE];
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
if (argc > 1) {
|
2014-07-29 20:54:34 +02:00
|
|
|
if (argv[2][0] != '\"') {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Message must be enclosed in quotes."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
/* remove opening and closing quotes */
|
|
|
|
char tmp[MAX_STR_SIZE];
|
|
|
|
snprintf(tmp, sizeof(tmp), "%s", &argv[2][1]);
|
|
|
|
int len = strlen(tmp) - 1;
|
|
|
|
tmp[len] = '\0';
|
|
|
|
snprintf(msg, sizeof(msg), "%s", tmp);
|
2013-11-18 05:14:27 +01:00
|
|
|
} else {
|
2014-07-07 04:15:35 +02:00
|
|
|
char selfname[TOX_MAX_NAME_LENGTH];
|
2015-03-26 03:56:45 +01:00
|
|
|
tox_self_get_name(m, (uint8_t *) selfname);
|
|
|
|
|
|
|
|
size_t n_len = tox_self_get_name_size(m);
|
2014-04-01 04:00:17 +02:00
|
|
|
selfname[n_len] = '\0';
|
2015-05-25 16:38:52 +02:00
|
|
|
snprintf(msg, sizeof(msg), gettext("Hello, my name is %s. Care to Tox?"), selfname);
|
2013-11-18 05:14:27 +01:00
|
|
|
}
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
char id_bin[TOX_ADDRESS_SIZE] = {0};
|
2014-07-07 04:15:35 +02:00
|
|
|
uint16_t id_len = (uint16_t) strlen(id);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-06-17 03:22:26 +02:00
|
|
|
/* try to add tox ID */
|
2015-03-26 03:56:45 +01:00
|
|
|
if (id_len == 2 * TOX_ADDRESS_SIZE) {
|
2014-06-17 03:22:26 +02:00
|
|
|
size_t i;
|
|
|
|
char xx[3];
|
|
|
|
uint32_t x;
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
for (i = 0; i < TOX_ADDRESS_SIZE; ++i) {
|
2014-06-17 03:22:26 +02:00
|
|
|
xx[0] = id[2 * i];
|
|
|
|
xx[1] = id[2 * i + 1];
|
|
|
|
xx[2] = '\0';
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-06-17 03:22:26 +02:00
|
|
|
if (sscanf(xx, "%02x", &x) != 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Invalid Tox ID."));
|
2014-06-17 03:22:26 +02:00
|
|
|
return;
|
|
|
|
}
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-06-17 03:22:26 +02:00
|
|
|
id_bin[i] = x;
|
|
|
|
}
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-06-18 01:10:25 +02:00
|
|
|
cmd_add_helper(self, m, id_bin, msg);
|
|
|
|
} else { /* assume id is a username@domain address and do DNS lookup */
|
|
|
|
dns3_lookup(self, m, id_bin, id, msg);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-26 09:10:44 +02:00
|
|
|
void cmd_avatar(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
|
|
|
{
|
2015-04-04 09:26:38 +02:00
|
|
|
if (argc < 2 || strlen(argv[1]) < 3) {
|
|
|
|
avatar_unset(m);
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Avatar is not set."));
|
2015-04-04 09:26:38 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argv[1][0] != '\"') {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Path must be enclosed in quotes."));
|
2015-04-04 09:26:38 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* remove opening and closing quotes */
|
|
|
|
char path[MAX_STR_SIZE];
|
|
|
|
snprintf(path, sizeof(path), "%s", &argv[1][1]);
|
|
|
|
int len = strlen(path) - 1;
|
|
|
|
|
|
|
|
if (len <= 0) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Invalid path."));
|
2015-04-04 09:26:38 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
path[len] = '\0';
|
|
|
|
char filename[MAX_STR_SIZE];
|
|
|
|
get_file_name(filename, sizeof(filename), path);
|
|
|
|
|
|
|
|
if (avatar_set(m, path, len) == -1) {
|
2015-04-05 03:15:34 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0,
|
2015-05-25 16:38:52 +02:00
|
|
|
gettext("Failed to set avatar. Avatars must be in PNG format and may not exceed %d bytes."),
|
2015-04-05 03:15:34 +02:00
|
|
|
MAX_AVATAR_FILE_SIZE);
|
2015-04-04 09:26:38 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Avatar set to '%s'"), filename);
|
2014-09-26 09:10:44 +02:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_clear(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2014-03-26 02:43:49 +01:00
|
|
|
line_info_clear(self->chatwin->hst);
|
2014-10-01 22:24:36 +02:00
|
|
|
force_refresh(window);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_connect(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
|
|
|
if (argc != 3) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Require: <ip> <port> <key>"));
|
2014-04-19 23:58:13 +02:00
|
|
|
return;
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-07-07 04:15:35 +02:00
|
|
|
const char *ip = argv[1];
|
|
|
|
const char *port = argv[2];
|
|
|
|
const char *key = argv[3];
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
if (atoi(port) == 0) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Invalid port."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-07 04:15:35 +02:00
|
|
|
char *binary_string = hex_string_to_bin(key);
|
2015-03-28 07:56:54 +01:00
|
|
|
|
|
|
|
TOX_ERR_BOOTSTRAP err;
|
|
|
|
tox_bootstrap(m, ip, atoi(port), (uint8_t *) binary_string, &err);
|
2015-05-24 23:56:30 +02:00
|
|
|
tox_add_tcp_relay(m, ip, atoi(port), (uint8_t *) binary_string, &err);
|
2013-11-10 03:43:56 +01:00
|
|
|
free(binary_string);
|
2015-03-28 07:56:54 +01:00
|
|
|
|
|
|
|
switch (err) {
|
|
|
|
case TOX_ERR_BOOTSTRAP_BAD_HOST:
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Bootstrap failed: Invalid IP."));
|
2015-03-28 07:56:54 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TOX_ERR_BOOTSTRAP_BAD_PORT:
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Bootstrap failed: Invalid port."));
|
2015-03-28 07:56:54 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TOX_ERR_BOOTSTRAP_NULL:
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Bootstrap failed."));
|
2015-03-28 07:56:54 +01:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-08-25 20:08:01 +02:00
|
|
|
void cmd_decline(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
|
|
|
{
|
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Request ID required."));
|
2014-08-25 20:08:01 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
int req = atoi(argv[1]);
|
|
|
|
|
|
|
|
if ((req == 0 && strcmp(argv[1], "0")) || req < 0 || req > MAX_FRIEND_REQUESTS) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("No pending friend request with that ID."));
|
2014-08-25 20:08:01 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
if (!FrndRequests.request[req].active) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("No pending friend request with that ID."));
|
2014-08-25 20:08:01 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
memset(&FrndRequests.request[req], 0, sizeof(struct friend_request));
|
2014-08-25 20:08:01 +02:00
|
|
|
|
|
|
|
int i;
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
for (i = FrndRequests.max_idx; i > 0; --i) {
|
|
|
|
if (FrndRequests.request[i - 1].active)
|
2014-08-25 20:08:01 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
FrndRequests.max_idx = i;
|
|
|
|
--FrndRequests.num_requests;
|
2014-08-25 20:08:01 +02:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_groupchat(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2014-03-07 01:39:57 +01:00
|
|
|
if (get_num_active_windows() >= MAX_WINDOWS_NUM) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, RED, gettext(" * Warning: Too many windows are open."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-11-12 02:49:05 +01:00
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Please specify group type: %s"), "text|audio");
|
2014-11-12 02:49:05 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-11-15 21:55:45 +01:00
|
|
|
uint8_t type;
|
|
|
|
|
|
|
|
if (!strcasecmp(argv[1], "audio"))
|
|
|
|
type = TOX_GROUPCHAT_TYPE_AV;
|
|
|
|
else if (!strcasecmp(argv[1], "text"))
|
|
|
|
type = TOX_GROUPCHAT_TYPE_TEXT;
|
|
|
|
else {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Valid group types are: %s"), "text|audio");
|
2014-11-15 21:55:45 +01:00
|
|
|
return;
|
|
|
|
}
|
2014-11-12 02:49:05 +01:00
|
|
|
|
|
|
|
int groupnum = -1;
|
|
|
|
|
|
|
|
if (type == TOX_GROUPCHAT_TYPE_TEXT)
|
|
|
|
groupnum = tox_add_groupchat(m);
|
|
|
|
#ifdef AUDIO
|
|
|
|
else
|
2015-04-04 09:26:38 +02:00
|
|
|
groupnum = toxav_add_av_groupchat(m, NULL, NULL);
|
2014-11-12 02:49:05 +01:00
|
|
|
#endif
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
if (groupnum == -1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Group chat instance failed to initialize."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-11-12 02:49:05 +01:00
|
|
|
if (init_groupchat_win(prompt, m, groupnum, type) == -1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Group chat window failed to initialize."));
|
2013-11-10 03:43:56 +01:00
|
|
|
tox_del_groupchat(m, groupnum);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Group chat [%d] created."), groupnum);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-02-27 01:00:13 +01:00
|
|
|
void cmd_log(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
|
|
|
{
|
2014-07-29 20:54:34 +02:00
|
|
|
const char *msg;
|
2014-03-24 12:37:52 +01:00
|
|
|
struct chatlog *log = self->chatwin->log;
|
2014-02-27 01:00:13 +01:00
|
|
|
|
2014-03-24 12:37:52 +01:00
|
|
|
if (argc == 0) {
|
2014-03-25 08:17:22 +01:00
|
|
|
if (log->log_on)
|
2015-05-25 16:38:52 +02:00
|
|
|
msg = gettext("Logging for this window is ON. Type \"/log off\" to disable.");
|
2014-03-25 08:17:22 +01:00
|
|
|
else
|
2015-05-25 16:38:52 +02:00
|
|
|
msg = gettext("Logging for this window is OFF. Type \"/log on\" to enable.");
|
2014-02-27 01:45:11 +01:00
|
|
|
|
2014-07-25 04:43:32 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, msg);
|
2014-02-27 01:00:13 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
const char *swch = argv[1];
|
2014-02-27 01:00:13 +01:00
|
|
|
|
|
|
|
if (!strcmp(swch, "1") || !strcmp(swch, "on")) {
|
2015-03-26 03:56:45 +01:00
|
|
|
char myid[TOX_ADDRESS_SIZE];
|
|
|
|
tox_self_get_address(m, (uint8_t *) myid);
|
2014-03-02 00:06:35 +01:00
|
|
|
|
2014-02-28 05:33:00 +01:00
|
|
|
if (self->is_chat) {
|
2014-08-07 19:05:42 +02:00
|
|
|
Friends.list[self->num].logging_on = true;
|
2014-09-22 23:09:39 +02:00
|
|
|
log_enable(self->name, myid, Friends.list[self->num].pub_key, log, LOG_CHAT);
|
2014-03-02 00:06:35 +01:00
|
|
|
} else if (self->is_prompt) {
|
2014-09-22 23:09:39 +02:00
|
|
|
log_enable(self->name, myid, NULL, log, LOG_PROMPT);
|
2014-03-02 00:06:35 +01:00
|
|
|
} else if (self->is_groupchat) {
|
2014-09-22 23:09:39 +02:00
|
|
|
log_enable(self->name, myid, NULL, log, LOG_GROUP);
|
2014-02-28 05:33:00 +01:00
|
|
|
}
|
2014-02-27 01:00:13 +01:00
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
msg = gettext("Logging enabled");
|
2014-07-25 04:43:32 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, msg);
|
2014-02-27 01:00:13 +01:00
|
|
|
return;
|
|
|
|
} else if (!strcmp(swch, "0") || !strcmp(swch, "off")) {
|
2014-03-24 12:37:52 +01:00
|
|
|
if (self->is_chat)
|
2014-08-07 19:05:42 +02:00
|
|
|
Friends.list[self->num].logging_on = false;
|
2014-03-24 12:37:52 +01:00
|
|
|
|
|
|
|
log_disable(log);
|
2014-02-27 01:00:13 +01:00
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
msg = gettext("Logging disabled");
|
2014-07-25 04:43:32 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, msg);
|
2014-02-27 01:00:13 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-05-25 16:38:52 +02:00
|
|
|
msg = gettext("Invalid option. Use \"%s\" to toggle logging.");
|
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, msg, "/log on|off");
|
2014-02-27 01:00:13 +01:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_myid(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2015-03-26 03:56:45 +01:00
|
|
|
char id[TOX_ADDRESS_SIZE * 2 + 1] = {0};
|
|
|
|
char address[TOX_ADDRESS_SIZE];
|
|
|
|
tox_self_get_address(m, (uint8_t *) address);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
size_t i;
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
for (i = 0; i < TOX_ADDRESS_SIZE; ++i) {
|
2013-11-10 03:43:56 +01:00
|
|
|
char xx[3];
|
|
|
|
snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff);
|
|
|
|
strcat(id, xx);
|
|
|
|
}
|
|
|
|
|
2014-08-02 21:35:57 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "%s", id);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_nick(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2013-11-26 23:39:11 +01:00
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Input required."));
|
2014-04-19 23:58:13 +02:00
|
|
|
return;
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
char nick[MAX_STR_SIZE];
|
2015-03-26 03:56:45 +01:00
|
|
|
size_t len = 0;
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
if (argv[1][0] == '\"') { /* remove opening and closing quotes */
|
|
|
|
snprintf(nick, sizeof(nick), "%s", &argv[1][1]);
|
|
|
|
len = strlen(nick) - 1;
|
2014-07-07 04:15:35 +02:00
|
|
|
nick[len] = '\0';
|
2014-07-29 20:54:34 +02:00
|
|
|
} else {
|
|
|
|
snprintf(nick, sizeof(nick), "%s", argv[1]);
|
|
|
|
len = strlen(nick);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2013-11-28 08:53:43 +01:00
|
|
|
if (!valid_nick(nick)) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Invalid name."));
|
2013-11-28 08:53:43 +01:00
|
|
|
return;
|
2013-11-28 01:34:15 +01:00
|
|
|
}
|
|
|
|
|
2014-04-19 23:58:13 +02:00
|
|
|
len = MIN(len, TOXIC_MAX_NAME_LENGTH - 1);
|
2014-07-07 04:15:35 +02:00
|
|
|
nick[len] = '\0';
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
tox_self_set_name(m, (uint8_t *) nick, len, NULL);
|
2014-07-07 04:15:35 +02:00
|
|
|
prompt_update_nick(prompt, nick);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
|
|
|
store_data(m, DATA_FILE);
|
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_note(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
|
|
|
if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Input required."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
if (argv[1][0] != '\"') {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Note must be enclosed in quotes."));
|
2013-11-10 03:43:56 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
/* remove opening and closing quotes */
|
|
|
|
char msg[MAX_STR_SIZE];
|
|
|
|
snprintf(msg, sizeof(msg), "%s", &argv[1][1]);
|
2014-07-07 05:08:36 +02:00
|
|
|
int len = strlen(msg) - 1;
|
|
|
|
msg[len] = '\0';
|
2014-07-29 20:54:34 +02:00
|
|
|
|
2014-08-12 09:01:18 +02:00
|
|
|
prompt_update_statusmessage(prompt, m, msg);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_prompt_help(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-15 20:38:58 +01:00
|
|
|
{
|
2014-07-04 09:24:29 +02:00
|
|
|
help_init_menu(self);
|
2013-11-15 20:38:58 +01:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_quit(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2013-11-10 03:43:56 +01:00
|
|
|
{
|
2014-06-18 21:54:05 +02:00
|
|
|
exit_toxic_success(m);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2014-08-20 02:49:29 +02:00
|
|
|
void cmd_requests(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
|
|
|
{
|
2014-09-28 23:49:48 +02:00
|
|
|
if (FrndRequests.num_requests == 0) {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("No pending friend requests."));
|
2014-08-20 02:49:29 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-08-20 05:40:49 +02:00
|
|
|
int i, j;
|
2014-08-20 02:49:29 +02:00
|
|
|
int count = 0;
|
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
for (i = 0; i < FrndRequests.max_idx; ++i) {
|
|
|
|
if (!FrndRequests.request[i].active)
|
2014-08-20 02:49:29 +02:00
|
|
|
continue;
|
|
|
|
|
2015-02-01 21:09:48 +01:00
|
|
|
char id[TOX_PUBLIC_KEY_SIZE * 2 + 1] = {0};
|
2014-08-20 02:49:29 +02:00
|
|
|
|
2015-02-01 21:09:48 +01:00
|
|
|
for (j = 0; j < TOX_PUBLIC_KEY_SIZE; ++j) {
|
2014-08-20 02:49:29 +02:00
|
|
|
char d[3];
|
2014-09-28 23:49:48 +02:00
|
|
|
snprintf(d, sizeof(d), "%02X", FrndRequests.request[i].key[j] & 0xff);
|
2014-08-20 02:49:29 +02:00
|
|
|
strcat(id, d);
|
|
|
|
}
|
|
|
|
|
2014-08-20 05:40:49 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "%d : %s", i, id);
|
2014-09-28 23:49:48 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "%s", FrndRequests.request[i].msg);
|
2014-08-20 02:49:29 +02:00
|
|
|
|
2014-09-28 23:49:48 +02:00
|
|
|
if (++count < FrndRequests.num_requests)
|
2014-08-20 02:49:29 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, "");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-19 21:32:35 +01:00
|
|
|
void cmd_status(WINDOW *window, ToxWindow *self, Tox *m, int argc, char (*argv)[MAX_STR_SIZE])
|
2015-03-11 23:38:07 +01:00
|
|
|
{
|
2014-07-29 20:54:34 +02:00
|
|
|
bool have_note = false;
|
|
|
|
const char *errmsg;
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-02-26 22:51:20 +01:00
|
|
|
lock_status ();
|
|
|
|
|
2013-11-10 03:43:56 +01:00
|
|
|
if (argc >= 2) {
|
2014-07-29 20:54:34 +02:00
|
|
|
have_note = true;
|
2014-08-04 20:35:34 +02:00
|
|
|
} else if (argc < 1) {
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Require a status. Statuses are: %s.");
|
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, errmsg, "online|busy|away");
|
2015-02-26 22:51:20 +01:00
|
|
|
goto finish;
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2015-03-28 07:56:54 +01:00
|
|
|
const char *status_str = argv[1];
|
2015-03-26 03:56:45 +01:00
|
|
|
TOX_USER_STATUS status;
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
if (!strcasecmp(status_str, "online"))
|
|
|
|
status = TOX_USER_STATUS_NONE;
|
|
|
|
else if (!strcasecmp(status_str, "away"))
|
|
|
|
status = TOX_USER_STATUS_AWAY;
|
|
|
|
else if (!strcasecmp(status_str, "busy"))
|
|
|
|
status = TOX_USER_STATUS_BUSY;
|
2013-11-10 03:43:56 +01:00
|
|
|
else {
|
2015-05-25 16:38:52 +02:00
|
|
|
errmsg = gettext("Invalid status. Valid statuses are: %s.");
|
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, errmsg, "online|busy|away");
|
2015-02-26 22:51:20 +01:00
|
|
|
goto finish;
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
|
|
|
|
2015-03-26 03:56:45 +01:00
|
|
|
tox_self_set_status(m, status);
|
|
|
|
prompt_update_status(prompt, status);
|
2013-11-10 03:43:56 +01:00
|
|
|
|
2014-07-29 20:54:34 +02:00
|
|
|
if (have_note) {
|
|
|
|
if (argv[2][0] != '\"') {
|
2015-05-25 16:38:52 +02:00
|
|
|
line_info_add(self, NULL, NULL, NULL, SYS_MSG, 0, 0, gettext("Note must be enclosed in quotes."));
|
2015-02-26 22:51:20 +01:00
|
|
|
goto finish;
|
2014-07-29 20:54:34 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* remove opening and closing quotes */
|
|
|
|
char msg[MAX_STR_SIZE];
|
|
|
|
snprintf(msg, sizeof(msg), "%s", &argv[2][1]);
|
2014-07-07 05:08:36 +02:00
|
|
|
int len = strlen(msg) - 1;
|
2014-07-29 20:54:34 +02:00
|
|
|
msg[len] = '\0';
|
|
|
|
|
2014-08-12 09:01:18 +02:00
|
|
|
prompt_update_statusmessage(prompt, m, msg);
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|
2015-02-26 22:51:20 +01:00
|
|
|
|
|
|
|
finish:
|
|
|
|
unlock_status ();
|
2013-11-10 03:43:56 +01:00
|
|
|
}
|