Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unable to add integration w/ station sensors #210

Closed
johntdyer opened this issue Dec 30, 2024 · 2 comments · Fixed by #214
Closed

Unable to add integration w/ station sensors #210

johntdyer opened this issue Dec 30, 2024 · 2 comments · Fixed by #214

Comments

@johntdyer
Copy link

johntdyer commented Dec 30, 2024

Describe the bug
When I try to add the station while checking the "include device sensors" I get the following error

To Reproduce
Steps to reproduce the behavior:

  1. Add integration
  2. Check "include station sensors"
  3. Apply
  4. See error




2024-12-30 16:41:14.441 ERROR (MainThread) [aiohttp.server] Error handling request
Traceback (most recent call last):
  File "/usr/local/lib/python3.13/site-packages/aiohttp/web_protocol.py", line 480, in _handle_request
    resp = await request_handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.13/site-packages/aiohttp/web_app.py", line 569, in _handle
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.13/site-packages/aiohttp/web_middlewares.py", line 117, in impl
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/security_filter.py", line 92, in security_filter_middleware
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/forwarded.py", line 210, in forwarded_middleware
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/request_context.py", line 26, in request_context_middleware
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/auth.py", line 242, in auth_middleware
    return await handler(request)
           ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/headers.py", line 32, in headers_middleware
    response = await handler(request)
               ^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/helpers/http.py", line 73, in handle
    result = await handler(request, **request.match_info)
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/decorators.py", line 81, in with_admin
    return await func(self, request, *args, **kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/config/config_entries.py", line 222, in post
    return await super().post(request, flow_id)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/components/http/data_validator.py", line 74, in wrapper
    return await method(view, request, data, *args, **kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/helpers/data_entry_flow.py", line 122, in post
    result = await self._flow_mgr.async_configure(flow_id, data)
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/data_entry_flow.py", line 341, in async_configure
    result = await self._async_configure(flow_id, user_input)
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/src/homeassistant/homeassistant/data_entry_flow.py", line 388, in _async_configure
    result = await self._async_handle_step(
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
        flow, cur_step["step_id"], user_input
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    )
    ^
  File "/usr/src/homeassistant/homeassistant/data_entry_flow.py", line 491, in _async_handle_step
    result: _FlowResultT = await getattr(flow, method)(user_input)
                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/config/custom_components/weatherflow_forecast/config_flow.py", line 62, in async_step_user
    sensor_data: WeatherFlowSensorData = await weatherflow_api.async_fetch_sensor_data()
                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.13/site-packages/pyweatherflow_forecast/wffcst_lib.py", line 209, in async_fetch_sensor_data
    device_data: WeatherFlowDeviceData = _get_device_data(json_device_data, self._device_id)
                                         ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/local/lib/python3.13/site-packages/pyweatherflow_forecast/wffcst_lib.py", line 577, in _get_device_data
    precipitation_type = None if api_result is None else api_result["obs"][0][13]
                                                         ~~~~~~~~~~~~~~~~~^^^
TypeError: 'NoneType' object is not subscriptable

I am able to get past this by unchecking that option in the integration setup. I then go back an check the now configured integration and I get the following error in the integration screen


2024-12-30 16:44:05.308 ERROR (MainThread) [homeassistant.config_entries] Config entry 'Alpharetta' from integration weatherflow_forecast has an invalid unique_id '164431' of type int when a string is expected, please create a bug report at https://github.com/briis/weatherflow_forecast/issues
2024-12-30 16:44:05.308 ERROR (MainThread) [homeassistant.config_entries] Config entry 'Alpharetta' from integration weatherflow_forecast has an invalid unique_id '164431' of type int when a string is expected, please create a bug report at https://github.com/briis/weatherflow_forecast/issues
2024-12-30 16:44:05.638 DEBUG (MainThread) [custom_components.weatherflow_forecast] Finished fetching weatherflow_forecast data in 0.329 seconds (success: True)
2024-12-30 16:44:05.638 INFO (MainThread) [homeassistant.components.weather] Setting up weatherflow_forecast.weather
2024-12-30 16:44:05.640 INFO (MainThread) [homeassistant.helpers.entity_registry] Registered new weather.weatherflow_forecast entity: weather.forecast_alpharetta
2024-12-30 16:44:05.683 INFO (MainThread) [homeassistant.components.sensor] Setting up weatherflow_forecast.sensor
2024-12-30 16:44:05.683 INFO (MainThread) [homeassistant.components.binary_sensor] Setting up weatherflow_forecast.binary_sensor
2024-12-30 16:44:17.848 DEBUG (MainThread) [custom_components.weatherflow_forecast] Finished fetching weatherflow_forecast data in 0.676 seconds (success: False)
2024-12-30 16:44:23.422 DEBUG (MainThread) [custom_components.weatherflow_forecast] Finished fetching weatherflow_forecast data in 0.293 seconds (success: False)

Expected behavior
this not to happen :)

Screenshots
If applicable, add screenshots to help explain your problem.

Additional context
Add any other context about the problem here.

@briis
Copy link
Owner

briis commented Jan 7, 2025

Would you mind posting your Station ID, or send it to me at [email protected]. Then I will have a look at the data that is returned.

@briis
Copy link
Owner

briis commented Jan 8, 2025

Never mind. I found the Station ID in the logs.
I just tried to setup the Station including the sensors, and I can add everything. However I get the same errors with the unique ID, which I will investigate.

But I still get data on my dev system.

@briis briis linked a pull request Jan 8, 2025 that will close this issue
@briis briis closed this as completed in #214 Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants