Rev 1132 | Rev 1263 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
#!/usr/bin/pythonimport datetimeimport optparseimport sysimport csvimport xlrdif __name__ == '__main__' and __package__ is None:import ossys.path.insert(0, os.getcwd())from shop2020.clients.LogisticsClient import LogisticsClientfrom shop2020.clients.TransactionClient import TransactionClientfrom shop2020.thriftpy.model.v1.order.ttypes import TransactionServiceExceptionfrom shop2020.utils.EmailAttachmentDownloader import download_attachmentfrom shop2020.utils.Utils import to_py_datedef process_pickup_records(provider):filename = fetch_report('PICKUP REPORT')pickup_details = read_pickup_report(filename)orders_not_picked_up = update_picked_orders(provider.id, pickup_details)if orders_not_picked_up:print "Some of our orders were not picked up. Printing report to: PickupMismatch.csv"print_discrepancy_report("PickupMismatch.csv", orders_not_picked_up)def process_delivery_report(provider):filename = fetch_report('DELIVERED AND RTO REPORT')#filename = 'delivery_report.xls'delivered_orders, returned_orders = read_delivery_report(filename)update_delivered_orders(provider.id, delivered_orders)update_returned_orders(provider.id, returned_orders)#TODO: Send returned orders in a maildef process_non_delivery_report(provider):filename = fetch_report('UNDELIVERED REPORT')def get_provider_by_name(provider_name):logistics_client = LogisticsClient().get_client()#FIXME: Write a thrift call to get a provider by nameprovider = Noneproviders = logistics_client.getAllProviders()for p in providers:if p.name == provider_name:provider=pbreakif provider == None:sys.exit("Can't continue execution: No such provider")return providerdef fetch_report(type):filename = download_attachment(type, todays_date_string())if filename is None:sys.exit("The " + type + " report is not yet available.")return filenamedef read_pickup_report(filename):print "Reading pickup report from:" + filenameworkbook = xlrd.open_workbook(filename)sheet = workbook.sheet_by_index(0)num_rows = sheet.nrowspicked_up_orders = {}for rownum in range(1, num_rows):unused_customer_code, awb, date, time = sheet.row_values(rownum)[0:4]picked_up_orders[awb] = 0 #TODO: Use the date and time value in the reportprint "Picked up Orders:"print picked_up_ordersreturn picked_up_ordersdef read_delivery_report(filename):print "Reading delivery details from:" + filenameworkbook = xlrd.open_workbook(filename)sheet = workbook.sheet_by_index(0)num_rows = sheet.nrowsdelivered_orders = {}returned_orders = {}for rownum in range(1, num_rows):unused_customer_code, awb, date, time, status, receiver, reason_for_return = sheet.row_values(rownum)[0:7]if receiver: #TODO: Use status for this checkdelivered_orders[awb] = str(datetime.datetime.now()) + "|" + receiver #TODO: Use the date and time value in the reportelse:returned_orders[awb] = str(datetime.datetime.now()) + "|" + reason_for_returnprint "Delivered Orders:"print delivered_ordersprint "Returned Orders:"print returned_ordersreturn delivered_orders, returned_ordersdef update_picked_orders(provider_id, pickup_details):txnClient = TransactionClient().get_client()try:orders_not_picked_up = txnClient.markOrdersAsPickedUp(provider_id, pickup_details)return orders_not_picked_upexcept TransactionServiceException as tex:print tex.messagedef update_delivered_orders(provider_id, delivered_orders):txnClient = TransactionClient().get_client()try:txnClient.markOrdersAsDelivered(provider_id, delivered_orders)except TransactionServiceException as tex:print tex.messagedef update_returned_orders(provider_id, returned_orders):txnClient = TransactionClient().get_client()try:txnClient.markOrdersAsFailed(provider_id, returned_orders)except TransactionServiceException as tex:print tex.messagedef print_discrepancy_report(filename, orders):writer = csv.writer(open(filename, "wb"), delimiter=',', quoting=csv.QUOTE_NONE)writer.writerow(['Order Id', 'AWB No', 'Shipping timestamp'])for order in orders:writer.writerow([order.id, order.airwaybill_no, to_py_date(order.shipping_timestamp)])def todays_date_string():return '"24-Mar-2011"'def main():parser = optparse.OptionParser()parser.add_option("-p", "--pickup", dest="pickup_report",action="store_true",help="Run the pickup reconciliation")parser.add_option("-d", "--delivery", dest="delivery_report",action="store_true",help="Run the delivery reconciliation")parser.add_option("-n", "--non-delivery", dest="non_delivery_report",action="store_true",help="Run the non delivery reconciliation")parser.add_option("-a", "--all", dest="all_reports",action="store_true",help="Run all reconciliations")parser.add_option("-P", "--provider", dest="provider",default="BlueDart", type="string",help="The PROVIDER this report is for",metavar="PROVIDER")parser.set_defaults(pickup_report=False, delivery_report=False, non_delivery_report=False, all_reports=False)(options, args) = parser.parse_args()if len(args) != 0:parser.error("You've supplied extra arguments. Are you sure you want to run this program?")if options.all_reports:options.pickup_report = Trueoptions.delivery_report = Trueoptions.non_delivery_report = Trueprovider = get_provider_by_name(options.provider)if options.pickup_report:process_pickup_records(provider)if options.delivery_report:process_delivery_report(provider)if options.non_delivery_report:process_non_delivery_report(provider)if __name__ == '__main__':main()