Ejemplo n.º 1
0
Archivo: local.py Proyecto: caitp/inbox
def local_copy(db_session, account, thread_id, from_folder, to_folder):
    """ Copy thread in the local datastore (*not* the account backend).

    NOT idempotent.
    """
    if from_folder == to_folder:
        return

    with db_write_lock(account.namespace.id):
        listings = {item.folder.name: item for item in
                    db_session.query(FolderItem).join(Folder).join(Thread)
                    .filter(
                        Thread.namespace_id == account.namespace.id,
                        FolderItem.thread_id == thread_id,
                        Folder.name.in_([from_folder, to_folder]))
                    .all()}
        if from_folder not in listings:
            raise LocalActionError("thread {} does not exist in folder {}"
                                   .format(thread_id, from_folder))
        elif to_folder not in listings:
            thread = listings[from_folder].thread
            folder = Folder.find_or_create(db_session,
                                           thread.namespace.account,
                                           to_folder)
            thread.folders.add(folder)
            db_session.commit()
Ejemplo n.º 2
0
Archivo: local.py Proyecto: caitp/inbox
def local_copy(db_session, account, thread_id, from_folder, to_folder):
    """ Copy thread in the local datastore (*not* the account backend).

    NOT idempotent.
    """
    if from_folder == to_folder:
        return

    with db_write_lock(account.namespace.id):
        listings = {
            item.folder.name: item
            for item in db_session.query(FolderItem).join(Folder).join(Thread).
            filter(Thread.namespace_id == account.namespace.id,
                   FolderItem.thread_id == thread_id,
                   Folder.name.in_([from_folder, to_folder])).all()
        }
        if from_folder not in listings:
            raise LocalActionError(
                "thread {} does not exist in folder {}".format(
                    thread_id, from_folder))
        elif to_folder not in listings:
            thread = listings[from_folder].thread
            folder = Folder.find_or_create(db_session,
                                           thread.namespace.account, to_folder)
            thread.folders.add(folder)
            db_session.commit()
Ejemplo n.º 3
0
Archivo: local.py Proyecto: caitp/inbox
def local_archive(db_session, account, thread_id):
    """ Archive thread in the local datastore (*not* the account backend).

    (Just removes it from Inbox!)

    Idempotent.
    """
    with db_write_lock(account.namespace.id):
        try:
            inbox_item = db_session.query(FolderItem).join(Thread).filter(
                Thread.namespace_id == account.namespace.id,
                FolderItem.thread_id == thread_id,
                FolderItem.folder_id == account.inbox_folder_id).one()
            db_session.delete(inbox_item)
        except NoResultFound:
            pass
        db_session.commit()
Ejemplo n.º 4
0
Archivo: local.py Proyecto: caitp/inbox
def local_delete(db_session, account, thread_id, folder_name):
    """ Delete thread in the local datastore (*not* the account backend).

    NOT idempotent. (Will throw an exception if the thread doesn't exist in
    `folder_name`.)
    """
    with db_write_lock(account.namespace.id):
        try:
            item = db_session.query(FolderItem).join(Folder).join(Thread)\
                .filter(Thread.namespace_id == account.namespace.id,
                        FolderItem.thread_id == thread_id,
                        Folder.name == folder_name).one()
            db_session.delete(item)
            db_session.commit()
        except NoResultFound:
            raise LocalActionError("thread {} does not exist in folder {}"
                                   .format(thread_id, folder_name))
Ejemplo n.º 5
0
Archivo: local.py Proyecto: caitp/inbox
def local_archive(db_session, account, thread_id):
    """ Archive thread in the local datastore (*not* the account backend).

    (Just removes it from Inbox!)

    Idempotent.
    """
    with db_write_lock(account.namespace.id):
        try:
            inbox_item = db_session.query(FolderItem).join(Thread).filter(
                Thread.namespace_id == account.namespace.id,
                FolderItem.thread_id == thread_id,
                FolderItem.folder_id == account.inbox_folder_id).one()
            db_session.delete(inbox_item)
        except NoResultFound:
            pass
        db_session.commit()
Ejemplo n.º 6
0
Archivo: local.py Proyecto: caitp/inbox
def local_delete(db_session, account, thread_id, folder_name):
    """ Delete thread in the local datastore (*not* the account backend).

    NOT idempotent. (Will throw an exception if the thread doesn't exist in
    `folder_name`.)
    """
    with db_write_lock(account.namespace.id):
        try:
            item = db_session.query(FolderItem).join(Folder).join(Thread)\
                .filter(Thread.namespace_id == account.namespace.id,
                        FolderItem.thread_id == thread_id,
                        Folder.name == folder_name).one()
            db_session.delete(item)
            db_session.commit()
        except NoResultFound:
            raise LocalActionError(
                "thread {} does not exist in folder {}".format(
                    thread_id, folder_name))
Ejemplo n.º 7
0
Archivo: imap.py Proyecto: jre21/inbox
    def __init__(self, account_id, namespace_id, email_address, provider, status_cb, heartbeat=1, poll_frequency=300):

        self.shared_state = {
            # IMAP folders are kept up-to-date via polling
            "poll_frequency": poll_frequency,
            "syncmanager_lock": db_write_lock(namespace_id),
        }

        self.folder_monitors = Group()
        if not hasattr(self, "folder_state_handlers"):
            self.folder_state_handlers = {
                "initial": initial_sync,
                "initial uidinvalid": resync_uids_from("initial"),
                "poll": poll,
                "poll uidinvalid": resync_uids_from("poll"),
                "finish": lambda c, s, l, f, st: "finish",
            }

        BaseMailSyncMonitor.__init__(self, account_id, email_address, provider, status_cb, heartbeat)
Ejemplo n.º 8
0
Archivo: imap.py Proyecto: cenk/inbox
    def __init__(self, account_id, namespace_id, email_address, provider,
            status_cb, heartbeat=1, poll_frequency=30):

        self.shared_state = {
                # IMAP folders are kept up-to-date via polling
                'poll_frequency': poll_frequency,
                'syncmanager_lock': db_write_lock(namespace_id),
                }

        self.folder_monitors = []
        if not hasattr(self, 'folder_state_handlers'):
            self.folder_state_handlers = {
                    'initial': initial_sync,
                    'initial uidinvalid': resync_uids_from('initial'),
                    'poll': poll,
                    'poll uidinvalid': resync_uids_from('poll'),
                    'finish': lambda c, s, l, f, st: 'finish',
                    }

        BaseMailSyncMonitor.__init__(self, account_id, email_address, provider,
                status_cb, heartbeat)
Ejemplo n.º 9
0
Archivo: local.py Proyecto: caitp/inbox
def set_local_unread(db_session, account, thread, unread):
    with db_write_lock(account.namespace.id):
        for message in thread.messages:
            message.is_read = not unread
Ejemplo n.º 10
0
Archivo: local.py Proyecto: caitp/inbox
def set_local_unread(db_session, account, thread, unread):
    with db_write_lock(account.namespace.id):
        for message in thread.messages:
            message.is_read = not unread