Example #1
0
def new_drop():
    FirstName = str(search_value('first_name', str(current_user.username)))
    LastName = str(search_value('last_name', current_user.username))
    if request.method == 'POST':
        user = str(current_user.username)
        I_name = request.form["Item_name"]
        I_cost = request.form["Item_cost"]
        I_desc = request.form["Item_desc"]
        location = request.form["location"]
        url = request.form["main_image"]
        url2 = request.form["main2_image"]
        url3 = request.form["main3_image"]
        url4 = request.form["main4_image"]
        url5 = request.form["main5_image"]
        S_name = str(current_user.username)
        B_name = 'None'
        txid = newOrder(S_name, B_name, I_name, I_desc, I_cost, location)
        if url != "undefined":
            url_id = search_OrderValue('img_url', txid=txid)
            newImage(url_id, txid, user, url)
        if url2 != "undefined":
            url_id = search_OrderValue('img_url', txid=txid)
            newImage(url_id, txid, user, url2)
        if url3 != "undefined":
            url_id = search_OrderValue('img_url', txid=txid)
            newImage(url_id, txid, user, url3)
        if url4 != "undefined":
            url_id = search_OrderValue('img_url', txid=txid)
            newImage(url_id, txid, user, url4)
        if url5 != "undefined":
            url_id = search_OrderValue('img_url', txid=txid)
            newImage(url_id, txid, user, url5)
        return redirect(url_for('active_drops'))
    return render_template("new_drop.html", FirstName = FirstName,\
    LastName = LastName)
Example #2
0
def boxUse(chat_id):
    if request.method == 'POST':
        item = search_OrderValue('I_name', txid=chat_id)

        sub = request.form.get("submit")
        if sub == 'submit':
            confirm_msg = dropStatus(chat_id, current_user.username, msg=True)
            codeView = requestCode(chat_id, current_user.username)
            return render_template("boxUse.html", code = codeView, item = item,\
            confirm_msg = confirm_msg)

    else:
        b_user = search_OrderValue('B_username', txid=chat_id)
        s_user = search_OrderValue('S_username', txid=chat_id)
        confirm_msg = dropStatus(chat_id, current_user.username, msg=True)
        stage = search_ChatValue('stage', chat_id)
        if stage == "Buyer Access" and current_user.username == b_user:
            code_msg = "Request Box Access Code"
        elif stage == "Seller Access" and current_user.username == s_user:
            code_msg = "Request Box Access Code"
        elif stage == "Buyer Access" and current_user.username == s_user:
            code_msg = "Item successfully dropped!"
        elif stage == "Seller Access" and current_user.username == b_user:
            code_msg = "Awaiting seller drop..."
        else:
            code_msg = 'Confirm transaction before requesting an access code.'
        item = search_OrderValue('I_name', txid=chat_id)
        return render_template("boxUse.html",code = code_msg, item = item,\
        confirm_msg = confirm_msg, stage=stage)
Example #3
0
def completeMoneyTransfer(txid):
    cost = search_OrderValue('cost', txid)
    b_user = search_OrderValue('B_username', txid)
    s_user = search_OrderValue('S_username', txid)
    b_bucks = searchBucks(b_user) - cost
    s_bucks = searchBucks(s_user) + cost
    updateBucks(b_user, b_bucks)
    updateBucks(s_user, s_bucks)
    return cost
Example #4
0
def dropStatus(txid, user, msg = None, status = None):
    connect_codelog()
    drop_status = search_OrderValue('status', txid = txid)
    b_user = search_OrderValue('B_username', txid = txid)
    s_user = search_OrderValue('S_username', txid = txid)
    if drop_status == "Buyer_Seller_TX_Confirm":
        confirm_msg = "Sale Confirmed!"
        tx_status = "Buyer_Seller_TX_Confirm"

    elif drop_status == "ITEM RETURNED":
        confirm_msg = "The item has been successfully returned by the buyer."
        tx_status = "ITEM RETURNED"

    elif drop_status == "FALSE RETURN":
        confirm_msg = "The buyer attempted a false return, transaction completed."
        tx_status = "ITEM FALSE RETURNED"

    elif drop_status == "TRANSACTION COMPLETE":
        confirm_msg = "Transaction complete!"
        tx_status = "TRANSACTION COMPLETE"

    else:
        if user == b_user:

            if drop_status == "Buyer_TX_Confirm":
                confirm_msg = 'Awaiting seller confirmation.'
                tx_status = "Buyer_TX_Confirm"

            elif drop_status == "Seller_TX_Confirm":
                confirm_msg = 'Confirm Buy.'
                tx_status = "Buyer_Seller_TX_Confirm"


            elif drop_status == 'None':
                confirm_msg = 'Confirm Buy.'
                tx_status = 'Buyer_TX_Confirm'


        elif user == s_user:

            if drop_status == "Seller_TX_Confirm":
                confirm_msg = 'Awaiting buyer confirmation.'
                tx_status = 'Seller_TX_Confirm'

            elif drop_status == "Buyer_TX_Confirm":
                confirm_msg = 'Confirm Sale.'
                tx_status = "Buyer_Seller_TX_Confirm"

            elif drop_status == 'None':
                confirm_msg = 'Confirm Sale.'
                tx_status = 'Seller_TX_Confirm'

    if msg == True:
        return confirm_msg
    elif status == True:
        return tx_status
Example #5
0
def buypage(txid):
    FirstName = str(search_value('first_name', str(current_user.username)))
    LastName = str(search_value('last_name', current_user.username))

    if request.method == 'POST':
        SellerName = str(search_OrderValue('S_username', txid=txid))
        sub = request.form.get("submit")
        if sub == 'submit':
            msg = request.form.get("message")
            newMsg(txid, current_user.username, SellerName,
                   current_user.username, msg)
            confirmBuyer(current_user.username, txid)
            return (redirect(url_for('active_drops')))
    else:
        url = []
        img = search_allImages(search_OrderValue('img_url', txid=txid))
        for item in img:
            try:
                img_url = item.url
                img_url = str(img_url)
                url.append(img_url)
            except IndexError:
                img_url = ""
                url.append(img_url)
        item_name = search_OrderValue('I_name', txid=txid)
        location = search_OrderValue('Location', txid=txid)
        item_desc = search_OrderValue('description', txid=txid)
        item_cost = search_OrderValue('Cost', txid=txid)
        SellerName = search_OrderValue('S_username', txid=txid)
        date_init = date_time(search_OrderValue('date_initialized', txid=txid))
        return render_template("buyPage(new).html", FirstName = FirstName, \
            LastName = LastName, i_name = item_name,\
            location = location, i_desc = item_desc, i_cost = item_cost,\
            SellerName = SellerName, date_init = date_init, \
            currentuser = current_user.username, txid = txid, url=url)
Example #6
0
def transactionpage(chat_id):
    FirstName = str(search_value('first_name', str(current_user.username)))
    LastName = str(search_value('last_name', current_user.username))

    request_code = url_for('confirmTX', chat_id=chat_id)
    code_msg = dropStatus(chat_id, current_user.username, msg=True)
    if search_OrderValue('status', txid=chat_id) == "Buyer_Seller_TX_Confirm":
        code_msg = 'Request Box Access Code'
    item_name = search_OrderValue('I_name', txid=chat_id)
    location = search_OrderValue('Location', txid=chat_id)
    item_desc = search_OrderValue('description', txid=chat_id)
    item_cost = search_OrderValue('Cost', txid=chat_id)
    buy_user = search_OrderValue('B_username', txid=chat_id)
    sell_user = search_OrderValue('S_username', txid=chat_id)
    date_init = date_time(search_OrderValue('date_initialized', txid=chat_id))
    oldMsg = searchMsg(chat_id)
    oldMsgTime = []
    oldMsgMsg = []
    oldMsgSender = []
    for item in oldMsg:
        try:
            oldMsgSender.append(item.Sender_username)
            oldMsgMsg.append(item.msg)
            oldMsgTime.append(date_time(item.msg_date))
        except TypeError:
            oldMsgTime.append('<i>time not available</i>')


    return render_template('message.html', currentuser = \
    str(current_user.username), FirstName=FirstName, LastName=LastName, \
    chatid = chat_id, item_name=item_name, location = location, \
    item_desc=item_desc, item_cost=item_cost, buy_user=buy_user, \
    sell_user=sell_user, date_init=date_init, oldMsgMsg = oldMsgMsg, oldMsgSender=oldMsgSender,\
    request_code = request_code, code_msg = code_msg, oldMsgTime=oldMsgTime)
Example #7
0
def newBoxAssignment(txid, box_id):
    B_username = search_OrderValue('B_username', txid=txid)
    S_username = search_OrderValue('S_username', txid=txid)
    stage = 'Seller Access'
    date = None
    code = None
    status = None
    new_entry = ConnectData(TXID = txid, B_username = B_username, \
        S_username = S_username, stage = stage, box_id = box_id, \
        access_code = code, expiry_time = date, code_attempt = code, attempt_time = date, seller_close_date = date, \
        buyer_close_date = date, door_status = status, scale_status = status, scale_delta = status)
    db.session.add(new_entry)
    db.session.commit()
    db.session.close()
Example #8
0
def newBoxAssignment(txid, box_id):
    connect_codelog()
    conn=psycopg2.connect("dbname='SafeDrop_KeypadCode' user='******' password='******' host='localhost' port = '5432'")
    cur=conn.cursor()
    B_username = search_OrderValue('B_username', txid = txid)
    S_username = search_OrderValue('S_username', txid = txid)
    stage = 'Seller Access'
    date = None
    code = None
    status = None
    cur.execute("INSERT INTO codelog VALUES(default, %s, %s, %s, %s, %s, %s, %s,\
    %s, %s, %s, %s, %s, %s, %s)", \
    (txid, B_username, S_username, stage, box_id, code, date, code, date, date,\
    date, status, status, status))
    conn.commit()
    conn.close()
Example #9
0
def confirmTX(chat_id):
    #dropStatus updates as per current values
    tx_status = dropStatus(chat_id, current_user.username, status=True)
    order_status = search_OrderValue('status', txid=chat_id)

    if order_status != "Buyer_Seller_TX_Confirm":
        statusUpdate(tx_status, chat_id)
        return redirect(url_for('transactionpage', chat_id=chat_id))

    if order_status == "Buyer_Seller_TX_Confirm":
        newBoxAssignment(chat_id, "SafeDrop UBC Box 1")
        return redirect(url_for('boxUse', chat_id=chat_id))
Example #10
0
def history():
    FirstName = str(search_value('first_name', str(current_user.username)))
    LastName = str(search_value('last_name', current_user.username))

    h_txid = search_allOrders(SUN=current_user.username,
                              BUN=current_user.username)
    h_txids = []
    b_names = []
    s_names = []
    h_item = []
    h_price = []
    h_location = []
    h_date_open = []
    h_date_close = []
    h_status = []
    h_txstatus = []
    h_url = []
    for item in h_txid:
        txid = str(item)
        h_txids.append(item.TXID)
        b_names.append(item.B_username)
        s_names.append(item.S_username)
        h_item.append(item.I_name)
        h_price.append(item.Cost)
        h_location.append(item.Location)
        h_date_open.append(item.date_initialized)
        h_date_close.append(item.date_resolved)
        h_txstatus.append(item.status)
        h_status.append(search_OrderValue('status', item.TXID))
        h_url.append(item.img_url)
    currentuser = current_user.username
    return render_template('history.html', FirstName=FirstName, currentuser=currentuser, \
        LastName = LastName, h_txids=h_txids, b_names=b_names, s_names=s_names,\
        h_item=h_item, h_price=h_price, h_location=h_location, h_url=h_url,\
        h_date_open=h_date_open, h_date_close=h_date_close,\
        h_status=h_status, h_txstatus = h_txstatus)
Example #11
0
def active_drops():
    FirstName = str(search_value('first_name', str(current_user.username)))
    LastName = str(search_value('last_name', current_user.username))

    s_txid = search_OrderValue('TXID', S_username=current_user.username)
    s_txids = []
    s_names = []
    s_other_user = []
    s_price = []
    s_location = []
    s_date = []
    s_return = []

    a_txids = []
    a_names = []
    a_price = []
    a_location = []
    a_date = []

    for item in s_txid:
        txid = str(item)
        if (search_OrderValue('status', txid=txid) != "TRANSACTION COMPLETE"):
            if (search_OrderValue('B_username', txid=txid)) != 'None':
                s_txids.append(txid)
                s_names.append(search_OrderValue('I_name', txid=txid))
                s_other_user.append(search_OrderValue('B_username', txid=txid))
                s_price.append(search_OrderValue('Cost', txid=txid))
                s_location.append(search_OrderValue('Location', txid=txid))
                s_date.append(
                    date_time(search_OrderValue('date_initialized',
                                                txid=txid)))
                if (search_OrderValue('status', txid=txid) == "ITEM RETURNED"):
                    s_return.append('waiting')
                else:
                    s_return.append('else')
            else:
                txid = str(item)
                a_txids.append(txid)
                a_names.append(search_OrderValue('I_name', txid=txid))
                a_price.append(search_OrderValue('Cost', txid=txid))
                a_location.append(search_OrderValue('Location', txid=txid))
                a_date.append(
                    date_time(search_OrderValue('date_initialized',
                                                txid=txid)))

    b_txid = search_OrderValue('TXID', B_username=current_user.username)
    b_txids = []
    b_names = []
    b_other_user = []
    b_price = []
    b_location = []
    b_date = []
    for item in b_txid:
        txid = str(item)
        if (search_OrderValue('status', txid=txid) != "TRANSACTION COMPLETE"):
            b_txids.append(txid)
            b_names.append(search_OrderValue('I_name', txid=txid))
            b_other_user.append(search_OrderValue('S_username', txid=txid))
            b_price.append(search_OrderValue('Cost', txid=txid))
            b_location.append(search_OrderValue('Location', txid=txid))
            b_date.append(
                date_time(search_OrderValue('date_initialized', txid=txid)))
    currentuser = current_user.username
    return render_template('active_drops.html', FirstName=FirstName, \
        LastName = LastName, s_txids=s_txids, b_txids = b_txids,\
        s_names=s_names, b_names=b_names, s_other_user = s_other_user, \
        s_price = s_price, s_location = s_location, s_date = s_date,\
        b_other_user = b_other_user, b_price = b_price, b_location = b_location\
        , b_date = b_date, a_price = a_price, a_location = a_location\
        , a_date = a_date, a_txids=a_txids, a_names=a_names, s_return=s_return)