Implement the parsing of message shares (attachments) [closes #14]

v1
Tony Olagbaiye 7 years ago
parent 4e8e378ae5
commit 59a9b463a3
No known key found for this signature in database
GPG Key ID: 7420820577A31D11

@ -84,6 +84,7 @@
- [ ] Implement handling api message =message.message_changed= - [ ] Implement handling api message =message.message_changed=
- [ ] Implement handling api message =message.message_deleted= - [ ] Implement handling api message =message.message_deleted=
- [ ] Implement handling api message =message.message_replied= - [ ] Implement handling api message =message.message_replied=
- [ ] Implement handling api message =message.file_share=
- [ ] Implement sending websocket =typing= message - [ ] Implement sending websocket =typing= message
** TODO [#B] Implement completion engine (milestone v0.3) ** TODO [#B] Implement completion engine (milestone v0.3)
- [X] +Tab completion for slack emoji (see [[http://github.com/bqv/weechat-slack/issues/3][#3]])+ - [X] +Tab completion for slack emoji (see [[http://github.com/bqv/weechat-slack/issues/3][#3]])+

@ -124,6 +124,31 @@ int slack_api_message_message_handle(struct t_slack_workspace *workspace,
return 1; return 1;
} }
int slack_api_message_attachment_handle(struct t_slack_workspace *workspace,
const char *channel, const char *user,
const char *text, const char *ts)
{
struct t_slack_channel *ptr_channel;
struct t_slack_user *ptr_user;
ptr_channel = slack_channel_search(workspace, channel);
if (!ptr_channel)
return 1; /* silently ignore if channel hasn't been loaded yet */
ptr_user = slack_user_search(workspace, user);
if (!ptr_user)
return 1; /* silently ignore if user hasn't been loaded yet */
weechat_printf_date_tags(
ptr_channel->buffer,
(time_t)atof(ts),
"slack_message",
_("%s%s"),
"++\t",
text);
return 1;
}
int slack_api_message_route_message(struct t_slack_workspace *workspace, int slack_api_message_route_message(struct t_slack_workspace *workspace,
const char *subtype, const char *subtype,
json_object *message) json_object *message)
@ -155,6 +180,8 @@ int slack_api_message(struct t_slack_workspace *workspace,
json_object *message) json_object *message)
{ {
json_object *subtype, *channel, *user, *text, *ts; json_object *subtype, *channel, *user, *text, *ts;
json_object *attachments, *attachment, *fallback;
int i, rc;
subtype = json_object_object_get(message, "subtype"); subtype = json_object_object_get(message, "subtype");
if (!subtype) if (!subtype)
@ -175,11 +202,32 @@ int slack_api_message(struct t_slack_workspace *workspace,
if (!json_valid(ts, workspace)) if (!json_valid(ts, workspace))
return 0; return 0;
return slack_api_message_message_handle(workspace, rc = slack_api_message_message_handle(workspace,
json_object_get_string(channel), json_object_get_string(channel),
json_object_get_string(user), json_object_get_string(user),
json_object_get_string(text), json_object_get_string(text),
json_object_get_string(ts)); json_object_get_string(ts));
attachments = json_object_object_get(message, "attachments");
if (json_valid(attachments, workspace))
{
for (i = json_object_array_length(attachments); i > 0; i--)
{
attachment = json_object_array_get_idx(attachments, i - 1);
if (!json_valid(attachment, workspace))
continue;
fallback = json_object_object_get(attachment, "fallback");
if (!json_valid(fallback, workspace))
continue;
slack_api_message_attachment_handle(workspace,
json_object_get_string(channel),
json_object_get_string(user),
json_object_get_string(fallback),
json_object_get_string(ts));
}
}
return rc;
} }
else else
{ /* special message */ { /* special message */

Loading…
Cancel
Save