Improve config page to edit actual configuration used by EOS. Add admin page to save the actual configuration to the configuration file. Signed-off-by: Bobby Noelte <b0661n0e17e@gmail.com>
26 KiB
Akkudoktor-EOS
Version: 0.0.1
Description: This project provides a comprehensive solution for simulating and optimizing an energy system based on renewable energy sources. With a focus on photovoltaic (PV) systems, battery storage (batteries), load management (consumer requirements), heat pumps, electric vehicles, and consideration of electricity price data, this system enables forecasting and optimization of energy flow and costs over a specified period.
Base URL: No base URL provided.
Endpoints:
POST /gesamtlast
Fastapi Gesamtlast
Deprecated: Total Load Prediction with adjustment.
Endpoint to handle total load prediction adjusted by latest measured data.
Total load prediction starts at 00.00.00 today and is provided for 48 hours.
If no prediction values are available the missing ones at the start of the series are
filled with the first available prediction value.
Note:
Use '/v1/prediction/list?key=load_mean_adjusted' instead.
Load energy meter readings to be added to EOS measurement by:
'/v1/measurement/load-mr/value/by-name' or
'/v1/measurement/value'
Request Body:
application/json
: { "$ref": "#/components/schemas/GesamtlastRequest" }
Responses:
-
200: Successful Response
-
422: Validation Error
GET /gesamtlast_simple
Fastapi Gesamtlast Simple
Deprecated: Total Load Prediction.
Endpoint to handle total load prediction.
Total load prediction starts at 00.00.00 today and is provided for 48 hours.
If no prediction values are available the missing ones at the start of the series are
filled with the first available prediction value.
Args:
year_energy (float): Yearly energy consumption in Wh.
Note:
Set LoadAkkudoktor as provider, then update data with
'/v1/prediction/update'
and then request data with
'/v1/prediction/list?key=load_mean' instead.
Parameters:
year_energy
(query, required): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
POST /optimize
Fastapi Optimize
Parameters:
-
start_hour
(query, optional): Defaults to current hour of the day. -
ngen
(query, optional): No description provided.
Request Body:
application/json
: { "$ref": "#/components/schemas/OptimizationParameters" }
Responses:
-
200: Successful Response
-
422: Validation Error
GET /pvforecast
Fastapi Pvforecast
Deprecated: PV Forecast Prediction.
Endpoint to handle PV forecast prediction.
PVForecast starts at 00.00.00 today and is provided for 48 hours.
If no forecast values are available the missing ones at the start of the series are
filled with the first available forecast value.
Note:
Set PVForecastAkkudoktor as provider, then update data with
'/v1/prediction/update'
and then request data with
'/v1/prediction/list?key=pvforecast_ac_power' and
'/v1/prediction/list?key=pvforecastakkudoktor_temp_air' instead.
Responses:
- 200: Successful Response
GET /strompreis
Fastapi Strompreis
Deprecated: Electricity Market Price Prediction per Wh (€/Wh).
Electricity prices start at 00.00.00 today and are provided for 48 hours.
If no prices are available the missing ones at the start of the series are
filled with the first available price.
Note:
Electricity price charges are added.
Note:
Set ElecPriceAkkudoktor as provider, then update data with
'/v1/prediction/update'
and then request data with
'/v1/prediction/list?key=elecprice_marketprice_wh' or
'/v1/prediction/list?key=elecprice_marketprice_kwh' instead.
Responses:
- 200: Successful Response
GET /v1/admin/cache
Fastapi Admin Cache Get
Current cache management data.
Returns:
data (dict): The management data.
Responses:
- 200: Successful Response
POST /v1/admin/cache/clear
Fastapi Admin Cache Clear Post
Clear the cache from expired data.
Deletes expired cache files.
Args:
clear_all (Optional[bool]): Delete all cached files. Default is False.
Returns:
data (dict): The management data after cleanup.
Parameters:
clear_all
(query, optional): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
POST /v1/admin/cache/load
Fastapi Admin Cache Load Post
Load cache management data.
Returns:
data (dict): The management data that was loaded.
Responses:
- 200: Successful Response
POST /v1/admin/cache/save
Fastapi Admin Cache Save Post
Save the current cache management data.
Returns:
data (dict): The management data that was saved.
Responses:
- 200: Successful Response
POST /v1/admin/server/restart
Fastapi Admin Server Restart Post
Restart the server.
Restart EOS properly by starting a new instance before exiting the old one.
Responses:
- 200: Successful Response
POST /v1/admin/server/shutdown
Fastapi Admin Server Shutdown Post
Shutdown the server.
Responses:
- 200: Successful Response
GET /v1/config
Fastapi Config Get
Get the current configuration.
Returns:
configuration (ConfigEOS): The current configuration.
Responses:
- 200: Successful Response
PUT /v1/config
Fastapi Config Put
Update the current config with the provided settings.
Note that for any setting value that is None or unset, the configuration will fall back to
values from other sources such as environment variables, the EOS configuration file, or default
values.
Args:
settings (SettingsEOS): The settings to write into the current settings.
Returns:
configuration (ConfigEOS): The current configuration after the write.
Request Body:
application/json
: { "$ref": "#/components/schemas/SettingsEOS" }
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/config/file
Fastapi Config File Put
Save the current configuration to the EOS configuration file.
Returns:
configuration (ConfigEOS): The current configuration that was saved.
Responses:
- 200: Successful Response
POST /v1/config/reset
Fastapi Config Reset Post
Reset the configuration to the EOS configuration file.
Returns:
configuration (ConfigEOS): The current configuration after update.
Responses:
- 200: Successful Response
GET /v1/config/{path}
Fastapi Config Get Key
Get the value of a nested key or index in the config model.
Args:
path (str): The nested path to the key (e.g., "general/latitude" or "optimize/nested_list/0").
Returns:
value (Any): The value of the selected nested key.
Parameters:
path
(path, required): The nested path to the configuration key (e.g., general/latitude).
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/config/{path}
Fastapi Config Put Key
Update a nested key or index in the config model.
Args:
path (str): The nested path to the key (e.g., "general/latitude" or "optimize/nested_list/0").
value (Any): The new value to assign to the key or index at path.
Returns:
configuration (ConfigEOS): The current configuration after the update.
Parameters:
path
(path, required): The nested path to the configuration key (e.g., general/latitude).
Request Body:
application/json
: { "anyOf": [ {}, { "type": "null" } ], "description": "The value to assign to the specified configuration path (can be None).", "title": "Value" }
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/health
Fastapi Health Get
Health check endpoint to verify that the EOS server is alive.
Responses:
- 200: Successful Response
PUT /v1/measurement/data
Fastapi Measurement Data Put
Merge the measurement data given as datetime data into EOS measurements.
Request Body:
application/json
: { "$ref": "#/components/schemas/PydanticDateTimeData" }
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/measurement/dataframe
Fastapi Measurement Dataframe Put
Merge the measurement data given as dataframe into EOS measurements.
Request Body:
application/json
: { "$ref": "#/components/schemas/PydanticDateTimeDataFrame" }
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/measurement/keys
Fastapi Measurement Keys Get
Get a list of available measurement keys.
Responses:
- 200: Successful Response
GET /v1/measurement/load-mr/series/by-name
Fastapi Measurement Load Mr Series By Name Get
Get the meter reading of given load name as series.
Parameters:
name
(query, required): Load name.
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/measurement/load-mr/series/by-name
Fastapi Measurement Load Mr Series By Name Put
Merge the meter readings series of given load name into EOS measurements at given datetime.
Parameters:
name
(query, required): Load name.
Request Body:
application/json
: { "$ref": "#/components/schemas/PydanticDateTimeSeries" }
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/measurement/load-mr/value/by-name
Fastapi Measurement Load Mr Value By Name Put
Merge the meter reading of given load name and value into EOS measurements at given datetime.
Parameters:
-
datetime
(query, required): Datetime. -
name
(query, required): Load name. -
value
(query, required): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/measurement/series
Fastapi Measurement Series Get
Get the measurements of given key as series.
Parameters:
key
(query, required): Prediction key.
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/measurement/series
Fastapi Measurement Series Put
Merge measurement given as series into given key.
Parameters:
key
(query, required): Prediction key.
Request Body:
application/json
: { "$ref": "#/components/schemas/PydanticDateTimeSeries" }
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/measurement/value
Fastapi Measurement Value Put
Merge the measurement of given key and value into EOS measurements at given datetime.
Parameters:
-
datetime
(query, required): Datetime. -
key
(query, required): Prediction key. -
value
(query, required): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/prediction/dataframe
Fastapi Prediction Dataframe Get
Get prediction for given key within given date range as series.
Args:
key (str): Prediction key
start_datetime (Optional[str]): Starting datetime (inclusive).
Defaults to start datetime of latest prediction.
end_datetime (Optional[str]: Ending datetime (exclusive).
Defaults to end datetime of latest prediction.
Parameters:
-
keys
(query, required): Prediction keys. -
start_datetime
(query, optional): Starting datetime (inclusive). -
end_datetime
(query, optional): Ending datetime (exclusive). -
interval
(query, optional): Time duration for each interval. Defaults to 1 hour.
Responses:
-
200: Successful Response
-
422: Validation Error
PUT /v1/prediction/import/{provider_id}
Fastapi Prediction Import Provider
Import prediction for given provider ID.
Args:
provider_id: ID of provider to update.
data: Prediction data.
force_enable: Update data even if provider is disabled.
Defaults to False.
Parameters:
-
provider_id
(path, required): Provider ID. -
force_enable
(query, optional): No description provided.
Request Body:
application/json
: { "anyOf": [ { "$ref": "#/components/schemas/PydanticDateTimeDataFrame" }, { "$ref": "#/components/schemas/PydanticDateTimeData" }, { "type": "object" }, { "type": "null" } ], "title": "Data" }
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/prediction/keys
Fastapi Prediction Keys Get
Get a list of available prediction keys.
Responses:
- 200: Successful Response
GET /v1/prediction/list
Fastapi Prediction List Get
Get prediction for given key within given date range as value list.
Args:
key (str): Prediction key
start_datetime (Optional[str]): Starting datetime (inclusive).
Defaults to start datetime of latest prediction.
end_datetime (Optional[str]: Ending datetime (exclusive).
Defaults to end datetime of latest prediction.
interval (Optional[str]): Time duration for each interval.
Defaults to 1 hour.
Parameters:
-
key
(query, required): Prediction key. -
start_datetime
(query, optional): Starting datetime (inclusive). -
end_datetime
(query, optional): Ending datetime (exclusive). -
interval
(query, optional): Time duration for each interval. Defaults to 1 hour.
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/prediction/providers
Fastapi Prediction Providers Get
Get a list of available prediction providers.
Args:
enabled (bool): Return enabled/disabled providers. If unset, return all providers.
Parameters:
enabled
(query, optional): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
GET /v1/prediction/series
Fastapi Prediction Series Get
Get prediction for given key within given date range as series.
Args:
key (str): Prediction key
start_datetime (Optional[str]): Starting datetime (inclusive).
Defaults to start datetime of latest prediction.
end_datetime (Optional[str]: Ending datetime (exclusive).
Defaults to end datetime of latest prediction.
Parameters:
-
key
(query, required): Prediction key. -
start_datetime
(query, optional): Starting datetime (inclusive). -
end_datetime
(query, optional): Ending datetime (exclusive).
Responses:
-
200: Successful Response
-
422: Validation Error
POST /v1/prediction/update
Fastapi Prediction Update
Update predictions for all providers.
Args:
force_update: Update data even if it is already cached.
Defaults to False.
force_enable: Update data even if provider is disabled.
Defaults to False.
Parameters:
-
force_update
(query, optional): No description provided. -
force_enable
(query, optional): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
POST /v1/prediction/update/{provider_id}
Fastapi Prediction Update Provider
Update predictions for given provider ID.
Args:
provider_id: ID of provider to update.
force_update: Update data even if it is already cached.
Defaults to False.
force_enable: Update data even if provider is disabled.
Defaults to False.
Parameters:
-
provider_id
(path, required): No description provided. -
force_update
(query, optional): No description provided. -
force_enable
(query, optional): No description provided.
Responses:
-
200: Successful Response
-
422: Validation Error
GET /visualization_results.pdf
Get Pdf
Responses:
- 200: Successful Response