import webnotes def execute(): """ * Remove unnecessary doctype properties * Remove docfield property setters if fieldname doesn't exist * Remove prev_field properties if value fieldname doesn't exist """ clean_doctype_properties() clean_docfield_properties() def clean_doctype_properties(): desc = webnotes.conn.sql("DESC `tabDocType`", as_dict=1) property_list = '", "'.join([d.get('Field') for d in desc]) webnotes.conn.sql("""\ DELETE FROM `tabProperty Setter` WHERE doctype_or_field = 'DocType' AND property NOT IN ("%s")""" % property_list) def clean_docfield_properties(): delete_list_1 = webnotes.conn.sql("""\ SELECT name FROM `tabProperty Setter` ps WHERE doctype_or_field = 'DocField' AND NOT EXISTS ( SELECT fieldname FROM `tabDocField` df WHERE df.parent = ps.doc_type AND df.fieldname = ps.field_name ) AND NOT EXISTS ( SELECT fieldname FROM `tabCustom Field` cf WHERE cf.dt = ps.doc_type AND cf.fieldname = ps.field_name )""") delete_list_2 = webnotes.conn.sql("""\ SELECT name FROM `tabProperty Setter` ps WHERE doctype_or_field = 'DocField' AND property = 'previous_field' AND NOT EXISTS ( SELECT fieldname FROM `tabDocField` df WHERE df.parent = ps.doc_type AND df.fieldname = ps.value ) AND NOT EXISTS ( SELECT fieldname FROM `tabCustom Field` cf WHERE cf.dt = ps.doc_type AND cf.fieldname = ps.value )""") delete_list = [d[0] for d in delete_list_1] + [d[0] for d in delete_list_2] webnotes.conn.sql("""\ DELETE FROM `tabProperty Setter` WHERE NAME IN ("%s")""" % '", "'.join(delete_list))