Skip to content

Transform your writing into engaging AI-generated podcasts. Ditch the mics and sound-proof rooms, and tap into a new audience base without the added effort. 2day converts your blogs and articles into audio podcasts.

License

Notifications You must be signed in to change notification settings

awaseem/2day-api

Repository files navigation

2Day 📻

Transform your writing into engaging AI-generated podcasts. Ditch the mics and sound-proof rooms, and tap into a new audience base without the added effort. 2day converts your blogs and articles into audio podcasts. See it in action here

Looking for the source code for the demo site? It's available here

Getting started

Install all the dependencies:

npm install

You'll need a few third party services API keys in a new .env file within the root of the project.

# Supabase: You can create a new project here: https://supabase.com/
DATABASE_URL=''
STORAGE_URL=''
SERVICE_KEY=''
BUCKET_NAME=''

# Redis: You can create a cloud hosted redis instance free here: https://upstash.com/
REDIS_URL=''
REDIS_PORT=''
REDIS_PASSWORD=''

# Open AI: You can create your keys for Open AI here: https://platform.openai.com/account/api-keys
OPENAI_API_KEY=''

# 11 Labs: You can create an account here: https://beta.elevenlabs.io
ELEVEN_LABS_API_KEY=''

Once all the values are supplied within an .env, simply run the following command:

npm start

Generating content

1. Create an account

You'll first need to create an account to do requests to the API:

curl --request POST \
  --url http://localhost:3000/v1/account

The response should be the following:

{
  "accountId": "<ACCOUNT_ID>",
  "apiKey": "<ACCOUNT_API_KEY>"
}

2. Create a source

You will then need to supply a source for the AI to fetch data from:

curl --request POST \
  --url http://localhost:3000/v1/source \
  --header 'Content-Type: application/json' \
  --header 'x-account-api-key: <ACCOUNT_API_KEY>' \
  --header 'x-account-id: <ACCOUNT_ID>' \
  --data '{
	"data": [
		{
			"type": "ARTICLE",
			"url": "https://www.readthepeak.com/stories/04-23-are-customer-service-reps-getting-free-goldfish"
		},
		{
			"type": "ARTICLE",
			"url": "https://www.cbc.ca/news/canada/calgary/danielle-smith-media-questions-alberta-politics-1.6812184"
		},
		{
			"type": "ARTICLE",
			"url": "https://www.esquire.com/entertainment/tv/a43518988/pedro-pascal-the-last-of-us-interview-2023/?utm_source=pocket-newtab"
		}
	]
}'

The response should be the following:

{
	"id": "216c988b-8092-48f3-afe5-feb58033ab3d", // <= This ID is important as its required when creating a script
	"createdAt": "2023-04-17T03:18:14.819Z",
	"sourceData": [
    // List of all the sources you supplied
    ...
	],
  ...
}

3. Create script

Now you can create a script with the source Id

curl --request POST \
  --url http://localhost:3000/v1/script \
  --header 'Content-Type: application/json' \
  --header 'x-account-api-key: <ACCOUNT_API_KEY>' \
  --header 'x-account-id: <ACCOUNT_ID>' \
  --data '{
	"sourceId": "216c988b-8092-48f3-afe5-feb58033ab3d"
}'

The response should be the following:

{
  "message": "Job started 🚀"
}

Now it can take upwards of 1-2 minutes to generate content and voice, you can continue to query the get script endpoint which will always return the most recent script. It takes the source ID as a param

curl --request GET \
  --url http://localhost:3000/v1/script/216c988b-8092-48f3-afe5-feb58033ab3d \
  --header 'x-account-api-key: <ACCOUNT_API_KEY>' \
  --header 'x-account-id: <ACCOUNT_ID>' \

About

Transform your writing into engaging AI-generated podcasts. Ditch the mics and sound-proof rooms, and tap into a new audience base without the added effort. 2day converts your blogs and articles into audio podcasts.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages