/* Copyright (c) 2015-2018 Dovecot authors, see the included COPYING file */
#include "lib.h"
#include "hash.h"
#include "http-client.h"
#include "http-url.h"
#include "ioloop.h"
#include "istream.h"
#include "settings-parser.h"
#include "json-parser.h"
#include "mailbox-attribute.h"
#include "mail-storage-private.h"
#include "str.h"
#include "strescape.h"
#include "push-notification-drivers.h"
#include "push-notification-event-messagenew.h"
#include "push-notification-events.h"
#include "push-notification-txn-msg.h"
#define OX_METADATA_KEY \
/* Default values. */
/* This is data that is shared by all plugin users. */
struct push_notification_driver_ox_global {
int refcount;
};
/* This is data specific to an OX driver. */
struct push_notification_driver_ox_config {
unsigned int cached_ox_metadata_lifetime_secs;
bool use_unsafe_username;
unsigned int http_max_retries;
unsigned int http_timeout_msecs;
char *cached_ox_metadata;
};
/* This is data specific to an OX driver transaction. */
struct push_notification_driver_ox_txn {
const char *unsafe_user;
};
static void
struct push_notification_driver_ox_config *config)
{
/* this is going to use the first user's settings, but these are
unlikely to change between users so it shouldn't matter much. */
}
}
static int
{
/* Valid config keys: cache_lifetime, url */
return -1;
}
return -1;
}
return -1;
}
}
}
"Using cache lifetime: %u",
}
return 0;
}
static const char *push_notification_driver_ox_get_metadata
(struct push_notification_driver_txn *dtxn)
{
int ret;
return dconfig->cached_ox_metadata;
}
/* Get canonical INBOX, where private server-level metadata is stored.
* See imap/cmd-getmetadata.c */
} else {
}
OX_METADATA_KEY, &attr);
if (ret < 0) {
} else if (ret == 0) {
} else {
}
if (!use_existing_txn) {
}
if (!success)
return NULL;
return dconfig->cached_ox_metadata;
}
static bool push_notification_driver_ox_begin_txn
(struct push_notification_driver_txn *dtxn)
{
const char *const *args;
return FALSE;
}
/* Unused keys: events, expire, folder */
/* TODO: To be implemented later(?) */
if (expire < ioloop_time) {
"Skipped due to expiration (%ld < %ld)",
(long)expire, (long)ioloop_time);
return FALSE;
}
mbox_found = TRUE;
break;
}
}
if (mbox_found == FALSE) {
"Skipped because %s is not a watched mailbox",
return FALSE;
}
/* Valid keys: user */
}
}
}
return FALSE;
}
struct push_notification_event_messagenew_config, 1);
"Handling MessageNew event");
}
}
return TRUE;
}
static void push_notification_driver_ox_http_callback
{
case 2:
// Success.
if (user->mail_debug) {
"Notification sent successfully: %s",
}
break;
default:
// Error.
break;
}
}
/* Callback needed for i_stream_add_destroy_callback() in
* push_notification_driver_ox_process_msg. */
{
}
(struct push_notification_driver_txn *dtxn,
struct mailbox_status *r_box_status)
{
/* The already opened mailbox. We cannot use or sync it, because we are within a save transaction. */
int ret;
/* open and sync new instance of the same mailbox to get most recent status */
box = mailbox_alloc(mailbox_get_namespace(mbox)->list, mailbox_get_name(mbox), MAILBOX_FLAG_READONLY);
if (mailbox_sync(box, 0) < 0) {
i_error("mailbox_sync(%s) failed: %s", mailbox_get_vname(mbox), mailbox_get_last_internal_error(box, NULL));
ret = -1;
} else {
/* only 'unseen' is needed at the moment */
push_notification_driver_debug(OX_LOG_LABEL, dtxn->ptxn->muser, "Got status of mailbox '%s': (unseen: %u)",
ret = 0;
}
mailbox_free(&box);
return ret;
}
static void push_notification_driver_ox_process_msg
(struct push_notification_driver_txn *dtxn,
struct push_notification_txn_msg *msg)
{
}
if (messagenew == NULL) {
return;
}
user);
"application/json; charset=utf-8");
}
}
}
if (status_success) {
}
}
static void push_notification_driver_ox_deinit
{
}
}
static void push_notification_driver_ox_cleanup(void)
{
}
}
}
/* Driver definition */
extern struct push_notification_driver push_notification_driver_ox;
.name = "ox",
.v = {
}
};