aboutsummaryrefslogblamecommitdiffstats
path: root/queue2pgsql.py
blob: f5be1d9c12f790eea38bbfa86cf21f1bcd53f854 (plain) (tree)
1
2
3
4
5
6
7
8
9
                      
                                         





                              
 
                               

                                                        

            
                               





                                                           
                                     




                         



                                       
                      



                                                                                       
#!/usr/bin/env python3
''' move items from queue to database '''

import os
import time
import pickle
import sqlite3
from litequeue import SQLQueue

from common.postgres import dbi

QUEUE_DB = os.environ.get('el_QUEUE_db', 'litequeue.db')

# Unlock all
con = sqlite3.connect(QUEUE_DB)
cur = con.cursor()
cur.execute("UPDATE Queue SET status = 0 WHERE status = 1")
con.commit()
con.close()

# Open Queue
q = SQLQueue(QUEUE_DB, maxsize=None) 
q.prune()

# Event loop
while True:
    if q.empty() == True:
        time.sleep(10)
        continue
    task = q.pop()
    raw = pickle.loads(task['message'])
    dbi(raw[0],raw[1])
    print("Processed " + str(task['message_id']) + ". " + str(q.qsize() - 1) + " left")
    q.done(task['message_id'])

print("END")