Node JS and Mongo DB API Documentation
Base URL: http://localhost:3000
User Authentication & Profile
POST /register
Description: Register a new user.
Arguments
Name |
Type |
Required |
Description |
name |
string |
Required |
Name of user. |
email |
string |
Required |
Email of user. |
password |
string |
Required |
Password of user. |
Example Request
curl -X POST http://localhost:3000/register \
-d "name=Adnan&email=adnan@gmail.com&password=adnan"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Account has been registered. You can login now."
}
- 200 OK: Request successful.
Response
{
"status": "error",
"message": "Email already exists."
}
POST /login
Description: Logs-in a user.
Arguments
Name |
Type |
Required |
Description |
email |
string |
Required |
Email of user. |
password |
string |
Required |
Password of user. |
Example Request
curl -X POST http://localhost:3000/login \
-d "email=adnan@gmail.com&password=adnan"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Login successfully.",
"accessToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com"
}
}
POST /save-profile
Description: Update user name or profile image.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
name |
string |
Required |
Name of user. |
profileImage |
file |
Optional |
New profile image. |
Example Request
curl -X POST http://localhost:3000/save-profile \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "profileImage=@path/to/your/file.jpg" \
-F "name=Adnan"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Profile has been updated.",
"profileImage": {
"size": 577210,
"path": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG",
"name": "Photo0032.JPG",
"type": "image/jpeg"
}
}
POST /me
Description: Returns the authenticated user.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Example Request
curl -X POST http://localhost:3000/me \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"unreadNotifications": 0
}
POST /logout
Description: Logs-out the user.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Example Request
curl -X POST http://localhost:3000/logout \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Logout successfully."
}
POST /change-password
Description: Change password of user.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
password |
string |
Required |
Current password of user. |
newPassword |
string |
Required |
New password of user. |
confirmPassword |
string |
Required |
Re-type new password. |
Example Request
curl -X POST http://localhost:3000/change-password \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "password=adnan&newPassword=adnan565&confirmPassword=adnan565"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Password has been changed."
}
Posts
POST /sn/posts/create
Description: Creates a new social network post.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
caption |
string |
Optional |
Caption of post. |
type |
string |
Required |
["post", "shared", "page", "group"] |
pageId |
string |
Optional |
Page ID, in case the post is being posted on a page. |
groupId |
string |
Optional |
Group ID, in case the post is being posted on a group. |
files[] |
Array of files |
Optional |
Images or videos in post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/create \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "caption=My first post" \
-F "files[]=[@path/to/your/file.jpg]"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been created.",
"post": {
"_id": "6772d2573e3a7f1d0d35cefa",
"caption": "My first post",
"type": "post",
"files": [
{
"name": "799226c3-2ef0-41ee-9dcb-3cd3f0029055.MP4",
"size": 4545977,
"type": "video/mp4",
"path": "http://localhost:3000/uploads/public/posts/3cd3f0029055.MP4"
}
],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"createdAt": "12/30/2024, 10:03:19 PM",
"updatedAt": "12/30/2024, 10:03:19 PM",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
}
}
}
POST /sn/posts/share
Description: Shares a post on your timeline.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post that needs to be shared. |
caption |
string |
Optional |
Caption of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/share \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=6773799669bb298f68d9a833" \
-d "caption=Sharing"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been shared."
}
POST /sn/posts/fetch-sharers
Description: Fetch users who has shared the post.
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/posts/fetch-sharers \
-d "_id=6773799669bb298f68d9a833" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"sharers": [
{
"_id": "67738f67d5b017474582ef02",
"postId": "6773799669bb298f68d9a833",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"createdAt": "12/31/2024, 11:29:59 AM"
}
]
}
POST /sn/posts/fetch
Description: Fetch all the posts from social network.
Arguments
Name |
Type |
Required |
Description |
userId |
string |
Optional |
ID of user to return that user's posts only. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/posts/fetch \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"posts": [
{
"_id": "6773880c5c988c96aeff94f1",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"caption": "Check this out.",
"type": "shared",
"sharedPost": {
"_id": "6773799669bb298f68d9a833",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"caption": "Test",
"type": "post",
"files": [],
"views": 0,
"likes": 1,
"comments": 0,
"shares": 1,
"hasLiked": false,
"createdAt": "12/31/2024, 9:56:54 AM"
},
"files": [
{
"name": "Screenshot 2024-12-31 at 9.14. AM.png",
"size": 87437,
"type": "image/png",
"path": "http://localhost:3000/uploads/public/posts/6773799669bb298f68d9a833/Screenshot 2024-12-31 at 9.14. AM.png"
}
],
"views": 0,
"likes": 1,
"comments": 0,
"shares": 0,
"hasLiked": true,
"createdAt": "12/31/2024, 10:58:36 AM"
}
]
}
POST /sn/posts/fetch/6772d21a3e3a7f1d0d35cef9
Description: Fetch single post.
Parameters
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/fetch/6772d21a3e3a7f1d0d35cef9
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"posts": [
{
"_id": "6772d21a3e3a7f1d0d35cef9",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"caption": "test",
"type": "post",
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "12/30/2024, 10:02:18 PM"
}
]
}
POST /sn/posts/update
Description: Updates a post.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post that needs to be updated. |
caption |
string |
Optional |
Caption of post. |
files[] |
Array of files |
Optional |
Images or videos in post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/update \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "caption=My updated post" \
-F "files[]=[@path/to/your/file.jpg]"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been updated."
}
POST /sn/posts/remove-file
Description: Removes a file from the post.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
path |
string |
Optional |
The path of file. |
Example Request
curl -X POST http://localhost:3000/sn/posts/remove-file \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=6772d21a3e3a7f1d0d35cef9" \
-d "path=http://localhost:3000/uploads/public/posts/6772d21a3e3a7f1d0d35cef9/image.png"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "File has been removed."
}
POST /sn/posts/delete
Description: Delete the post.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/delete \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=6772d21a3e3a7f1d0d35cef9"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been deleted."
}
POST /sn/posts/toggle-like
Description: Likes or dislikes a post.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/toggle-like \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=6772d334ace8f55f58cc3883"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been liked.",
"type": "liked"
}
POST /sn/posts/fetch-likers
Description: Fetch all the people who has liked a post.
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/posts/fetch-likers \
-d "_id=6772d334ace8f55f58cc3883" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"likers": [
{
"_id": "6772d4f76e772a8eff70bb40",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"createdAt": "12/30/2024, 10:14:31 PM"
}
]
}
POST /sn/posts/replies/send
Description: Sends a reply to a comment.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of comment. |
reply |
string |
Required |
Reply to be posted. |
Example Request
curl -X POST http://localhost:3000/sn/posts/replies/send \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=6772d6e66e772a8eff70bb42" \
-d "reply=Thanks."
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Reply has been posted.",
"reply": {
"_id": "6772d90e6e772a8eff70bb44",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"reply": "Thanks.",
"createdAt": "12/30/2024, 10:31:58 PM"
}
}
POST /sn/posts/replies/fetch
Description: Fetch replies on a comment.
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of comment. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/posts/replies/fetch \
-d "_id=677243747242a14a24bbf0e4" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Reply has been fetched.",
"replies": [{
"_id": "677243747242a14a24bbf0e4",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"reply": "Thanks.",
"comment": "Nice.",
"createdAt": "12/30/2024, 11:53:40 AM"
}]
}
POST /sn/posts/replies/fetch-single
Description: Fetch single reply on a comment.
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of comment. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/posts/replies/fetch-single \
-d "_id=677243747242a14a24bbf0e4" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Reply has been fetched.",
"reply": {
"_id": "677243747242a14a24bbf0e4",
"user": {
"_id": "676db209053557d2d7b23de5",
"name": "Adnan Afzal",
"profileImage": "http://localhost:3000/uploads/public/profiles/Photo0032.JPG"
},
"reply": "Thanks.",
"comment": "Nice.",
"createdAt": "12/30/2024, 11:53:40 AM"
}
}
POST /sn/posts/replies/update
Description: Update your reply.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of reply. |
reply |
string |
Required |
Updated reply text. |
Example Request
curl -X POST http://localhost:3000/sn/posts/replies/update \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677243747242a14a24bbf0e4" \
-d "reply=Nice"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Reply has been updated."
}
POST /sn/posts/replies/delete
Description: Delete my reply.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of reply. |
Example Request
curl -X POST http://localhost:3000/sn/posts/replies/delete \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "caption=677243747242a14a24bbf0e4"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Reply has been deleted."
}
Pages
POST /sn/pages/create
Description: Creates a new page.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
name |
string |
Required |
Name of the page. |
description |
string |
Required |
A little description about the page. |
image |
file |
Required |
Cover photo for the page. |
Example Request
curl -X POST http://localhost:3000/sn/pages/create \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "name=My page" \
-F "description=My page" \
-F "image=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Page has been created.",
"page": {
"_id": "67790963dd4859ee4d380471",
"name": "My page",
"description": "My page",
"userId": "677501e0300a154edcd8f40c",
"followers": 0,
"image": {
"path": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png",
"name": "Photo0032.JPG",
"size": 577210
},
"createdAt": "Sat, 04 Jan 2025 10:11:47 GMT",
"updatedAt": "Sat, 04 Jan 2025 10:11:47 GMT",
}
}
POST /sn/pages/fetch-single
Description: Fetch detail of a page.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of page. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/pages/fetch-single \
-d "_id=67790963dd4859ee4d380471" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"page": {
"_id": "67790963dd4859ee4d380471",
"name": "test",
"description": "test",
"user": {
"_id": "677501e0300a154edcd8f40c",
"name": "Adnan",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg"
},
"followersCount": 1,
"image": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png",
"isFollowing": true,
"isMyPage": true,
"createdAt": "1/4/2025, 3:11:47 PM",
"followers": [
{
"_id": "67790b4bb593e623fe120e72",
"userId": "677501e0300a154edcd8f40c",
"name": "Adnan",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg",
"createdAt": "1/4/2025, 3:19:55 PM"
}
],
"posts": [
{
"_id": "67790acadd4859ee4d380472",
"user": {
"_id": "677501e0300a154edcd8f40c",
"name": "Adnan",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg"
},
"caption": "Post in page.",
"type": "page",
"sharedPost": null,
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "1/4/2025, 3:17:46 PM",
"page": {
"_id": "67790963dd4859ee4d380471",
"name": "test",
"followers": 1,
"image": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png"
}
}
]
}
}
POST /sn/pages/toggle-follow
Description: Follow or unfollow a page.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of page. |
Example Request
curl -X POST http://localhost:3000/sn/pages/toggle-follow \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=67790963dd4859ee4d380471"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Page has been followed."
}
POST /sn/pages/fetch
Description: Fetch pages.
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
Search by page name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/pages/fetch \
-d "query=test" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"pages": [
{
"_id": "67790963dd4859ee4d380471",
"name": "test",
"description": "test",
"status": "active",
"userId": "677501e0300a154edcd8f40c",
"followers": 1,
"isFollowed": false,
"image": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png",
"createdAt": "1/4/2025, 3:11:47 PM"
}
]
}
POST /sn/pages/fetch-my
Description: Fetch pages that I own.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
Search by page name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/pages/fetch-my \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "query=test" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"pages": [
{
"_id": "67790963dd4859ee4d380471",
"name": "test",
"description": "test",
"status": "active",
"userId": "677501e0300a154edcd8f40c",
"followers": 1,
"isFollowed": false,
"image": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png",
"createdAt": "1/4/2025, 3:11:47 PM"
}
]
}
POST /sn/pages/fetch-my-followed
Description: Fetch pages that I am following.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
Search by page name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/pages/fetch-my-followed \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "query=test" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"pages": [
{
"_id": "67790963dd4859ee4d380471",
"name": "test",
"description": "test",
"status": "active",
"userId": "677501e0300a154edcd8f40c",
"followers": 1,
"isFollowed": false,
"image": "http://localhost:3000/uploads/public/pages/8126855cd4c9.png",
"createdAt": "1/4/2025, 3:11:47 PM"
}
]
}
POST /sn/pages/fetch-followers
Description: Fetch followers of a page.
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of page. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/pages/fetch-followers \
-d "_id=67790963dd4859ee4d380471" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"followers": [
{
"_id": "67790b4bb593e623fe120e72",
"userId": "677501e0300a154edcd8f40c",
"name": "Adnan",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg",
"createdAt": "1/4/2025, 3:19:55 PM"
}
]
}
POST /sn/pages/update
Description: Update page created by you.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of page that needs to be updated. |
name |
string |
Required |
Name of the page. |
description |
string |
Required |
A little description about the page. |
image |
file |
Optional |
Cover photo for the page. |
Example Request
curl -X POST http://localhost:3000/sn/pages/update \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "_id=67790963dd4859ee4d380471" \
-F "name=My page" \
-F "description=My page" \
-F "image=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Page has been updated.",
"page": {
"name": "My page",
"description": "My page",
"updatedAt": "Sat, 04 Jan 2025 12:26:28 GMT",
"image": {
"path": "http://localhost:3000/uploads/public/pages/187f9dfe4507.png",
"name": "Photo0032.JPG",
"size": 577210
}
}
}
POST /sn/pages/delete
Description: Deletes a page.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of page that needs to be deleted. |
Example Request
curl -X POST http://localhost:3000/sn/pages/delete \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=67790963dd4859ee4d380471"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Page has been deleted."
}
Groups
POST /sn/groups/create
Description: Creates a new group.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
name |
string |
Required |
Name of group. |
description |
string |
Required |
A little description about the group. |
image |
file |
Required |
Cover photo for group. |
Example Request
curl -X POST http://localhost:3000/sn/groups/create \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "name=My group" \
-F "description=This is a testing group" \
-F "image=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Group has been created.",
"group": {
"_id": "677f0d36fc4635da9658c8a7",
"name": "My group",
"description": "This is a testing group",
"userId": "677501e0300a154edcd8f40c",
"members": 0,
"image": "http://localhost:3000/uploads/public/groups/33028df6434c.png",
"createdAt": "Wed, 08 Jan 2025 23:41:42 GMT",
"updatedAt": "Wed, 08 Jan 2025 23:41:42 GMT",
}
}
POST /sn/groups/fetch
Description: Fetch groups.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
To search group by name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "query=My group" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"groups": [
{
"_id": "677f0d36fc4635da9658c8a7",
"name": "My group",
"description": "This is a testing group",
"members": 0,
"isJoined": false,
"image": "http://localhost:3000/uploads/public/groups/33028df6434c.png",
"createdAt": "1/9/2025, 4:41:42 AM"
}
]
}
POST /sn/groups/fetch-my
Description: Fetch my created groups.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
To search group by name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch-my \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "query=My group" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"groups": [
{
"_id": "677f0d36fc4635da9658c8a7",
"name": "My group",
"description": "This is a testing group",
"members": 0,
"isJoined": false,
"image": "http://localhost:3000/uploads/public/groups/33028df6434c.png",
"createdAt": "1/9/2025, 4:41:42 AM"
}
]
}
POST /sn/groups/fetch-my-joined
Description: Fetch groups I am a member of.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
query |
string |
Optional |
To search group by name. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch-my-joined \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "query=My group" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"groups": [
{
"_id": "677f0d36fc4635da9658c8a7",
"name": "My group",
"description": "This is a testing group",
"members": 0,
"isJoined": false,
"image": "http://localhost:3000/uploads/public/groups/33028df6434c.png",
"createdAt": "1/9/2025, 4:41:42 AM"
}
]
}
POST /sn/groups/fetch-single
Description: Fetch detail of the group.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
page |
Integer |
Required |
Required for pagination on posts. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch-single \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"group": {
"_id": "677f0d36fc4635da9658c8a7",
"name": "My group",
"description": "This is a testing group",
"membersCount": 1,
"image": "http://localhost:3000/uploads/public/groups/33028df6434c.png",
"isMember": false,
"isAdmin": true,
"createdAt": "1/9/2025, 4:41:42 AM",
"members": [
{
"_id": "677f10cb32165447fe3b1835",
"userId": "677ce2c5444f1da568429d03",
"name": "Adnan 3",
"profileImage": "",
"createdAt": "1/9/2025, 4:56:59 AM"
}
],
"posts": [
{
"_id": "677f105632165447fe3b1834",
"user": {
"_id": "677501e0300a154edcd8f40c",
"name": "Adnan",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg"
},
"caption": "Test",
"type": "group",
"status": "published",
"sharedPost": null,
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "1/9/2025, 4:55:02 AM"
}
],
"pendingPosts": [
{
"_id": "677f10eb32165447fe3b1836",
"user": {
"_id": "677ce2c5444f1da568429d03",
"name": "Adnan 3",
"email": "adnan3@gmail.com",
"profileImage": ""
},
"caption": "Post by member.",
"type": "group",
"status": "pending",
"sharedPost": null,
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "1/9/2025, 4:57:31 AM"
}
],
"pendingPostsCount": 1
}
}
POST /sn/groups/toggle-join
Description: Join or leave the group.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
Example Request
curl -X POST http://localhost:3000/sn/groups/toggle-join \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Group has been joined."
}
POST /sn/groups/fetch-posts
Description: Fetch posts of the group.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch-posts \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"posts": [
{
"_id": "677f105632165447fe3b1834",
"user": {
"_id": "677501e0300a154edcd8f40c",
"name": "Adnan",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg"
},
"caption": "Test",
"type": "group",
"status": "published",
"sharedPost": null,
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "1/9/2025, 4:55:02 AM"
}
]
}
POST /sn/groups/fetch-pending-posts
Description: Fetch pending posts of group members.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/fetch-pending-posts \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"posts": [
{
"_id": "677f105632165447fe3b1834",
"user": {
"_id": "677501e0300a154edcd8f40c",
"name": "Adnan",
"email": "adnan@gmail.com",
"profileImage": "http://localhost:3000/uploads/public/profiles/IMG_1130.jpg"
},
"caption": "Test",
"type": "group",
"status": "published",
"sharedPost": null,
"files": [],
"views": 0,
"likes": 0,
"comments": 0,
"shares": 0,
"hasLiked": false,
"createdAt": "1/9/2025, 4:55:02 AM"
}
]
}
POST /sn/posts/decline
Description: Decline a post of group member.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/decline \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f10eb32165447fe3b1836"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been declined."
}
POST /sn/posts/accept
Description: Accepts a post of group member.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of post. |
Example Request
curl -X POST http://localhost:3000/sn/posts/accept \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f10eb32165447fe3b1836"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Post has been published."
}
POST /sn/groups/members
Description: Fetch members of the group.
Headers
Name |
Required |
Description |
Authorization |
Optional |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
page |
Integer |
Required |
Required for pagination. |
Example Request
curl -X POST http://localhost:3000/sn/groups/members \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"members": [
{
"_id": "677f114932165447fe3b1837",
"userId": "677ce2c5444f1da568429d03",
"name": "Adnan 3",
"profileImage": "",
"createdAt": "1/9/2025, 4:59:05 AM"
}
]
}
POST /sn/groups/remove-member
Description: Remove a member from group.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of member. |
Example Request
curl -X POST http://localhost:3000/sn/groups/remove-member \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f114932165447fe3b1837"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Group member has been removed."
}
POST /sn/groups/update
Description: Update the group.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
name |
string |
Required |
Name of group. |
description |
string |
Required |
A little description about group. |
image |
file |
Optional |
Cover photo of group. |
Example Request
curl -X POST http://localhost:3000/sn/groups/update \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "_id=677f0d36fc4635da9658c8a7" \
-F "name=My group" \
-F "description=This is a testing group" \
-F "image=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Group has been updated.",
"group": {
"name": "My group",
"description": "This is a testing group",
"image": "http://localhost:3000/uploads/public/groups/f523abe9cc1d.png",
"updatedAt": "Thu, 09 Jan 2025 00:22:18 GMT",
}
}
POST /sn/groups/delete
Description: Delete the group.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of group. |
Example Request
curl -X POST http://localhost:3000/sn/groups/delete \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=677f0d36fc4635da9658c8a7"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Group has been deleted."
}
POST /media/upload
Description: Uploads a new media file.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
title |
string |
Optional |
Title of media. |
alt |
string |
Optional |
Alt attribute for images. |
caption |
string |
Optional |
Caption of media. |
file |
file |
Required |
Media file. |
Example Request
curl -X POST http://localhost:3000/media/upload \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "title=My media" \
-F "alt=My media" \
-F "caption=My media" \
-F "file=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Media has been uploaded.",
"media": {
"_id": "676effbea57ba0808a0da080",
"title": "My media"",
"alt": "My media"",
"caption": "My media"",
"type": "public",
"file": {
"name": "IMG_1130.jpg",
"path": "http://localhost:3000/uploads/public/media/61eb3c1076a3.jpg",
"size": 2568669,
"type": "image/jpeg"
},
"userId": "676db209053557d2d7b23de5",
"createdAt": "12/28/2024, 12:27:58 AM",
"updatedAt": "12/28/2024, 12:27:58 AM"
}
}
POST /media/fetch
Description: Fetch all my uploaded media.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
page |
Integer |
Required |
The page number of results to be fetched. |
Example Request
curl -X POST http://localhost:3000/media/fetch \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "page=1"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"media": [
{
"_id": "676effbea57ba0808a0da080",
"title": "My media"",
"alt": "My media"",
"caption": "My media"",
"type": "public",
"file": {
"name": "IMG_1130.jpg",
"path": "http://localhost:3000/uploads/public/media/61eb3c1076a3.jpg",
"size": 2568669,
"type": "image/jpeg"
},
"userId": "676db209053557d2d7b23de5",
"createdAt": "12/28/2024, 12:27:58 AM",
"updatedAt": "12/28/2024, 12:27:58 AM"
}
]
}
POST /media/fetch-single
Description: Fetch details of my single media file.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of media file. |
Example Request
curl -X POST http://localhost:3000/media/fetch-single \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-d "_id=676effbea57ba0808a0da080"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Data has been fetched.",
"media": {
"_id": "676effbea57ba0808a0da080",
"title": "My media"",
"alt": "My media"",
"caption": "My media"",
"type": "public",
"file": {
"name": "IMG_1130.jpg",
"path": "http://localhost:3000/uploads/public/media/61eb3c1076a3.jpg",
"size": 2568669,
"type": "image/jpeg"
},
"createdAt": "12/28/2024, 12:27:58 AM",
"updatedAt": "12/28/2024, 12:27:58 AM"
}
}
POST /media/update
Description: Update already uploaded media file.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Content-Type |
Required |
multipart/form-data |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of media file to be updated. |
title |
string |
Optional |
Title of media. |
alt |
string |
Optional |
Alt attribute for images. |
caption |
string |
Optional |
Caption of media. |
type |
string |
Required |
Is the media "public" or "private". |
file |
file |
Optional |
Media file. |
Example Request
curl -X POST http://localhost:3000/media/update \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-H "Content-Type: multipart/form-data" \
-F "_id=676effbea57ba0808a0da080"
-F "title=My media" \
-F "alt=My media" \
-F "caption=My media" \
-F "type=public" \
-F "file=@path/to/your/file.jpg"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Media has been updated."
}
POST /media/delete
Description: Delete media file.
Headers
Name |
Required |
Description |
Authorization |
Required |
Bearer {token} |
Arguments
Name |
Type |
Required |
Description |
_id |
string |
Required |
ID of media file to be deleted. |
Example Request
curl -X POST http://localhost:3000/media/delete \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiI2Nz" \
-F "_id=676effbea57ba0808a0da080"
Status Codes
- 200 OK: Request successful.
Response
{
"status": "success",
"message": "Media has been removed."
}