Contributing | Documentation | Code of Conduct | Slack Channel
Igbo is the principal native language of the Igbo people, an ethnic group of southeastern Nigeria, and is spoken by approx 45 million people with more than 20 different dialects.
📚 4,500+ Igbo words, 5,000+ dialectal variations, 17,000+ Igbo example sentences
✍🏾 English and Igbo definitions
🗣 Audio pronunciations for words and examples
🔎 Full-text search with diacritic support
Let's get the Igbo API running locally on your machine.
To run this project locally, please install the following:
- Node.js
- Yarn
- Mongo for Windows
- Mongo for Mac
- Firebase
- Java
- NVM
- MongoDB Compass (Optional)
Clone the project:
git clone https://github.com/nkowaokwu/igbo_api.git
Note: It's recommended to have NVM installed so you can easily switch between Node versions that are required in this project.
Navigate into the project directory and install its dependencies:
cd igbo_api/
yarn install
Build the frontend for the site:
yarn build
This project uses Firebase and requires you to create your own free Firebase project.
Please follow the Firebase Configuration Guide here
Once you've configured your project, you can start the Igbo API dev server by running:
yarn dev
Navigate to localhost:8080 to see the API
To start the dev API server while running MongoDB Replica sets and the Redis cache, run:
yarn dev:full
To start a Redis server, run:
redis-server
Warning: Running replica sets locally is machine intensive and should only be ran for testing or specific-feature development purposes.
Reminder: You must have Redis installed on your machine in order to run the server.
If you don't want to run a local Node and MongoDB, you can use Docker
Run the following command:
yarn start:docker
Navigate to localhost:8080 to see the API
To start up the front site for the API, run:
yarn dev:site
Navigate to localhost:3000 to see the API front site
To populate the database complete the following steps:
The following command places the JSON dictionaries in the build/
directory:
yarn build:dictionaries
Here's an example JSON dictionary file: ig-en/ig-en_expanded.json
Now that the data has been parsed, it needs to be used to populate, or seed, the MongoDB database.
Start the development server:
yarn dev
Then make a POST
request to the following route:
/api/v1/test/populate
For example:
http://localhost:8080/api/v1/test/populate // POST
After about 20 seconds, if you see the ✅ Seeding successful.
message in your terminal, then you have successfully populated your database.
Install one of the options on your machine to view the seeded data
Option 1: Download MongoDB Compass
https://docs.mongodb.com/manual/administration/install-community/
Option 2: Install MongoDB VSCode extension
https://marketplace.visualstudio.com/items?itemName=mongodb.mongodb-vscode
Connect to your local mongodb cluster using this connection:
mongodb://127.0.0.1:27017/igbo_api
The database has gone through a number of migrations since the beginning of this project. To ensure that local testing data is the same shape as the data in the production MongoDB database, run all MongoDB migration scripts with the following command:
yarn migrate-up
Frontend tests focus specifically on the Igbo API homepage using Cypress. First, run:
yarn build
To watch frontend tests, run:
yarn cypress
Backend tests use both locally stored MongoDB and JSON data, so to spin up an instance of MongoDB and start the tests at the same time, run:
yarn test
If you want to run your MongoDB instance and tests in separate terminals, you can run:
Visit our 📚 documentation website to learn how to use the Igbo API within your own project.