iamcmnut
iamcmnut

Reputation: 479

How Firebase Cloud functions handle HTTP post method?

I have created Firebase Cloud Functions app, I created function with https.onRequest. and get data with req.body but there is not data there.

Can Firebase Cloud Functions can handle HTTP POST method?

This is my sample code:-

var functions = require('firebase-functions');

exports.testPost = functions.https.onRequest((req, res) => {
    console.log(req.body);
});

I tested by postman with POST method but didn't show result in Firebase log.

Upvotes: 37

Views: 48045

Answers (4)

SerzN1
SerzN1

Reputation: 1894

Firebase functions support GET, POST, PUT, DELETE, and OPTIONS method, and you can check what kind of methods that trigger your function.

// Check for POST request
if(request.method !== "POST"){
 res.status(400).send('Please send a POST request');
 return;
}

Then to get data from POST request (for example JSON type) will be in the header of your request.

const postData = request.body;
// for instance
const format = req.body.format;
// query string params
let format = req.query.format;

Upvotes: 4

nukalov
nukalov

Reputation: 1357

Functions built on Firebase can also use Express.js routers for handling GET/POST/PUT/DELETE, etc... is fully supported by Google, and is the recommended way to implement these types of functions.

More documentation can be found here:

https://firebase.google.com/docs/functions/http-events

Here's a working example built on Node.js

const functions = require('firebase-functions');
const express = require('express');
const cors = require('cors');
const app = express();

// Automatically allow cross-origin requests
app.use(cors({ origin: true }));

app.get('/hello', (req, res) => {
  res.end("Received GET request!");  
});

app.post('/hello', (req, res) => {
  res.end("Received POST request!");  
});

// Expose Express API as a single Cloud Function:
exports.widgets = functions.https.onRequest(app);

Then, run firebase deploy, and that should compile your code and create the new "widgets" function. Note: You can rename widgets to anything you want. Ultimately, it will generate a URL for calling the function.

Upvotes: 47

Bryan Jyh Herng Chong
Bryan Jyh Herng Chong

Reputation: 630

I am planning to do the same thing. What I reckon the approach should be is to check the request.method in the function body. A probable approach can be:

if (request.method != "POST") {
     respond.status(400).send("I am not happy");
     return;
}

// handle the post request

Here's some reference to the details regarding what the request object holds: https://firebase.google.com/docs/functions/http-events

Upvotes: 14

T M
T M

Reputation: 530

Maybe your project hasn't been setup to communicate with your firebase database. Try the following from your terminal:

npm install -g firebase-tools

Then inside your project folder, run the following and login using your credentials

firebase login

Then

firebase init functions

This will create a folder with index.js, package.json and node_modules

If you are using Postman correctly the rest of your code should work.

Upvotes: -17

Related Questions