mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-07 10:28:32 +00:00
Merged revisions 124121 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ................ r124121 | mmichelson | 2008-06-19 15:30:23 -0500 (Thu, 19 Jun 2008) | 16 lines Merged revisions 124112 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r124112 | mmichelson | 2008-06-19 15:28:41 -0500 (Thu, 19 Jun 2008) | 8 lines Fix IMAP forwarding so that messages are sent to the proper mailbox. (closes issue #12897) Reported by: jaroth Patches: destination_forward.patch uploaded by jaroth (license 50) ........ ................ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.0@124124 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -143,6 +143,7 @@ static void vm_imap_delete(int msgnum, struct vm_state *vms);
|
|||||||
static char *get_user_by_mailbox(char *mailbox, char *buf, size_t len);
|
static char *get_user_by_mailbox(char *mailbox, char *buf, size_t len);
|
||||||
static struct vm_state *get_vm_state_by_imapuser(char *user, int interactive);
|
static struct vm_state *get_vm_state_by_imapuser(char *user, int interactive);
|
||||||
static struct vm_state *get_vm_state_by_mailbox(const char *mailbox, int interactive);
|
static struct vm_state *get_vm_state_by_mailbox(const char *mailbox, int interactive);
|
||||||
|
static struct vm_state *create_vm_state_from_user(struct ast_vm_user *vmu, char *mailbox);
|
||||||
static void vmstate_insert(struct vm_state *vms);
|
static void vmstate_insert(struct vm_state *vms);
|
||||||
static void vmstate_delete(struct vm_state *vms);
|
static void vmstate_delete(struct vm_state *vms);
|
||||||
static void set_update(MAILSTREAM * stream);
|
static void set_update(MAILSTREAM * stream);
|
||||||
@@ -4494,6 +4495,9 @@ static int forward_message(struct ast_channel *chan, char *context, struct vm_st
|
|||||||
|
|
||||||
/* get destination mailbox */
|
/* get destination mailbox */
|
||||||
dstvms = get_vm_state_by_mailbox(vmtmp->mailbox, 0);
|
dstvms = get_vm_state_by_mailbox(vmtmp->mailbox, 0);
|
||||||
|
if (!dstvms) {
|
||||||
|
dstvms = create_vm_state_from_user(vmtmp, vmtmp->mailbox);
|
||||||
|
}
|
||||||
if (dstvms) {
|
if (dstvms) {
|
||||||
init_mailstream(dstvms, 0);
|
init_mailstream(dstvms, 0);
|
||||||
if (!dstvms->mailstream) {
|
if (!dstvms->mailstream) {
|
||||||
@@ -9666,6 +9670,27 @@ static char *get_user_by_mailbox(char *mailbox, char *buf, size_t len)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static struct vm_state *create_vm_state_from_user(struct ast_vm_user *vmu, char *mailbox)
|
||||||
|
{
|
||||||
|
struct vm_state *vms_p;
|
||||||
|
|
||||||
|
if (option_debug > 4)
|
||||||
|
ast_log(LOG_DEBUG,"Adding new vmstate for %s\n",vmu->imapuser);
|
||||||
|
if (!(vms_p = ast_calloc(1, sizeof(*vms_p))))
|
||||||
|
return NULL;
|
||||||
|
ast_copy_string(vms_p->imapuser,vmu->imapuser, sizeof(vms_p->imapuser));
|
||||||
|
ast_copy_string(vms_p->username, mailbox, sizeof(vms_p->username)); /* save for access from interactive entry point */
|
||||||
|
vms_p->mailstream = NIL; /* save for access from interactive entry point */
|
||||||
|
if (option_debug > 4)
|
||||||
|
ast_log(LOG_DEBUG,"Copied %s to %s\n",vmu->imapuser,vms_p->imapuser);
|
||||||
|
vms_p->updated = 1;
|
||||||
|
/* set mailbox to INBOX! */
|
||||||
|
ast_copy_string(vms_p->curbox, mbox(0), sizeof(vms_p->curbox));
|
||||||
|
init_vm_state(vms_p);
|
||||||
|
vmstate_insert(vms_p);
|
||||||
|
return vms_p;
|
||||||
|
}
|
||||||
|
|
||||||
static struct vm_state *get_vm_state_by_imapuser(char *user, int interactive)
|
static struct vm_state *get_vm_state_by_imapuser(char *user, int interactive)
|
||||||
{
|
{
|
||||||
struct vmstate *vlist = NULL;
|
struct vmstate *vlist = NULL;
|
||||||
|
|||||||
Reference in New Issue
Block a user