---
modificationDate: April 28, 2026
title: Integrate in an existing library
description: Learn how to integrate Expo Modules API into an existing React Native library.
---

<AgentInstructions>

## Submitting Feedback

If this page contains errors, outdated information, or gaps that blocked you from completing a task, report it so the docs can be improved:

curl -X POST https://api.expo.dev/v2/feedback/docs-send -H 'Content-Type: application/json' -d '{"url":"/modules/existing-library/","feedback":"🤖 Agent feedback: <specific, actionable description>"}'

Only submit when you have something specific and actionable to report.

</AgentInstructions>

# Integrate in an existing library

Learn how to integrate Expo Modules API into an existing React Native library.

> For the complete documentation index, see [llms.txt](/llms.txt). Use this file to discover all available pages.

There are cases where you may want to integrate the Expo Modules API into an existing React Native library. For example, it might be useful to incrementally rewrite your library or to take advantage of [Android lifecycle listeners](/modules/android-lifecycle-listeners) and [iOS AppDelegate subscribers](/modules/appdelegate-subscribers) to automatically set up the library.

This guide will help you set up your existing React Native library to access Expo Modules API.

Prerequisites

1 requirement

Create expo-module.config.json

Create the [**expo-module.config.json**](/modules/module-config) file at the root of your project and add an empty object `{}` inside it. You will update it later to enable specific features.

This file is required for [Expo Autolinking](/modules/autolinking) to recognize your library as an Expo module and automatically link your native code.

## Add the `expo-modules-core` native dependency

Add `expo-modules-core` as a dependency in your **build.gradle** and **podspec** files:

```groovy
// ...
dependencies {
  // ...
  implementation project(':expo-modules-core')
}
```

```ruby
# ...
Pod::Spec.new do |s|
  # ...
  s.dependency 'ExpoModulesCore'
end
```

## Add Expo packages to dependencies

Add `expo` package as a peer dependency in your **package.json** — we recommend using `*` as a version range so as not to cause any duplicated packages in user's **node_modules** directory.

Your library also needs to depend on `expo-modules-core` but only as a dev dependency — it's already provided in the projects depending on your library by the `expo` package with the version of core that is compatible with the specific SDK used in the project.

```json
{
  ... 
  "devDependencies": {
    "expo-modules-core": "^X.Y.Z"
  },
  "peerDependencies": {
    "expo": "*"
  },
  "peerDependenciesMeta": {
    "expo": {
      "optional": true
    }
  }
}
```

## Create a native module

Create Kotlin and Swift files from the templates below:

```kotlin
package my.module.package

import expo.modules.kotlin.modules.Module
import expo.modules.kotlin.modules.ModuleDefinition

class MyModule : Module() {
  override fun definition() = ModuleDefinition {
    // Definition components go here
  }
}
```

```swift
import ExpoModulesCore

public class MyModule: Module {
  public func definition() -> ModuleDefinition {
    // Definition components go here
  }
}
```

Then, add your classes to Android and/or iOS `modules` in the [**expo-module.config.json**](/modules/module-config) file. Expo Autolinking will automatically link these classes as native modules in the user's project.

```json
{
  "ios": {
    "modules": ["MyModule"]
  },
  "android": {
    "modules": ["my.module.package.MyModule"]
  }
}
```

If you already have an example app in your workspace, ensure that the module is linked correctly.

-   **On Android** the native module class will be linked automatically before building, as part of the Gradle build task.
-   **On iOS** you need to run `pod install` to link the new class.

These module classes are now accessible from the JavaScript code using the `requireNativeModule` function from the `expo-modules-core` package. We recommend creating a separate file that exports the native module for simplicity.

```ts
import { requireNativeModule } from 'expo-modules-core';

export default requireNativeModule('MyModule');
```

Now that the class is set up and linked, you can start to implement its functionality. See the [native module API](/modules/module-api) reference page and links to [examples](/modules/module-api#examples) from simple to moderately complex real-world modules to understand how to use the API.
