Poprzez API jest możliwość wykorzystania silnika cieplo.app we własnej aplikacji, która może wyglądać i być zorganizowana prawie w dowolny sposób.
Obsługiwane kraje: Polska, Niemcy, Austria, Czechy, Słowacja, Wielka Brytania, Holandia.
Uwagi, życzenia, skargi, pytania i zażalenia odnośnie API można kierować zwyczajowymi drogami kontaktu.
Każdy użytkownik posiada indywidualny klucz dostępu do API, który należy dołączyć do każdego żądania jako parametr GET o nazwie token. Klucz dostępu do API można znaleźć w panelu konta.
Jeśli użytkownik ma aktywną subskrypcję z dostępme do API – jego klucz jest w pełni funkcjonalny. W przeciwnym wypadku klucz działa w trybie testowym – do celów wdrożeniowych. Obliczenia przesłane za pomocą testowego klucza API przechodzą walidację, ale nie są zapisywane na serwerze. Zwracane w odpowiedzi wartości zawsze dotyczą jednego i tego samego oszacowania, które już istnieje w bazie (jest zwracany jego identyfikator, więc można pobrać całość w osobnym żądaniu).
POST https://cieplo.app/api/calculation
Treść żądania należy przesłać jako application/json.
Wszystkie parametry są obowiązkowe – poza opisanymi jako warunkowe lub opcjonalne. Poniższy przykład dla ilustracji zawiera wszystkie parametry, także te, które w tym typie budynku nie są potrzebne.
{ "building_type": "single_house", "construction_year": 2020, "construction_type": "traditional", "latitude": 51.4453433, "longitude": 16.2334445, "building_length": 12.5, "building_width": 6, "floor_area": 45, "floor_perimeter": 125, "building_floors": 3, "building_heated_floors": [0, 1, 2], "floor_height": 2.6, "building_roof": "steep", "has_basement": true, "has_balcony": true, "has_garage": false, "garage_type": "double_unheated", "wall_size": 65, "primary_wall_material": 57, "secondary_wall_material": null, "internal_wall_isolation": { "material": 88, "size": 5 }, "external_wall_isolation": { "material": 88, "size": 15 }, "top_isolation": { "material": 68, "size": 35 }, "bottom_isolation": { "material": 71, "size": 5 }, "number_doors": 2, "number_balcony_doors": 2, "number_windows": 12, "number_huge_windows": 0, "doors_type": "new_metal", "windows_type": "new_double_glass", "indoor_temperature": 21, "ventilation_type": "natural", "include_hot_water": true, "hot_water_persons": 3, "hot_water_usage": "shower_bath", "whats_over": "heated_room", "whats_under": "heated_room", "whats_north": "heated_room", "whats_south": "unheated_room", "whats_east": "heated_room", "whats_west": "outdoor", "on_corner": true, "unheated_space_under_type": "worst", "unheated_space_over_type": "great" }
Parametr | Typ danych | Jednostka | Opis |
---|---|---|---|
building_type | enum | - | Rodzaj budynku:
|
construction_year | integer | - | Rok budowy; wartość nie musi być dokładna, wystarczy zdefiniować przedziały, podobnie jak to jest na cieplo.app:
|
construction_type | enum | - | Rodzaj konstrukcji budynku:
|
latitude, longitude | double | - | Współrzędne przybliżonej lokalizacji budynku. |
building_length, building_width
warunkowe |
double | m | Długość i szerokość obrysu budynku. Alternatywnie można podać powierzchnię zabudowy. |
building_shape
warunkoweopcjonalne |
enum | - | Kształt obrysu ścian zewnętrznych budynku.
Natomiast jeśli budynek ma kształt nieregularny, masz dwie opcje:
|
floor_area
warunkowe |
double | m2 | Powierzchnia zabudowy. Alternatywnie można podać długość i szerokość obrysu budynku. |
floor_perimeter
warunkoweopcjonalne |
double | m | Obwód budynku. Podaj tylko gdy building_shape = irregular. |
building_floors | integer | - | Liczba pełnych kondygnacji naziemnych – nie licząc poddasza i piwnic. Maksymalna wartość: 13 |
building_heated_floors | array[integer] | - | Lista ogrzewanych kondygnacji, tutaj dla odmiany licząc piwnicę i poddasze:
|
floor_height | enum/double | m | Wysokość pięter przeważająca w budynku.
|
building_roof | enum | - | Rodzaj dachu
|
has_basement | boolean | - | Czy budynek posiada piwnicę? |
has_balcony | boolean | - | Czy budynek posiada balkon(y)? |
has_garage opcjonalne |
boolean | - | Czy jest garaż w bryle budynku? (garaż rozumiany jako jednostanowiskowy nieogrzewany) Parametr przestarzały, nadal działa, ale zalecane w zamian używanie parametru garage_type, który oferuje wybór wielkości i stopnia dogrzania garażu. |
garage_type
opcjonalne |
enum | - | Charakterystyka garażu w bryle budynku.
|
wall_size | integer | cm | Całkowita grubość ściany zewnętrznej. |
primary_wall_material
warunkowe Wymagane tylko dla construction_type = traditional |
Materiał | - | Podstawowy materiał konstrukcyjny ścian (ten, który przeważa). |
secondary_wall_material opcjonalne |
Materiał | - | Dodatkowy materiał konstrukcyjny ścian (jeśli ściana jest zbudowana np. z mixu pustaków i cegieł). |
internal_wall_isolation[material]
warunkowe Wymagane przy construction_type = canadian |
Materiał | - | Materiał wewnętrznej warstwy izolacji w ścianie zewnętrznej. |
internal_wall_isolation[size]
warunkowe Wymagane przy construction_type = canadian |
integer | cm | Grubość wewnętrznej warstwy izolacji w ścianie zewnętrznej. |
external_wall_isolation[material]
opcjonalne |
Materiał | - | Materiał zewnętrznego docieplenia ścian zewnętrznych. |
external_wall_isolation[size]
opcjonalne |
integer | cm | Grubość zewnętrznego docieplenia ścian zewnętrznych. |
top_isolation[material]
opcjonalne |
Materiał | - | Materiał ew. docieplenia przestrzeni ogrzewanej od góry. Może to być strop najwyższego ogrzewanego pomieszczenia lub dach – zależnie od konstrukcji budynku oraz od tego, które piętra są ogrzewane, a które nie. |
top_isolation[size]
opcjonalne |
integer | cm | Grubość w/w docieplenia (jeśli jest takowe). |
bottom_isolation[material]
opcjonalne |
Materiał | - | Materiał ew. docieplenia przestrzeni ogrzewanej od dołu. Może to być podłoga piwnicy, podłoga parteru albo strop parteru – zależnie od tego, które piętra są ogrzewane, a które nie. |
bottom_isolation[size]
opcjonalne |
integer | cm | Grubość w/w docieplenia (jeśli jest takowe). |
number_doors | integer | - | Liczba drzwi zewnętrznych w budynku. |
number_balcony_doors | integer | - | Liczba drzwi balkonowych w budynku. |
number_windows | integer | - | Liczba okien w budynku. Typowe okno = ok. 130x150cm. |
number_huge_windows | integer | - | Liczba dużych przeszkleń w budynku. Duże przeszklenie = np. 3x3m. |
doors_type | enum | - | Rodzaj drzwi zewnętrznych.
|
windows_type | enum | - | Rodzaj okien.
|
indoor_temperature | double | °C | Średnia dobowa temperatura w pomieszczeniach ogrzewanych zimą. |
ventilation_type | enum | - | Rodzaj wentylacji
|
include_hot_water | boolean | - | Czy wyliczamy dodatkową moc na potrzeby podgrzewania ciepłej wody użytkowej (CWU)? |
hot_water_persons warunkowe Wymagane tylko dla include_hot_water = true |
integer | - | Liczba osób korzystających z ciepłej wody użytkowej (CWU). |
hot_water_usage warunkowe Wymagane tylko dla include_hot_water = true |
enum | - | Intensywność wykorzystania ciepłej wody użytkowej (CWU):
|
whats_over
warunkowe Wymagane tylko dla building_type = apartment |
enum | - | Co znajduje się powyżej mieszkania?
|
whats_under
warunkowe Wymagane tylko dla building_type = apartment |
enum | - | Co znajduje się poniżej mieszkania?
|
whats_north, whats_east, whats_south, whats_west
warunkowe Wymagane tylko dla building_type = apartment |
enum | - | Co znajduje się w sąsiedztwie mieszkania – z każdej z czterech stron osobno?
|
on_corner
warunkowe Wymagane tylko dla building_type = row_house |
boolean | - | Czy segment w zabudowie szeregowej znajduje się na końcu/początku szeregu? |
unheated_space_under_type
opcjonalne |
enum | - | Jakość zaizolowania przestrzeni nieogrzewanej znajdującej się poniżej ogrzewanej części budynku.
|
unheated_space_over_type
opcjonalne |
enum | - | Jakość zaizolowania przestrzeni nieogrzewanej znajdującej się powyżej ogrzewanej części budynku.
|
number_stairways
opcjonalne tylko dla building_type = multifamily |
integer | - | Liczba klatek schodowych w budynku. |
number_elevators
opcjonalne tylko dla building_type = multifamily |
integer | - | Liczba wind w budynku. |
Póki co zwracane są tylko te podstawowe dane, które – jak się naszemu jednoosobowemu zespołowi wydawało – będą potrzebne użytkownikom API. Daj znać jeśli potrzebujesz czegoś więcej spośród treści, jakie znajdują się na stronie z wynikiem.
{ "result": { "id": 12345, "total_area": 145, "heated_area": 145, "max_heating_power": 5.2, "avg_heating_power": 2.5, "bivalent_point_heating_power": 4.6, "hot_water_power": 0.5, "annual_energy_consumption": 12345, "annual_energy_consumption_factor": 123, "heating_power_factor": 155, "design_outdoor_temperature": -20, "avg_outdoor_temperature": 1.24 } }
Parametr | Typ danych | Jednostka | Opis |
---|---|---|---|
total_area | double | m2 | Całkowita powierzchnia budynku |
heated_area | double | m2 | Ogrzewana powierzchnia budynku |
max_heating_power | double | kW | Maksymalna moc grzewcza na potrzeby wyłącznie ogrzewania budynku w najzimniejszym dniu zimy (dla projektowej temperatury zewnętrznej). |
avg_heating_power | double | kW | Przeciętna moc grzewcza na potrzeby wyłącznie ogrzewania budynku przy średniej zimowej temperaturze zewnętrznej. |
bivalent_point_heating_power | double | kW | Moc grzewcza w punkcie biwalentnym, tj. przy temperaturze zewnętrznej wyliczonej odpowiednio dla strefy klimatycznej, w której znajduje się budynek. |
hot_water_power | double | kW | Dodatkowa moc grzewcza na potrzeby przygotowania ciepłej wody użytkowej (CWU). |
annual_energy_consumption | integer | kWh | Całkowite roczne zużycie energii na potrzeby wyłącznie ogrzewania budynku (nie jest w to wliczone przygotowanie CWU). |
annual_energy_consumption_factor | double | kWh/m2 | Współczynnik zapotrzebowania na ciepło. |
heating_power_factor | double | W/m2 | Współczynnik zapotrzebowania na moc grzewczą. |
design_outdoor_temperature | integer | °C | Projektowa temperatura zewnętrzna w danej lokalizacji, dla której liczona jest maksymalna wymagana moc grzewcza na potrzeby wyłącznie ogrzewania budynku. |
avg_outdoor_temperature | double | °C | Średnia temperatura zewnętrzna w ciągu sezonu grzewczego na podstawie danych klimatycznych. |
{ "errors": { "internal_wall_isolation": "Pole wymagane." } }
GET https://cieplo.app/api/calculation/{id}
{ "parameters": { ... }, "result": { "id": 12345, "total_area": 145, "heated_area": 145, "max_heating_power": 5.2, "avg_heating_power": 2.5, "bivalent_point_heating_power": 4.6, "annual_energy_consumption": 12345, "annual_energy_consumption_factor": 123, "heating_power_factor": 155, "design_outdoor_temperature": -20, "avg_outdoor_temperature": 1.24 } }
GET https://cieplo.app/api/calculation/{id}?extended=1
Dodatkowo zwracane są: dane z wykresu z kosztami energii/paliw, lista najbardziej opłacalnych modernizacji budynku oraz dane z wykresu dot. strat ciepła.
{ "parameters": { ... }, "result": { ... }, "heating_costs": [ { "label": "Kocioł na drewno bez podajnika", "detail": "Ecodesign, z buforem ciepła", "fuel": { "name": "Drewno", "price": 1, "unit": "kg", "trade_amount": 450, "trade_unit": "mp", "energy": 16.00 }, "amount": 10651, "consumption": 23.7, "efficiency": 80, "cost": 9586 }, ... ], "improvements": [{ "label": "ocieplenie dachu 20cm styropianu", "energy_saved": 35 }, { "label": "wentylacja mechaniczna z odzyskiem ciepła", "energy_saved": 10 }], "energy_losses": [{ "label": "Drzwi", "percent": 2 },{ "label": "Ściany zewnętrzne", "percent": 3 },{ "label": "Podłoga parteru", "percent": 8 },{ "label": "Okna", "percent": 10 },{ "label": "Wentylacja", "percent": 17 },{ "label": "Dach", "percent": 60 }] }
Parametr | Typ danych | Jednostka | Opis |
---|---|---|---|
heating_costs | array | - | Lista wariantów ogrzewania budynku: różne kombinacje urządzeń grzewczych i źródeł energii. |
heating_costs[fuel][unit] | string | - | Jednostka obliczeniowa nośnika energii (ta, dla której zwyczajowo podawana jest wartość energetyczna, np. dla węgla jest to kg). |
heating_costs[fuel][price] | double | zł/j.obl. | Cena za jednostkę obliczeniową nośnika energii. |
heating_costs[fuel][trade_unit] | string | - | Jednostka handlowa (w jakiej sprzedawany jest dany nośnik energii), np.:
|
heating_costs[fuel][trade_amount] | double | - | Liczba jednostek obliczeniowych mieszczących się w jednostce handlowej danego źródła energii. |
heating_costs[fuel][energy] | double | MJ/j.obl. | Ilość energii w jednostce obliczeniowej. |
heating_costs[amount] | integer | kWh | Ilość energii jaką trzeba zakupić w danym jej nośniku na potrzeby ogrzania tego budynku. Im gorsza sprawność danego źródła ciepła, tym ta liczba będzie większa od zapotrzebowania budynku. |
heating_costs[consumption] | double | j.handl. | Zapotrzebowanie na dany nośnik energii wyrażone w jego jednostce handlowej. |
heating_costs[efficiency] | integer | % | Efektywność danego urządzenia grzewczego, np. 80% dla kotła, 350% dla pompy ciepła. |
heating_costs[cost] | integer | zł | Roczny koszt ogrzewania w danym wariance (urządzenie grzewcze + nośnik energii). |
improvements | array | - | Warianty modernizacji budynku najbardziej zmniejszające zapotrzebowanie na energię. |
improvements[energy_saved] | integer | % | Oszczędność energii względem pierwotnego zapotrzebowania budynku. |
energy_loses | array | - | Procentowe rozbicie strac ciepła na poszczególnie źródła. |
energy_loses[label] | string | - | Nazwa źródła strat ciepła. |
energy_loses[percent] | integer | % | Procent całkowitej straty ciepła budynku jaki przypada na to źródło. |
GET https://cieplo.app/api/materials/{field}
Gdzie field to nazwa pola, w którym lista materiałów jest wykorzystywana, dla którego ma być zwrócona lista odpowiednich materiałów (dla każdego z pól lista materiałów jest/może być inna).
{ "123": "Styropian", "125": "Wełna mineralna", "129": "Słoma" }
GET https://cieplo.app/api/subscription
{ "level": "102", "status": "paid", "ends_at": "2025-03-22 01:52:44", }
Parametr | Typ danych | Opis |
---|---|---|
level | string | Poziom subskrypcji. |
status | string | Status subskrypcji:
|
ends_at | datetime | Znacznik czasu końca ważności subskrypcji. W przypadku bezpłatnego okresu próbnego jest to koniec tegoż okresu. |
{ }