-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathexpense_reports.py
105 lines (81 loc) · 4.14 KB
/
expense_reports.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
from collections import OrderedDict
from .base import ApiBase
import logging
from netsuitesdk.internal.utils import PaginatedSearch
from netsuitesdk.internal.exceptions import NetSuiteRequestError
from netsuitesdk.export_errors.parser import ErrorParser
from netsuitesdk.export_errors.helpers import export_error_matcher
logger = logging.getLogger(__name__)
class ExpenseReports(ApiBase):
"""
ExpenseReports are not directly searchable - only via as employees
"""
def __init__(self, ns_client):
ApiBase.__init__(self, ns_client=ns_client, type_name='ExpenseReport')
def get_all_generator(self):
record_type_search_field = self.ns_client.SearchStringField(searchValue='ExpenseReport', operator='contains')
basic_search = self.ns_client.basic_search_factory('Employee', recordType=record_type_search_field)
paginated_search = PaginatedSearch(client=self.ns_client,
type_name='Employee',
basic_search=basic_search,
pageSize=20)
return self._paginated_search_to_generator(paginated_search=paginated_search)
def post(self, data) -> OrderedDict:
assert data['externalId'], 'missing external id'
er = self.ns_client.ExpenseReport()
expense_list = []
for eod in data['expenseList']:
if 'customFieldList' in eod and eod['customFieldList']:
custom_fields = []
for field in eod['customFieldList']:
if field['type'] == 'String':
custom_fields.append(
self.ns_client.StringCustomFieldRef(
scriptId=field['scriptId'] if 'scriptId' in field else None,
internalId=field['internalId'] if 'internalId' in field else None,
value=field['value']
)
)
elif field['type'] == 'Select':
custom_fields.append(
self.ns_client.SelectCustomFieldRef(
scriptId=field['scriptId'] if 'scriptId' in field else None,
internalId=field['internalId'] if 'internalId' in field else None,
value=self.ns_client.ListOrRecordRef(
internalId=field['value']
)
)
)
eod['customFieldList'] = self.ns_client.CustomFieldList(custom_fields)
ere = self.ns_client.ExpenseReportExpense(**eod)
expense_list.append(ere)
er['expenseList'] = self.ns_client.ExpenseReportExpenseList(expense=expense_list)
if 'expenseReportCurrency' in data:
er['expenseReportCurrency'] = self.ns_client.RecordRef(**(data['expenseReportCurrency']))
if 'memo' in data:
er['memo'] = data['memo']
if 'tranDate' in data:
er['tranDate'] = data['tranDate']
if 'tranId' in data:
er['tranId'] = data['tranId']
if 'class' in data:
er['class'] = data['class']
if 'location' in data:
er['location'] = data['location']
if 'department' in data:
er['department'] = data['department']
if 'account' in data:
er['account'] = self.ns_client.RecordRef(**(data['account']))
if 'accountingApproval' in data:
er['accountingApproval'] = data['accountingApproval']
if 'supervisorApproval' in data:
er['supervisorApproval'] = data['supervisorApproval']
if 'acctCorpCardExp' in data:
er['acctCorpCardExp'] = data['acctCorpCardExp']
if 'externalId' in data:
er['externalId'] = data['externalId']
if 'entity' in data:
er['entity'] = self.ns_client.RecordRef(**(data['entity']))
logger.debug('able to create er = %s', er)
res = self.ns_client.upsert(er, 'expense_report')
return self._serialize(res)