Error POSTing to Residual Endpoint
This issues addresses the bug seen on the page:
https://staging-geomag.cr.usgs.gov/operations/metadata/edit/583
When trying to POST to the residual endpoint I get this error:
INFO: 127.0.0.1:54394 - "POST /algorithms/residual HTTP/1.1" 500 Internal Server Error
ERROR: Exception in ASGI application
Traceback (most recent call last):
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/anyio/streams/memory.py", line 94, in receive
return self.receive_nowait()
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/anyio/streams/memory.py", line 89, in receive_nowait
raise WouldBlock
anyio.WouldBlock
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/base.py", line 78, in call_next
message = await recv_stream.receive()
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/anyio/streams/memory.py", line 114, in receive
raise EndOfStream
anyio.EndOfStream
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/uvicorn/protocols/http/httptools_impl.py", line 435, in run_asgi
result = await app( # type: ignore[func-returns-value]
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/uvicorn/middleware/proxy_headers.py", line 78, in __call__
return await self.app(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/applications.py", line 276, in __call__
await super().__call__(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/applications.py", line 122, in __call__
await self.middleware_stack(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/errors.py", line 184, in __call__
raise exc
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/errors.py", line 162, in __call__
await self.app(scope, receive, _send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/exceptions.py", line 79, in __call__
raise exc
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/exceptions.py", line 68, in __call__
await self.app(scope, receive, sender)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/middleware/asyncexitstack.py", line 21, in __call__
raise e
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/middleware/asyncexitstack.py", line 18, in __call__
await self.app(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/routing.py", line 718, in __call__
await route.handle(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/routing.py", line 443, in handle
await self.app(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/applications.py", line 276, in __call__
await super().__call__(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/applications.py", line 122, in __call__
await self.middleware_stack(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/errors.py", line 184, in __call__
raise exc
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/errors.py", line 162, in __call__
await self.app(scope, receive, _send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/base.py", line 108, in __call__
response = await self.dispatch_func(request, call_next)
File "/Users/ehunter/Documents/code.usgs.gov/geomag-algorithms/geomagio/api/ws/app.py", line 44, in add_headers
response = await call_next(request)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/base.py", line 84, in call_next
raise app_exc
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/base.py", line 70, in coro
await self.app(scope, receive_or_disconnect, send_no_error)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/exceptions.py", line 79, in __call__
raise exc
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/middleware/exceptions.py", line 68, in __call__
await self.app(scope, receive, sender)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/middleware/asyncexitstack.py", line 21, in __call__
raise e
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/middleware/asyncexitstack.py", line 18, in __call__
await self.app(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/routing.py", line 718, in __call__
await route.handle(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/routing.py", line 276, in handle
await self.app(scope, receive, send)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/routing.py", line 66, in app
response = await func(request)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/fastapi/routing.py", line 266, in app
response = actual_response_class(content, **response_args)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/responses.py", line 196, in __init__
super().__init__(content, status_code, headers, media_type, background)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/responses.py", line 55, in __init__
self.body = self.render(content)
File "/Users/ehunter/Library/Caches/pypoetry/virtualenvs/geomag-algorithms-ELCs-gDP-py3.10/lib/python3.10/site-packages/starlette/responses.py", line 199, in render
return json.dumps(
File "/Users/ehunter/osx-bash-environment/pyenv/versions/3.10.10/lib/python3.10/json/__init__.py", line 238, in dumps
**kw).encode(obj)
File "/Users/ehunter/osx-bash-environment/pyenv/versions/3.10.10/lib/python3.10/json/encoder.py", line 199, in encode
chunks = self.iterencode(o, _one_shot=True)
File "/Users/ehunter/osx-bash-environment/pyenv/versions/3.10.10/lib/python3.10/json/encoder.py", line 257, in iterencode
return _iterencode(o, 0)
ValueError: Out of range float values are not JSON compliant
This is the data in the request:
{
"azimuth": 199.1383,
"metadata": {},
"absolutes": [],
"electronic": "0110",
"hemisphere": 1,
"theodolite": "109648",
"diagnostics": {
"mean_mark": 102.19291666666666,
"d_computed": 0.24252979763930943,
"ordinate_d": -0.24092967579478763,
"ordinate_f": 51426.2107501758,
"ordinate_h": 20774.962,
"ordinate_z": 46481.48,
"r_computed": 0.00024021681927733713,
"corrected_f": 51404.2107501758,
"inclination": 66.04208333404527,
"vertical_component": 46975.42732279686,
"horizontal_component": 20873.47864370287,
"magnetic_south_meridian": 180.74291666666664,
"magnetic_azimuth_of_mark": -78.54999999999998
},
"scale_value": null,
"measurements": [{
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 194.435,
"residual": null,
"measurement_type": "FirstMarkDown"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 194.435,
"residual": null,
"measurement_type": "FirstMarkDown"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 11.508333333333333,
"residual": null,
"measurement_type": "FirstMarkUp"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 11.508333333333333,
"residual": null,
"measurement_type": "FirstMarkUp"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 180.44,
"residual": null,
"measurement_type": "Meridian"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 191.41833333333332,
"residual": null,
"measurement_type": "SecondMarkDown"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 191.41833333333332,
"residual": null,
"measurement_type": "SecondMarkDown"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 11.408333333333331,
"residual": null,
"measurement_type": "SecondMarkUp"
}, {
"e": null,
"f": null,
"h": null,
"z": null,
"time": null,
"angle": 11.411666666666669,
"residual": null,
"measurement_type": "SecondMarkUp"
}, {
"e": -87.754,
"f": 51424.191,
"h": 20774.962,
"z": 46481.48,
"time": "2023-06-26T17:45:00.000000Z",
"angle": 270.555,
"residual": 0.1,
"measurement_type": "WestDown"
}, {
"e": -87.848,
"f": 51424.25,
"h": 20775.033,
"z": 46481.492,
"time": "2023-06-26T17:45:10.000000Z",
"angle": 270.555,
"residual": 0.1,
"measurement_type": "WestDown"
}, {
"e": -88.034,
"f": 51424.289,
"h": 20775.464,
"z": 46481.347,
"time": "2023-06-26T17:46:10.000000Z",
"angle": 90.36666666666666,
"residual": 0.3,
"measurement_type": "EastDown"
}, {
"e": -88.185,
"f": 51424.398,
"h": 20775.71,
"z": 46481.386,
"time": "2023-06-26T17:46:20.000000Z",
"angle": 90.36666666666666,
"residual": 0.2,
"measurement_type": "EastDown"
}, {
"e": -88.446,
"f": 51424.5,
"h": 20775.925,
"z": 46481.402,
"time": "2023-06-26T17:47:20.000000Z",
"angle": 91.57,
"residual": 0,
"measurement_type": "WestUp"
}, {
"e": -88.557,
"f": 51424.488,
"h": 20775.947,
"z": 46481.359,
"time": "2023-06-26T17:47:30.000000Z",
"angle": 91.57,
"residual": 0,
"measurement_type": "WestUp"
}, {
"e": -88.923,
"f": 51424.71,
"h": 20776.392,
"z": 46481.375,
"time": "2023-06-26T17:48:30.000000Z",
"angle": 270.47999999999996,
"residual": 0.1,
"measurement_type": "EastUp"
}, {
"e": -88.974,
"f": 51424.691,
"h": 20776.488,
"z": 46481.335,
"time": "2023-06-26T17:48:40.000000Z",
"angle": 270.47999999999996,
"residual": 0.3,
"measurement_type": "EastUp"
}, {
"e": -90.169,
"f": 51425.88,
"h": 20778.906,
"z": 46481.558,
"time": "2023-06-26T17:54:30.000000Z",
"angle": 246.25,
"residual": 0.1,
"measurement_type": "SouthDown"
}, {
"e": -90.071,
"f": 51425.788,
"h": 20778.912,
"z": 46481.468,
"time": "2023-06-26T17:54:40.000000Z",
"angle": 246.25,
"residual": 0.3,
"measurement_type": "SouthDown"
}, {
"e": -90,
"f": 51425.988,
"h": 20779.277,
"z": 46481.527,
"time": "2023-06-26T17:55:50.000000Z",
"angle": 66.26666666666667,
"residual": 0.3,
"measurement_type": "NorthUp"
}, {
"e": -90.078,
"f": 51426.032,
"h": 20779.027,
"z": 46481.687,
"time": "2023-06-26T17:56:00.000000Z",
"angle": 66.26666666666667,
"residual": 0.2,
"measurement_type": "NorthUp"
}, {
"e": -89.967,
"f": 51426.339,
"h": 20779.554,
"z": 46481.8,
"time": "2023-06-26T17:57:50.000000Z",
"angle": 113.68166666666669,
"residual": 0.3,
"measurement_type": "SouthUp"
}, {
"e": -89.781,
"f": 51426.25,
"h": 20779.697,
"z": 46481.625,
"time": "2023-06-26T17:58:00.000000Z",
"angle": 114.68166666666669,
"residual": 0.3,
"measurement_type": "SouthUp"
}, {
"e": -89.75,
"f": 51426.671,
"h": 20780.228,
"z": 46481.875,
"time": "2023-06-26T17:59:20.000000Z",
"angle": 293.6666666666667,
"residual": 0.2,
"measurement_type": "NorthDown"
}, {
"e": -89.805,
"f": 51426.738,
"h": 20780.273,
"z": 46481.949,
"time": "2023-06-26T17:59:30.000000Z",
"angle": 293.6666666666667,
"residual": 0.3,
"measurement_type": "NorthDown"
}, {
"e": -89.818,
"f": 51426.949,
"h": 20780.703,
"z": 46481.968,
"time": "2023-06-26T18:00:30.000000Z",
"angle": 294.83333333333337,
"residual": 148.8,
"measurement_type": "NorthDownScale"
}, {
"e": -89.818,
"f": 51426.949,
"h": 20780.703,
"z": 46481.968,
"time": "2023-06-26T18:00:30.000000Z",
"angle": 293.83333333333337,
"residual": 148.8,
"measurement_type": "NorthDownScale"
}],
"pier_correction": "-22",
"pier_temperature": 22
}
``