Added queries to add/delete user to group

This commit is contained in:
vysheng 2013-11-07 04:08:16 +04:00
parent 8d4dcf313c
commit 18bc09b201
5 changed files with 97 additions and 20 deletions

View File

@ -256,6 +256,8 @@ char *commands[] = {
"create_secret_chat",
"suggested_contacts",
"global_search",
"chat_add_user",
"chat_del_user",
0 };
int commands_flags[] = {
@ -287,6 +289,8 @@ int commands_flags[] = {
071,
07,
07,
0724,
0724,
};
int get_complete_mode (void) {
@ -658,6 +662,16 @@ void interpreter (char *line UU) {
GET_PEER;
int limit = next_token_int ();
do_get_history (id, limit > 0 ? limit : 40);
} else if (IS_WORD ("chat_add_user")) {
GET_PEER_CHAT;
peer_id_t chat_id = id;
GET_PEER_USER;
do_add_user_to_chat (chat_id, id, 100);
} else if (IS_WORD ("chat_del_user")) {
GET_PEER_CHAT;
peer_id_t chat_id = id;
GET_PEER_USER;
do_del_user_from_chat (chat_id, id);
} else if (IS_WORD ("add_contact")) {
int phone_len, first_name_len, last_name_len;
char *phone, *first_name, *last_name;

View File

@ -56,6 +56,7 @@ void push_color (const char *color);
void print_start (void);
void print_end (void);
void print_date_full (long t);
void print_date (long t);
void update_prompt (void);
#endif

View File

@ -728,6 +728,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
fetch_pts ();
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" %d messages marked as read\n", n);
pop_color ();
print_end ();
@ -739,6 +740,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *U = user_chat_get (id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (id, U);
printf (" is typing....\n");
@ -754,6 +756,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *U = user_chat_get (id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (id, U);
printf (" is typing in chat ");
@ -771,6 +774,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
fetch_user_status (&U->user.status);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (user_id, U);
printf (" is now ");
@ -791,6 +795,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
struct user *U = &UC->user;
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (user_id, UC);
if (U->first_name) { free (U->first_name); }
@ -835,6 +840,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (user_id, UC);
printf (" updated profile photo\n");
@ -867,6 +873,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
int n = fetch_int ();
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" Restored %d messages\n", n);
pop_color ();
print_end ();
@ -880,6 +887,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
int n = fetch_int ();
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" Deleted %d messages\n", n);
pop_color ();
print_end ();
@ -899,6 +907,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *C = user_chat_get (chat_id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" Chat ");
print_chat_name (chat_id, C);
printf (" changed list: now %d members\n", n);
@ -913,6 +922,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
fetch_int (); // date
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (user_id, U);
printf (" registered\n");
@ -926,6 +936,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *U = user_chat_get (user_id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" Updated link with user ");
print_user_name (user_id, U);
printf ("\n");
@ -949,6 +960,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *U = user_chat_get (user_id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" User ");
print_user_name (user_id, U);
printf (" activated\n");
@ -964,6 +976,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
char *location = fetch_str_dup ();
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" New autorization: device='%s' location='%s'\n",
s, location);
pop_color ();
@ -994,6 +1007,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
struct secret_chat *E = fetch_alloc_encrypted_chat ();
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
switch (E->state) {
case sc_none:
assert (0);
@ -1033,6 +1047,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
peer_t *P = user_chat_get (id);
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
if (P) {
printf (" User ");
peer_id_t user_id = MK_USER (P->encr_chat.user_id);
@ -1067,6 +1082,7 @@ void work_update (struct connection *c UU, long long msg_id UU) {
}
print_start ();
push_color (COLOR_YELLOW);
print_date (time (0));
printf (" Encrypted chat ");
print_encr_chat_name_full (id, user_chat_get (id));
printf (": %d messages marked read \n", x);

View File

@ -2438,6 +2438,50 @@ void do_get_suggested (void) {
}
/* }}} */
/* {{{ Add user to chat */
struct query_methods add_user_to_chat_methods = {
.on_answer = fwd_msg_on_answer
};
void do_add_user_to_chat (peer_id_t chat_id, peer_id_t id, int limit) {
clear_packet ();
out_int (CODE_messages_add_chat_user);
out_int (get_peer_id (chat_id));
assert (get_peer_type (id) == PEER_USER);
peer_t *U = user_chat_get (id);
if (U && U->user.access_hash) {
out_int (CODE_input_user_foreign);
out_int (get_peer_id (id));
out_long (U->user.access_hash);
} else {
out_int (CODE_input_user_contact);
out_int (get_peer_id (id));
}
out_int (limit);
send_query (DC_working, packet_ptr - packet_buffer, packet_buffer, &add_user_to_chat_methods, 0);
}
void do_del_user_from_chat (peer_id_t chat_id, peer_id_t id) {
clear_packet ();
out_int (CODE_messages_delete_chat_user);
out_int (get_peer_id (chat_id));
assert (get_peer_type (id) == PEER_USER);
peer_t *U = user_chat_get (id);
if (U && U->user.access_hash) {
out_int (CODE_input_user_foreign);
out_int (get_peer_id (id));
out_long (U->user.access_hash);
} else {
out_int (CODE_input_user_contact);
out_int (get_peer_id (id));
}
send_query (DC_working, packet_ptr - packet_buffer, packet_buffer, &add_user_to_chat_methods, 0);
}
/* }}} */
/* {{{ Create secret chat */
char *create_print_name (peer_id_t id, const char *a1, const char *a2, const char *a3, const char *a4);

View File

@ -103,5 +103,7 @@ void do_get_difference (void);
void do_mark_read (peer_id_t id);
void do_visualize_key (peer_id_t id);
void do_create_keys_end (struct secret_chat *U);
void do_add_user_to_chat (peer_id_t chat_id, peer_id_t id, int limit);
void do_del_user_from_chat (peer_id_t chat_id, peer_id_t id);
#endif