feat(xo-server-netbox): add data field to Netbox API errors (#5842)
Fixes #5834
This commit is contained in:
parent
d7940292d0
commit
03ec0cab1e
@ -7,6 +7,8 @@
|
|||||||
|
|
||||||
> Users must be able to say: “Nice enhancement, I'm eager to test it”
|
> Users must be able to say: “Nice enhancement, I'm eager to test it”
|
||||||
|
|
||||||
|
- [Netbox] Add information about a failed request to the error log to help better understand what happened [#5834](https://github.com/vatesfr/xen-orchestra/issues/5834) (PR [#5842](https://github.com/vatesfr/xen-orchestra/pull/5842))
|
||||||
|
|
||||||
### Bug fixes
|
### Bug fixes
|
||||||
|
|
||||||
> Users must be able to say: “I had this issue, happy to know it's fixed”
|
> Users must be able to say: “I had this issue, happy to know it's fixed”
|
||||||
@ -27,3 +29,5 @@
|
|||||||
> - major: if the change breaks compatibility
|
> - major: if the change breaks compatibility
|
||||||
>
|
>
|
||||||
> In case of conflict, the highest (lowest in previous list) `$version` wins.
|
> In case of conflict, the highest (lowest in previous list) `$version` wins.
|
||||||
|
|
||||||
|
- xo-server-netbox minor
|
||||||
|
@ -97,10 +97,9 @@ class Netbox {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async #makeRequest(path, method, data) {
|
async #makeRequest(path, method, data) {
|
||||||
log.debug(
|
const dataDebug =
|
||||||
`${method} ${path}`,
|
|
||||||
Array.isArray(data) && data.length > 2 ? [...data.slice(0, 2), `and ${data.length - 2} others`] : data
|
Array.isArray(data) && data.length > 2 ? [...data.slice(0, 2), `and ${data.length - 2} others`] : data
|
||||||
)
|
log.debug(`${method} ${path}`, dataDebug)
|
||||||
let url = this.#endpoint + '/api' + path
|
let url = this.#endpoint + '/api' + path
|
||||||
const options = {
|
const options = {
|
||||||
headers: { 'Content-Type': 'application/json', Authorization: `Token ${this.#token}` },
|
headers: { 'Content-Type': 'application/json', Authorization: `Token ${this.#token}` },
|
||||||
@ -116,10 +115,15 @@ class Netbox {
|
|||||||
return JSON.parse(body)
|
return JSON.parse(body)
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
error.data = {
|
||||||
|
method,
|
||||||
|
path,
|
||||||
|
body: dataDebug,
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
const body = await error.response.readAll()
|
const body = await error.response.readAll()
|
||||||
if (body.length > 0) {
|
if (body.length > 0) {
|
||||||
log.error(body.toString())
|
error.data.error = JSON.parse(body)
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
throw error
|
throw error
|
||||||
|
Loading…
Reference in New Issue
Block a user