2012-07-09 15:25:08 +05:30
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
# This script is for cleaning up of all data from system including
|
|
|
|
# all transactions and masters (excludes default masters).
|
|
|
|
# Basically after running this file, system will reset to it's
|
|
|
|
# initial state.
|
|
|
|
# This script can be executed from lib/wnf.py using
|
|
|
|
# lib/wnf.py --cleanup-data
|
|
|
|
|
2012-07-19 13:40:31 +05:30
|
|
|
from __future__ import unicode_literals
|
2012-07-09 15:25:08 +05:30
|
|
|
import sys
|
|
|
|
sys.path.append("lib/py")
|
|
|
|
sys.path.append(".")
|
|
|
|
sys.path.append("erpnext")
|
|
|
|
|
|
|
|
import webnotes
|
|
|
|
|
|
|
|
#--------------------------------
|
|
|
|
|
|
|
|
def delete_transactions():
|
|
|
|
print "Deleting transactions..."
|
|
|
|
|
|
|
|
trans = ['Timesheet','Task','Support Ticket','Stock Reconciliation', 'Stock Ledger Entry', \
|
|
|
|
'Stock Entry','Sales Order','Salary Slip','Sales Invoice','Quotation', 'Quality Inspection', \
|
|
|
|
'Purchase Receipt','Purchase Order','Production Order', 'POS Setting','Period Closing Voucher', \
|
|
|
|
'Purchase Invoice','Maintenance Visit','Maintenance Schedule','Leave Application', \
|
2013-02-18 13:49:15 +05:30
|
|
|
'Leave Allocation', 'Lead', 'Journal Voucher', 'Installation Note','Material Request', \
|
2012-07-09 15:25:08 +05:30
|
|
|
'GL Entry','Expense Claim','Opportunity','Delivery Note','Customer Issue','Bin', \
|
2012-09-28 16:03:11 +05:30
|
|
|
'Authorization Rule','Attendance', 'C-Form', 'Form 16A', 'Lease Agreement', \
|
2012-07-09 15:25:08 +05:30
|
|
|
'Lease Installment', 'TDS Payment', 'TDS Return Acknowledgement', 'Appraisal', \
|
|
|
|
'Installation Note', 'Communication'
|
|
|
|
]
|
|
|
|
for d in trans:
|
|
|
|
for t in webnotes.conn.sql("select options from tabDocField where parent='%s' and fieldtype='Table'" % d):
|
|
|
|
webnotes.conn.sql("delete from `tab%s`" % (t))
|
|
|
|
webnotes.conn.sql("delete from `tab%s`" % (d))
|
|
|
|
print "Deleted " + d
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def delete_masters():
|
|
|
|
print "Deleting masters...."
|
|
|
|
masters = {
|
|
|
|
'Workstation':['Default Workstation'],
|
|
|
|
'Warehouse Type':['Default Warehouse Type', 'Fixed Asset', 'Rejected', 'Reserved',
|
|
|
|
'Sample', 'Stores', 'WIP Warehouse'],
|
|
|
|
'Warehouse':['Default Warehouse'],
|
|
|
|
'UOM':['Kg', 'Mtr', 'Box', 'Ltr', 'Nos', 'Ft', 'Pair', 'Set'],
|
|
|
|
'Territory':['All Territories', 'Default Territory'],
|
|
|
|
'Terms and Conditions':'',
|
|
|
|
'Tag':'',
|
|
|
|
'Supplier Type':['Default Supplier Type'],
|
|
|
|
'Supplier':'',
|
|
|
|
'Serial No':'',
|
|
|
|
'Sales Person':['All Sales Persons'],
|
|
|
|
'Sales Partner':'',
|
|
|
|
'Sales BOM':'',
|
|
|
|
'Salary Structure':'',
|
|
|
|
'Purchase Taxes and Charges Master':'',
|
|
|
|
'Project':'',
|
|
|
|
'Print Heading':'',
|
|
|
|
'Price List':['Default Price List'],
|
|
|
|
'Sales Taxes and Charges Master':'',
|
|
|
|
'Letter Head':'',
|
|
|
|
'Leave Type':['Leave Without Pay', 'Privilege Leave', 'Casual Leave', 'PL', 'CL', 'LWP',
|
|
|
|
'Compensatory Off', 'Sick Leave'],
|
|
|
|
'Appraisal Template':'',
|
|
|
|
'Item Group':['All Item Groups', 'Default'],
|
|
|
|
'Item':'',
|
|
|
|
'Holiday List':'',
|
|
|
|
'Grade':'',
|
|
|
|
'Feed':'',
|
|
|
|
'Expense Claim Type':['Travel', 'Medical', 'Calls', 'Food', 'Others'],
|
|
|
|
'Event':'',
|
|
|
|
'Employment Type':'',
|
|
|
|
'Employee':'',
|
|
|
|
'Earning Type':['Basic', 'Conveyance', 'House Rent Allowance', 'Dearness Allowance',
|
|
|
|
'Medical Allowance', 'Telephone'],
|
|
|
|
'Designation':'',
|
|
|
|
'Department':'',
|
|
|
|
'Deduction Type':['Income Tax', 'Professional Tax', 'Provident Fund', 'Leave Deduction'],
|
|
|
|
'Customer Group':['All Customer Groups', 'Default Customer Group'],
|
|
|
|
'Customer':'',
|
|
|
|
'Cost Center':'',
|
|
|
|
'Contact':'',
|
|
|
|
'Campaign':'',
|
|
|
|
'Budget Distribution':'',
|
|
|
|
'Brand':'',
|
|
|
|
'Branch':'',
|
|
|
|
'Batch':'',
|
|
|
|
'Appraisal':'',
|
|
|
|
'Account':'',
|
|
|
|
'BOM': ''
|
|
|
|
}
|
|
|
|
for d in masters.keys():
|
|
|
|
for t in webnotes.conn.sql("select options from tabDocField where parent='%s' \
|
|
|
|
and fieldtype='Table'" % d):
|
|
|
|
webnotes.conn.sql("delete from `tab%s`" % (t))
|
|
|
|
lst = '"'+'","'.join(masters[d])+ '"'
|
|
|
|
webnotes.conn.sql("delete from `tab%s` where name not in (%s)" % (d, lst))
|
|
|
|
print "Deleted " + d
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-09-18 11:19:34 +05:30
|
|
|
def reset_all_series():
|
|
|
|
# Reset master series
|
|
|
|
webnotes.conn.sql("""update tabSeries set current = 0 where name not in
|
|
|
|
('Ann/', 'BSD', 'DEF', 'DF', 'EV', 'Event Updates/', 'FileData-',
|
|
|
|
'FL', 'FMD/', 'GLM Detail', 'Login Page/', 'MDI', 'MDR', 'MI', 'MIR',
|
|
|
|
'PERM', 'PR', 'SRCH/C/', 'TD', 'TIC/', 'TMD/', 'TW', 'UR', '_FEED',
|
2012-07-09 16:06:53 +05:30
|
|
|
'_SRCH', '_TRIGGER', '__NSO', 'CustomField', 'Letter')
|
2012-07-09 15:25:08 +05:30
|
|
|
""")
|
|
|
|
print "Series updated"
|
2012-09-18 11:19:34 +05:30
|
|
|
|
|
|
|
def reset_transaction_series():
|
|
|
|
webnotes.conn.sql("""update tabSeries set current = 0 where name in
|
|
|
|
('JV', 'INV', 'BILL', 'SO', 'DN', 'PO', 'LEAD', 'ENQUIRY', 'ENQ', 'CI',
|
|
|
|
'IN', 'PS', 'IDT', 'QAI', 'QTN', 'STE', 'SQTN', 'SUP', 'TDSP', 'SR',
|
|
|
|
'POS', 'LAP', 'LAL', 'EXP')""")
|
|
|
|
print "Series updated"
|
2012-07-09 15:25:08 +05:30
|
|
|
|
|
|
|
|
|
|
|
def delete_main_masters():
|
|
|
|
main_masters = ['Fiscal Year','Company', 'DefaultValue']
|
|
|
|
for d in main_masters:
|
|
|
|
for t in webnotes.conn.sql("select options from tabDocField where parent='%s' and fieldtype='Table'" % d):
|
|
|
|
webnotes.conn.sql("delete from `tab%s`" % (t))
|
|
|
|
webnotes.conn.sql("delete from `tab%s`" % (d))
|
|
|
|
print "Deleted " + d
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def reset_global_defaults():
|
|
|
|
flds = {
|
|
|
|
'default_company': '',
|
|
|
|
'default_currency': '',
|
|
|
|
'current_fiscal_year': '',
|
|
|
|
'date_format': 'dd-mm-yyyy',
|
|
|
|
'sms_sender_name': '',
|
|
|
|
'default_item_group': 'Default',
|
|
|
|
'default_stock_uom': 'Nos',
|
|
|
|
'default_valuation_method': 'FIFO',
|
|
|
|
'default_warehouse_type': 'Default Warehouse Type',
|
|
|
|
'tolerance': '',
|
|
|
|
'acc_frozen_upto': '',
|
|
|
|
'bde_auth_role': '',
|
|
|
|
'credit_controller': '',
|
|
|
|
'default_customer_group': 'Default Customer Group',
|
|
|
|
'default_territory': 'Default',
|
|
|
|
'default_price_list': 'Standard',
|
|
|
|
'default_supplier_type': 'Default Supplier Type'
|
|
|
|
}
|
|
|
|
|
|
|
|
from webnotes.model.code import get_obj
|
|
|
|
gd = get_obj('Global Defaults', 'Global Defaults')
|
|
|
|
for d in flds:
|
|
|
|
gd.doc.fields[d] = flds[d]
|
|
|
|
gd.doc.save()
|
|
|
|
|
|
|
|
webnotes.clear_cache()
|
|
|
|
|
|
|
|
|
|
|
|
def run():
|
|
|
|
webnotes.connect()
|
2012-10-09 15:19:59 +02:00
|
|
|
webnotes.conn.begin()
|
2012-07-09 15:25:08 +05:30
|
|
|
|
|
|
|
# Confirmation from user
|
|
|
|
confirm = ''
|
|
|
|
while not confirm:
|
|
|
|
confirm = raw_input("Are you sure you want to delete the data from the system (N/Y)?")
|
|
|
|
if confirm.lower() != 'y':
|
|
|
|
raise Exception
|
|
|
|
|
|
|
|
cleanup_type = ''
|
|
|
|
while cleanup_type not in ['1', '2']:
|
|
|
|
cleanup_type = raw_input("""\nWhat type of cleanup you want ot perform?
|
|
|
|
1. Only Transactions
|
|
|
|
2. Both Masters and Transactions
|
|
|
|
|
|
|
|
Please enter your choice (1/2):
|
|
|
|
""")
|
|
|
|
|
|
|
|
# delete
|
|
|
|
delete_transactions()
|
|
|
|
|
2012-09-18 11:19:34 +05:30
|
|
|
if cleanup_type == '1':
|
2012-10-09 15:19:59 +02:00
|
|
|
print "Reset Transaction Series"
|
2012-09-18 11:19:34 +05:30
|
|
|
reset_transaction_series()
|
2012-07-09 15:25:08 +05:30
|
|
|
else:
|
|
|
|
delete_masters()
|
2012-10-09 15:19:59 +02:00
|
|
|
print "Reset All Series"
|
2012-09-18 11:19:34 +05:30
|
|
|
reset_all_series()
|
2012-07-09 15:25:08 +05:30
|
|
|
delete_main_masters()
|
|
|
|
reset_global_defaults()
|
|
|
|
|
|
|
|
print "System cleaned up succesfully"
|
2012-10-09 15:19:59 +02:00
|
|
|
webnotes.conn.commit()
|
2012-07-09 15:25:08 +05:30
|
|
|
webnotes.conn.close()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
run()
|