Updates a chart of accounts

Script xero Verified

by hugo697 ยท 12/20/2024

The script

Submitted by hugo697 Bun
Verified 515 days ago
1
//native
2
type Xero = {
3
	token: string
4
}
5
/**
6
 * Updates a chart of accounts
7
 *
8
 */
9
export async function main(
10
	auth: Xero,
11
	AccountID: string,
12
	xero_tenant_id: string,
13
	Idempotency_Key: string,
14
	body: {
15
		Accounts?: {
16
			Code?: string
17
			Name?: string
18
			AccountID?: string
19
			Type?:
20
				| 'BANK'
21
				| 'CURRENT'
22
				| 'CURRLIAB'
23
				| 'DEPRECIATN'
24
				| 'DIRECTCOSTS'
25
				| 'EQUITY'
26
				| 'EXPENSE'
27
				| 'FIXED'
28
				| 'INVENTORY'
29
				| 'LIABILITY'
30
				| 'NONCURRENT'
31
				| 'OTHERINCOME'
32
				| 'OVERHEADS'
33
				| 'PREPAYMENT'
34
				| 'REVENUE'
35
				| 'SALES'
36
				| 'TERMLIAB'
37
				| 'PAYG'
38
			BankAccountNumber?: string
39
			Status?: 'ACTIVE' | 'ARCHIVED' | 'DELETED'
40
			Description?: string
41
			BankAccountType?: '' | 'BANK' | 'CREDITCARD' | 'PAYPAL' | 'NONE'
42
			CurrencyCode?:
43
				| 'AED'
44
				| 'AFN'
45
				| 'ALL'
46
				| 'AMD'
47
				| 'ANG'
48
				| 'AOA'
49
				| 'ARS'
50
				| 'AUD'
51
				| 'AWG'
52
				| 'AZN'
53
				| 'BAM'
54
				| 'BBD'
55
				| 'BDT'
56
				| 'BGN'
57
				| 'BHD'
58
				| 'BIF'
59
				| 'BMD'
60
				| 'BND'
61
				| 'BOB'
62
				| 'BRL'
63
				| 'BSD'
64
				| 'BTN'
65
				| 'BWP'
66
				| 'BYN'
67
				| 'BYR'
68
				| 'BZD'
69
				| 'CAD'
70
				| 'CDF'
71
				| 'CHF'
72
				| 'CLF'
73
				| 'CLP'
74
				| 'CNY'
75
				| 'COP'
76
				| 'CRC'
77
				| 'CUC'
78
				| 'CUP'
79
				| 'CVE'
80
				| 'CZK'
81
				| 'DJF'
82
				| 'DKK'
83
				| 'DOP'
84
				| 'DZD'
85
				| 'EEK'
86
				| 'EGP'
87
				| 'ERN'
88
				| 'ETB'
89
				| 'EUR'
90
				| 'FJD'
91
				| 'FKP'
92
				| 'GBP'
93
				| 'GEL'
94
				| 'GHS'
95
				| 'GIP'
96
				| 'GMD'
97
				| 'GNF'
98
				| 'GTQ'
99
				| 'GYD'
100
				| 'HKD'
101
				| 'HNL'
102
				| 'HRK'
103
				| 'HTG'
104
				| 'HUF'
105
				| 'IDR'
106
				| 'ILS'
107
				| 'INR'
108
				| 'IQD'
109
				| 'IRR'
110
				| 'ISK'
111
				| 'JMD'
112
				| 'JOD'
113
				| 'JPY'
114
				| 'KES'
115
				| 'KGS'
116
				| 'KHR'
117
				| 'KMF'
118
				| 'KPW'
119
				| 'KRW'
120
				| 'KWD'
121
				| 'KYD'
122
				| 'KZT'
123
				| 'LAK'
124
				| 'LBP'
125
				| 'LKR'
126
				| 'LRD'
127
				| 'LSL'
128
				| 'LTL'
129
				| 'LVL'
130
				| 'LYD'
131
				| 'MAD'
132
				| 'MDL'
133
				| 'MGA'
134
				| 'MKD'
135
				| 'MMK'
136
				| 'MNT'
137
				| 'MOP'
138
				| 'MRO'
139
				| 'MRU'
140
				| 'MUR'
141
				| 'MVR'
142
				| 'MWK'
143
				| 'MXN'
144
				| 'MXV'
145
				| 'MYR'
146
				| 'MZN'
147
				| 'NAD'
148
				| 'NGN'
149
				| 'NIO'
150
				| 'NOK'
151
				| 'NPR'
152
				| 'NZD'
153
				| 'OMR'
154
				| 'PAB'
155
				| 'PEN'
156
				| 'PGK'
157
				| 'PHP'
158
				| 'PKR'
159
				| 'PLN'
160
				| 'PYG'
161
				| 'QAR'
162
				| 'RON'
163
				| 'RSD'
164
				| 'RUB'
165
				| 'RWF'
166
				| 'SAR'
167
				| 'SBD'
168
				| 'SCR'
169
				| 'SDG'
170
				| 'SEK'
171
				| 'SGD'
172
				| 'SHP'
173
				| 'SKK'
174
				| 'SLE'
175
				| 'SLL'
176
				| 'SOS'
177
				| 'SRD'
178
				| 'STD'
179
				| 'STN'
180
				| 'SVC'
181
				| 'SYP'
182
				| 'SZL'
183
				| 'THB'
184
				| 'TJS'
185
				| 'TMT'
186
				| 'TND'
187
				| 'TOP'
188
				| 'TRY'
189
				| 'TTD'
190
				| 'TWD'
191
				| 'TZS'
192
				| 'UAH'
193
				| 'UGX'
194
				| 'USD'
195
				| 'UYU'
196
				| 'UZS'
197
				| 'VEF'
198
				| 'VES'
199
				| 'VND'
200
				| 'VUV'
201
				| 'WST'
202
				| 'XAF'
203
				| 'XCD'
204
				| 'XOF'
205
				| 'XPF'
206
				| 'YER'
207
				| 'ZAR'
208
				| 'ZMW'
209
				| 'ZMK'
210
				| 'ZWD'
211
			TaxType?: string
212
			EnablePaymentsToAccount?: false | true
213
			ShowInExpenseClaims?: false | true
214
			Class?: 'EQUITY' | 'EXPENSE' | 'LIABILITY' | 'REVENUE' | 'ASSET'
215
			SystemAccount?:
216
				| ''
217
				| 'DEBTORS'
218
				| 'CREDITORS'
219
				| 'BANKCURRENCYGAIN'
220
				| 'GST'
221
				| 'GSTONIMPORTS'
222
				| 'HISTORICAL'
223
				| 'REALISEDCURRENCYGAIN'
224
				| 'RETAINEDEARNINGS'
225
				| 'ROUNDING'
226
				| 'TRACKINGTRANSFERS'
227
				| 'UNPAIDEXPCLM'
228
				| 'UNREALISEDCURRENCYGAIN'
229
				| 'WAGEPAYABLES'
230
				| 'CISASSETS'
231
				| 'CISASSET'
232
				| 'CISLABOUR'
233
				| 'CISLABOUREXPENSE'
234
				| 'CISLABOURINCOME'
235
				| 'CISLIABILITY'
236
				| 'CISMATERIALS'
237
			ReportingCode?: string
238
			ReportingCodeName?: string
239
			HasAttachments?: never
240
			UpdatedDateUTC?: string
241
			AddToWatchlist?: false | true
242
			ValidationErrors?: { Message?: string }[]
243
		}[]
244
	}
245
) {
246
	const url = new URL(`https://api.xero.com/api.xro/2.0/Accounts/${AccountID}`)
247

248
	const response = await fetch(url, {
249
		method: 'POST',
250
		headers: {
251
			Accept: 'application/json',
252
			'xero-tenant-id': xero_tenant_id,
253
			'Idempotency-Key': Idempotency_Key,
254
			'Content-Type': 'application/json',
255
			Authorization: 'Bearer ' + auth.token
256
		},
257
		body: JSON.stringify(body)
258
	})
259
	if (!response.ok) {
260
		const text = await response.text()
261
		throw new Error(`${response.status} ${text}`)
262
	}
263
	return await response.json()
264
}
265