Serverless Function to backend
Answered
Felipe posted this in #help-forum
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Hi everyone! I'm doing a project for school in which I'm using NextJS to create an app. I have some api calls on a backend, and I saw this Vercel tutorial https://www.youtube.com/watch?v=yLMODEUPJdU on how to setup a Serverless Function. But I'm a bit lost on how to actually run it. Can anyone help me? Thanks!
This is my current file structure for the backend. I ran
This is my current file structure for the backend. I ran
vercel
on the terminal and created a project on Vercel linked to it.data:image/s3,"s3://crabby-images/4cdf2/4cdf29e5a3122a0cb012f842d160a2e2fb12cb30" alt="Image"
55 Replies
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
I already have the project deployed, but when I go on to test the api using ThunderClient, it returns this
data:image/s3,"s3://crabby-images/afc53/afc5321505d9657cc0abd83f11a605aa54a48800" alt="Image"
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
data:image/s3,"s3://crabby-images/7de53/7de53b4d58f576f0c574cfd7ecf906ce7e7f1e5d" alt="Image"
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe Hi everyone! I'm doing a project for school in which I'm using NextJS to create an app. I have some api calls on a backend, and I saw this Vercel tutorial https://www.youtube.com/watch?v=yLMODEUPJdU on how to setup a Serverless Function. But I'm a bit lost on how to actually run it. Can anyone help me? Thanks!
This is my current file structure for the backend. I ran `vercel` on the terminal and created a project on Vercel linked to it.
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
For me, I needed to add all my files inside
api
folder, with this addition in next config: "rewrites": [
{
"source": "/(.*)",
"destination": "/api"
}
],
and export app in
api/index.ts
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe Hi everyone! I'm doing a project for school in which I'm using NextJS to create an app. I have some api calls on a backend, and I saw this Vercel tutorial https://www.youtube.com/watch?v=yLMODEUPJdU on how to setup a Serverless Function. But I'm a bit lost on how to actually run it. Can anyone help me? Thanks!
This is my current file structure for the backend. I ran `vercel` on the terminal and created a project on Vercel linked to it.
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
can you share your vercel.json
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
sure!
{
"version": 2,
"builds": [
{
"src": "server.js",
"use": "@vercel/node"
}
],
"routes": [
{
"src": "/api/(.*)",
"dest": "server.js"
}
]
}
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe
{
"version": 2,
"builds": [
{
"src": "server.js",
"use": "@vercel/node"
}
],
"routes": [
{
"src": "/api/(.*)",
"dest": "server.js"
}
]
}
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
could you share the server.js too?
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Okay, I renamed the folder to api
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
i was thinking, you're using basic project, but you're using server.js
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe Okay, I renamed the folder to api
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
no it isn't needed, change it back to the routes
share any one of the routes too
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe
{
"version": 2,
"builds": [
{
"src": "server.js",
"use": "@vercel/node"
}
],
"routes": [
{
"src": "/api/(.*)",
"dest": "server.js"
}
]
}
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
if you're using
@vercel/node
, then renaming to api is not needed.It didn't really work well for me last I tried, but you can try if it works for you
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
@Black carpenter ant *i was thinking, you're using basic project, but you're using server.js*
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
I don't know If I'm doing it right, my professor said we could host it on vercel. Maybe I can't?
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe I don't know If I'm doing it right, my professor said we could host it on vercel. Maybe I can't?
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
what it does?
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
you can host on vercel
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
if it's only using simple things, http methods and all, you can host it on vercel!
if you aren't familiar with vercel functions, you can use express.js
https://vercel.com/guides/using-express-with-vercel
https://vercel.com/guides/using-express-with-vercel
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
@Black carpenter ant what it does?
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
it uses gemini to send product recommendations to a page, based on the user preferences
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe it uses gemini to send product recommendations to a page, based on the user preferences
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
alright, it looks like you haven't shared the server.js yet
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
@Black carpenter ant if you aren't familiar with vercel functions, you can use express.js
https://vercel.com/guides/using-express-with-vercel
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
Thats what I was guiding him with, when I told to rename to
api
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Here it is!
require('dotenv').config();
const express = require('express');
const cors = require('cors');
const recommendationsRouter = require('./routes/recommendations');
const scrapeRoute = require('./routes/scrape');
const app = express();
const PORT = process.env.PORT || 5000;
// Middleware
app.use(cors({
origin: ['http://localhost:3000', 'https://beauty-finder.vercel.app']
}));
app.use(express.json());
// Routes
app.use('/api/recommendations', recommendationsRouter);
app.use('/api', scrapeRoute);
// Error handling
app.use((err, req, res, next) => {
console.error('Server Error:', err);
res.status(500).json({
error: 'Internal server error',
message: process.env.NODE_ENV === 'production' ? 'Something went wrong' : err.message
});
});
module.exports = app;
// Start server if not in production
if (process.env.NODE_ENV !== 'production') {
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
console.log(`- Recommendations API: http://localhost:${PORT}/api/recommendations`);
console.log(`- Scraping API: http://localhost:${PORT}/api/scrape`);
});
}
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
This is a express app only
You are doing everything right, just:
- create a folder
- put your js files in it, like
- rename
It should work then
- create a folder
api
- put your js files in it, like
server.js
and routes- rename
server.js
, where you've app
setup, to index.js
It should work then
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
@Felipe javascript
require('dotenv').config();
const express = require('express');
const cors = require('cors');
const recommendationsRouter = require('./routes/recommendations');
const scrapeRoute = require('./routes/scrape');
const app = express();
const PORT = process.env.PORT || 5000;
// Middleware
app.use(cors({
origin: ['http://localhost:3000', 'https://beauty-finder.vercel.app']
}));
app.use(express.json());
// Routes
app.use('/api/recommendations', recommendationsRouter);
app.use('/api', scrapeRoute);
// Error handling
app.use((err, req, res, next) => {
console.error('Server Error:', err);
res.status(500).json({
error: 'Internal server error',
message: process.env.NODE_ENV === 'production' ? 'Something went wrong' : err.message
});
});
module.exports = app;
// Start server if not in production
if (process.env.NODE_ENV !== 'production') {
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
console.log(`- Recommendations API: http://localhost:${PORT}/api/recommendations`);
console.log(`- Scraping API: http://localhost:${PORT}/api/scrape`);
});
}
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Black carpenter ant
This should surely help
https://vercel.com/guides/using-express-with-vercel#5.-configure-your-project-for-vercel
https://vercel.com/guides/using-express-with-vercel#5.-configure-your-project-for-vercel
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Okay, I'll try it!
Thanks guys! I'll send another message if I have other issues!! Thanks a lot!
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
@Anay-208 | Ping on replies You are doing everything right, just:
- create a folder `api`
- put your js files in it, like `server.js` and routes
- rename `server.js`, where you've `app` setup, to `index.js`
It should work then
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
I did this, but I'm still getting Not found. This is my vercell projects tab. What may be the issue now?
data:image/s3,"s3://crabby-images/bef36/bef36756b3a08d8f7c781c74c6bd03f1c755a584" alt="Image"
data:image/s3,"s3://crabby-images/05e6d/05e6d7de64bb9ac4298ed558edd81099ebf07aa0" alt="Image"
This is the repo, with the api folder and renaming, as suggested @Anay-208 | Ping on replies
data:image/s3,"s3://crabby-images/442d1/442d17c6c093ee8cc19aee6d9f5888dc2acee039" alt="Image"
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
Can you share your index.js and vercel.json once again?
@Felipe
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Yes!
index.js
require('dotenv').config();
const express = require('express');
const cors = require('cors');
const recommendationsRouter = require('./routes/recommendations');
const scrapeRoute = require('./routes/scrape');
const app = express();
const PORT = process.env.PORT || 5000;
// Middleware
app.use(cors({
origin: ['http://localhost:3000', 'https://beauty-finder.vercel.app']
}));
app.use(express.json());
// Routes
app.use('/api/recommendations', recommendationsRouter);
app.use('/api', scrapeRoute);
// Error handling
app.use((err, req, res, next) => {
console.error('Server Error:', err);
res.status(500).json({
error: 'Internal server error',
message: process.env.NODE_ENV === 'production' ? 'Something went wrong' : err.message
});
});
module.exports = app;
// Start server if not in production
if (process.env.NODE_ENV !== 'production') {
app.listen(PORT, () => {
console.log(`Server running on port ${PORT}`);
console.log(`- Recommendations API: http://localhost:${PORT}/api/recommendations`);
console.log(`- Scraping API: http://localhost:${PORT}/api/scrape`);
});
}
vercel.json
{
"version": 2,
"builds": [
{
"src": "api/index.js",
"use": "@vercel/node"
}
],
"routes": [
{
"src": "/api/(.*)",
"dest": "api/index.js"
}
]
}
I updated the path on vercel.json, and now the error is @Anay-208 | Ping on replies
data:image/s3,"s3://crabby-images/d05d8/d05d89a0d812a49720b1ccc21d8f73e1472f872c" alt="Image"
data:image/s3,"s3://crabby-images/edf74/edf74044374c18540ac9d020392fbf5e0bda38c9" alt="Image"
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
I'm still getting the same error after removing builds @Anay-208 | Ping on replies
in src, you've
/api/
at the start instead of /
if that still doesn't works, check vercel logs
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Okay
Should my .env be inside api/ ?
I'm getting
APIFY_TOKEN is not defined. Please set it in your environment
@Anay-208 | Ping on replies . It's defined on .envdata:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
Have you added environment variables in vercel?
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
I have
@Anay-208 | Ping on replies
data:image/s3,"s3://crabby-images/9bb54/9bb54c7a9f71e554bd1995fd9686a2087e49f830" alt="Image"
data:image/s3,"s3://crabby-images/bc74d/bc74d9e5ada415b45224aaf02cbc64979050cd76" alt="Avatar"
try redeploying
Answer
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
Okay
data:image/s3,"s3://crabby-images/32e2d/32e2d725429e42c12a21b44a742e6bc90b3938fd" alt="Avatar"
FelipeOP
It worked! Thanks!