To run the backend of this project, follow the steps outlined below:
- Install MongoDB and MongoDB Compass.
- Ensure you have Node.js and npm installed on your machine.
- Clone the project from GitHub:
git clone https://github.com/kartik-raj7/adv-backend.git
- Navigate into the project directory:
cd adv-backend
- Install project dependencies:
npm install
Create a .env
file at the root of the project directory.
Add the following environment variables to the .env
file:
DATABASE_URL="mongodb://localhost:27017"
JWT_SECRET_KEY="jfds6532d9dx3ddsdf93v5" // add any random key here for secret key generation
EMAIL_HOST='smtp.gmail.com'
EMAIL_PORT=587
EMAIL_USER='[email protected]' // add your email here
EMAIL_PASS='your email password' // add your email password here
EMAIL_FROM='[email protected]' // add your email here
API_KEY='YOUR_CLOUDINARY_API_KEY'
API_SECRET='YOUR_CLOUDINARY_API_KEY'
API_ENVIRONMENT_VARIABLE='YOUR_CLOUDINARY_ENVIRONMENT_VARIABLE'
API_CLOUD_NAME='YOUR_CLOUDINARY_CLOUD_NAME'
- Create an account on Cloudinary and obtain the necessary credentials.
- Fill in the corresponding keys in the
.env
file with the obtained credentials.
Once you have completed the installation and configuration steps, you can start the backend server by running:
npm run dev
The base URL for accessing the API is https://adv-backend.vercel.app
.
- /api/user/register (POST)
- /api/user/login (POST)
- /api/user/userprofile (GET)
- /api/user/postad (POST)
- /api/user/getads (GET)
- /api/user/ad/{id} (PATCH)
- /api/user/ad/{id} (DELETE)
- /api/user/admetric (POST)
- /api/user/uploadmedia (POST)
- /api/user/allmedia (GET)
- /api/user/usersearch?search={search_query} (GET)
- /api/user/updaterole/{userid} (POST)
Endpoint: POST /api/user/register
This endpoint allows users to register with the platform.
There will be three types a user can register as:
- Client - User registered as client can view ads posted by advertiser
- Content Creator - User registered as content creator will be able to view the content posted by the creator and also will have functionality to post new content
- Advertiser - User registered as an advertiser can post ads as well as monitor the analytics of the ads posted by him.
No authentication is required for accessing the registration endpoint.
The request body should be a JSON object with the following fields:
name
(string, required): The name of the user.email
(string, required): The email address of the user.password
(string, required): The password for the user.type
(string, required): The type of user (Client, Content Creator, Advertiser).location
(string, optional): The location of the user (required only for Client type).
- Success Response: Status 200 OK
{
"status": "success",
"message": "Registration successful",
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySUQiOiI2NWJhNjRhYjkzNGRlYmFkZTE4NThkZWIiLCJpYXQiOjE3MDY3MTQyODMsImV4cCI6MTcwNzMxOTA4M30.JyAS7TqsoB8fSMb2EkX0XJkE-3EERiwER3mhdlm_IR0"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Email already exists"
}
Endpoint: POST /api/user/login
This endpoint allows to login user using email and password the user used to register previously
No authentication is required for accessing the registration endpoint.
The request body should be a JSON object with the following fields:
email
(string, required): The email address of the user.password
(string, required): The password for the user.
- Success Response: Status 200 OK
{
"status": "success",
"message": "Login successful",
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySUQiOiI2NWJhNjRhYjkzNGRlYmFkZTE4NThkZWIiLCJpYXQiOjE3MDY3MTQyODMsImV4cCI6MTcwNzMxOTA4M30.JyAS7TqsoB8fSMb2EkX0XJkE-3EERiwER3mhdlm_IR0"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Wrong Email or password"
}
Endpoint: GET /api/user/userprofile
This endpoint is used to get the details of the user
Include the bearer token in the Authorization header.
The request body should be empty
- Success Response: Status 200 OK
{
"user": {
"name": "Coca Cola",
"email": "[email protected]",
"type": "Client",
"location": "Delhi"
}
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Unauthorized User"
}
Endpoint: POST /api/user/postad
This endpoint allows advertisers to post ad
Include the bearer token in the Authorization header.
The request body should be a JSON object with the following fields:
ad_headline
(string, required): The headline of the advertisement.ad_detail
(string, required): Details of the advertisement.ad_description
(string, required): A description of the advertisement.ad_url
(string, required): The URL associated with the advertisement.ad_scheduledtime
(string, required): The scheduled time for the advertisementad_expirationtime
(string, required): The expiration time for the advertisementad_location
(string, required): The location associated with the advertisement.ad_multimedia
(string, required): multimedia associated with advertisement if choosing from previous ones url will be sent otherwise the file
- Success Response: Status 200 OK
{
"status": "success",
"message": "Add created successfully"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Failed to create ad"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Only Advertiser are permitted to post Ad"
}
Endpoint: GET /api/user/getads
This endpoint is used to get ads. Advertisers can only access the ads that are posted by them whereas others will be able to access the ads that are live (ie those ads that are scheduled for display on the day the api is called).
Include the bearer token in the Authorization header.
The request body is empty
- Success Response: Status 200 OK (For any user except Advertiser)
{
"status": "success",
"data": [
{
"_id": "65b6ad54debf25c5aa616686",
"ad_headline": "Coca Cola",
"ad_multimedia": "http://res.cloudinary.com/dmiajuv8k/image/upload/v1706381619/koclxhhh8ppwd2wgz5e1.png",
"ad_detail": "testing",
"ad_description": "testing",
"ad_url": "http://res.cloudinary.com/dmiajuv8k/image/upload/v1706381619/koclxhhh8ppwd2wgz5e1.png",
"ad_scheduledtime": "2024-01-29T19:38:54.760Z",
"ad_expirationtime": "2024-02-21T19:38:54.760Z",
"ad_location": "Delhi",
"ad_creator": "[email protected]"
}
]
}
- Success Response: Status 200 OK (For Advertiser)
{
"status": "success",
"data": [
{
"_id": "65b6ad54debf25c5aa616686",
"ad_headline": "Coca Cola",
"ad_multimedia": "http://res.cloudinary.com/dmiajuv8k/image/upload/v1706381619/koclxhhh8ppwd2wgz5e1.png",
"ad_detail": "testing",
"ad_description": "testing",
"ad_url": "http://res.cloudinary.com/dmiajuv8k/image/upload/v1706381619/koclxhhh8ppwd2wgz5e1.png",
"ad_scheduledtime": "2024-01-29T19:38:54.760Z",
"ad_expirationtime": "2024-02-21T19:38:54.760Z",
"ad_location": "Delhi",
"ad_creator": "[email protected]",
"metrics": {
"_id": "65b6ad54debf25c5aa616688",
"ad_id": "65b6ad54debf25c5aa616686",
"ad_view": 319,
"ad_clicks": 5,
"clicked_by": []
}
},
]
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Unauthorized User"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Failed to retrieve ads"
}
Endpoint: PATCH /api/user/ad/{ad_id}
This endpoint is used to edit ads posted by the advertiser.Only advertisers are permitted to access this functionality.
Include the bearer token in the Authorization header.
The request body should be a JSON object with the following fields:
ad_headline
(string, optional): The headline of the advertisement.ad_detail
(string, optional): Details of the advertisement.ad_description
(string, optional): A description of the advertisement.ad_url
(string, optional): The URL associated with the advertisement.ad_scheduledtime
(string, optional): The scheduled time for the advertisementad_expirationtime
(string, optional): The expiration time for the advertisementad_location
(string, optional): The location associated with the advertisement.ad_multimedia
(string, optional): multimedia associated with advertisement if choosing from previous ones url will be sent otherwise the file
- Success Response: Status 200 OK
{
"status": "success",
"message": "Ad updated successfully"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Failed to update ad"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Ad not found or you don't have permission to edit this ad"
}
Endpoint: DELETE /api/user/ad/{ad_id}
This endpoint is used to delete ads posted by the advertiser.Only advertisers are permitted to access this functionality.
Include the bearer token in the Authorization header.
The request body is empty
- Success Response: Status 200 OK
{
"status": "success",
"message": "Ad deleted successfully"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Failed to delete ad"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Ad not found or you don't have permission to delete this ad"
}
Endpoint: POST /api/user/admetric
This endpoint is used to update the views and click count of the ads posted by the advertiser. Only clients are permitted to access this functionality.
Include the bearer token in the Authorization header.
The request body should be a JSON object with the following fields:
views
(array,required) : array of ads with their ad_ids and countclicks
(array,required) : array of ads with their ad_ids and count
- Success Response: Status 200 OK
{
"status": "success",
"message": "Ad updated successfully"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Invalid request"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Failed to update metrics"
}
Endpoint: POST /api/user/uploadmedia
This endpoint is used to upload multimedia (ie audio and video) .Only Content Creators are permitted to access this functionality.
Include the bearer token in the Authorization header.
The request body should be a JSON object with the following fields:
ad_multimedia
(string,required): "BASE64_ENCODED_MULTIMEDIA_DATA"
- Success Response: Status 200 OK
{
"status": "success",
"message": "Image uploaded successfully"
"link": "https://www.exampleimageurl.com/adjsdfnnm"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Could not upload multimedia"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Something went wrong"
}
Endpoint: GET /api/user/allmedia
This endpoint is used to get multimedia. For advertisers this api will return all the multimedia that is present in the database whereas for content creators it will be limited to only that data that is posted by the creator himself.
Note- Advertisers and Content Creators can access the media available. Content creator can only access media uploaded by him/her whereas advertisers can access all the media
Include the bearer token in the Authorization header.
The request body should be empty
- Success Response: Status 200 OK
{
"status": "success",
"data": [
{
"_id": "65b2bdbd9d48e3efb7277241",
"url": "http://res.cloudinary.com/dmiajuv8k/image/upload/v1706212796/gl4usfkcuvrcpamt3vxi.png",
"format": "png",
"resource_type": "image"
}
]
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "Invalid request"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Something went wrong"
}
Endpoint: GET /api/user/usersearch
This endpoint is used by the Admins to search for the users by email or by their name in the database.This api will return the users that have same name or email as in the query
Include the bearer token in the Authorization header.
search
(string, required): The search query.(search is based on user name and email)
The request body should be empty
- Success Response: Status 200 OK
{
"status": "success",
"message": "data fetched",
"data": [
{
"_id": "65afd6550f7cbf8600e39ad8",
"name": "Kartikey",
"email": "[email protected]",
"type": "Advertiser"
},
{
"_id": "65b02611df2e790111673bdf",
"name": "tester1",
"email": "[email protected]",
"type": "Client",
"location": "Delhi"
},
]
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "You don't have permissions to make this request contact support"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Something went wrong"
}
Endpoint: POST /api/user/updaterole/{user_id}
This endpoint is will be used to modify the role of any user from the roles(Advertiser,Content Creator and Client).
Include the bearer token in the Authorization header.
The request body should be a JSON object with the following fields:
user_role
(string, required): "Advertiser"
- Success Response: Status 200 OK
{
"status": "success",
"message": "Role updated successfully"
}
- Error Response: Status 400 FAILED
{
"status": "failed",
"message": "You don't have permissions to make this request contact support"
}
- Error Response: Status 404 FAILED
{
"status": "failed",
"message": "Something went wrong"
}