# Blynk Library - firmware API

- [Installation](https://docs.blynk.io/en/blynk-library-firmware-api/installation.md): How to install Blynk library on popular IDEs
- [Install Blynk Library in Arduino IDE](https://docs.blynk.io/en/blynk-library-firmware-api/installation/install-blynk-library-in-arduino-ide.md): Step by step guide on how to install Blynk Library
- [Install Blynk Library for Platformio.org](https://docs.blynk.io/en/blynk-library-firmware-api/installation/install-blynk-library-for-platformio.org.md)
- [Install ESP8266 core for Arduino IDE](https://docs.blynk.io/en/blynk-library-firmware-api/installation/install-esp8266-core-for-arduino-ide.md)
- [Configuration](https://docs.blynk.io/en/blynk-library-firmware-api/configuration.md)
- [Connection Management](https://docs.blynk.io/en/blynk-library-firmware-api/connection-management.md)
- [Device Online/Offline Status](https://docs.blynk.io/en/blynk-library-firmware-api/devices-online-status.md)
- [Digital/Analog Pins](https://docs.blynk.io/en/blynk-library-firmware-api/digital-analog-pins.md)
- [Virtual Pins](https://docs.blynk.io/en/blynk-library-firmware-api/virtual-pins.md): Send and receive data from device
- [Widget Properties](https://docs.blynk.io/en/blynk-library-firmware-api/widget-properties.md): The widget property is a widget attribute like color, labels, min/max, ..., and others that could be dynamically changed from the hardware or HTTPS API.
- [State Syncing](https://docs.blynk.io/en/blynk-library-firmware-api/state-syncing.md): A feature in the Blynk library firmware API that allows the hardware device and the Blynk server and apps to keep track of the same state.
- [Timers](https://docs.blynk.io/en/blynk-library-firmware-api/blynk-timer.md): How to use timers in code
- [Time (RTC clock)](https://docs.blynk.io/en/blynk-library-firmware-api/rtc-clock.md): Working with time using Blynk API
- [Timezone / Location](https://docs.blynk.io/en/blynk-library-firmware-api/timezone-location.md)
- [Log Event](https://docs.blynk.io/en/blynk-library-firmware-api/log-event.md): How to log an event using firmware API
- [Metadata](https://docs.blynk.io/en/blynk-library-firmware-api/metadata.md): Set and receive metadata values
- [Debug](https://docs.blynk.io/en/blynk-library-firmware-api/debug.md)
- [Reboot](https://docs.blynk.io/en/blynk-library-firmware-api/reboot.md)
- [Over-The-Air Firmware Updates (OTA)](https://docs.blynk.io/en/blynk-library-firmware-api/ota-updates.md)
- [Other](https://docs.blynk.io/en/blynk-library-firmware-api/other.md)
- [Limitations and Recommendations](https://docs.blynk.io/en/blynk-library-firmware-api/limitations-and-recommendations.md)
- [Blynk Protocol](https://docs.blynk.io/en/blynk-library-firmware-api/blynk-protocol.md)


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.blynk.io/en/blynk-library-firmware-api.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
