# Introduction

{% hint style="info" %}
**Standard set of API**s and specifications **used to interact with aragonOS-powered contracts** by handling transaction pathing, upgradeability, and contract state without depending on a centralized service.
{% endhint %}

## Reference implementations in specific languages <a href="#reference-implementations-in-specific-languages" id="reference-implementations-in-specific-languages"></a>

#### JavaScript <a href="#javascript" id="javascript"></a>

A JavaScript implementation of the aragonAPI, used to interact with aragonOS by handling transaction pathing, upgradeability, identity providers and state of the contracts.

Some of the things you can do with the JavaScript implementation are:

* Connect contracts to front-end
* Interact with [aragonOS](https://legacy-docs.aragon.org/developers/tools/aragonos) and aragonOS-powered applications directly through an abstraction over web3.js
* Get access to application state with built in client-side caching
* Create human-readable transaction descriptions for your smart contracts through [Radspec](https://legacy-docs.aragon.org/developers/tools/the-basics/human-readable-transactions)

**Docs**

* [Quick Start for apps](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/quick-start)
* [App API](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/app-api)
  * [React API](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/react-api)
* [Aragon client implementations (wrapper)](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/wrapper)
* [Providers](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/providers)
* [Architecture of Aragon apps and their communication channels](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/architecture-off-apps)

**Guides**

* [Background Scripts](https://legacy-docs.aragon.org/developers/tools/aragonapi/javascript/background-scripts)
