# Initialize the library

To use the library and create custom inventories, it first must be initialized by defining a set of reusable Java objects. This is done by using the `CraftVentoryLibrary` class that provides several methods to use the default behaviors implemented in the library.

### Create an InventoryService

An `InventoryService` is a class with two purposes:

* Register, store and retrieve [inventory providers](/craftventory/get-started/declare-an-inventory.md)
* Store information about players with an opened inventory and manage inventories' life cycle

An instance of this class with the default behavior provided by the library can be created by using the following code:

```java
InventoryService service = CraftVentoryLibrary.createInventoryService(Plugin plugin);
```

> Note: We recommand to store this object as an instance variable in the main class of your plugin (eq. the class that extends `JavaPlugin`).

### Create an InventoryConfigDAO

An `InventoryConfigDAO` is a class used to load an inventory from a configuration file. By default, the library provides an instance of this class to load inventories from **YAML** files. The following code uses the library built-in methods to create a new instance of `InventoryConfigDAO`:

```java
// Factory used to load item click actions.
ClickActionLoaderFactory<ConfigurationSection> factory =
        FastInventoryLibrary.createDefaultClickActionLoaderFactory();

InventoryConfigDAO dao = FastInventoryLibrary.createDefaultConfigDAO(factory);
```

> Note: `ClickActionLoaderFactory` is a class that is used to load item actions from the configuration file.

### Example

Here is a complete example:

```java
public class CraftVentoryPlugin extends JavaPlugin {

    private InventoryService inventoryService;

    @Override
    public void onEnable() {
        this.inventoryService = CraftVentoryLibrary.createInventoryService(this);
        this.loadInventoryProviders();
    }

    private void loadInventoryProviders() {

        ClickActionLoaderFactory<ConfigurationSection> factory =
                FastInventoryLibrary.createDefaultClickActionLoaderFactory();

        InventoryConfigDAO dao = FastInventoryLibrary.createDefaultConfigDAO(factory);

        // Register inventory providers here.
    }
}
```


---

# 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://syrows-development.gitbook.io/craftventory/get-started/initialize-the-library.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.
