Last active
October 7, 2021 18:46
-
-
Save eldarc/e3e7176370e98bc2c9d30592a436db29 to your computer and use it in GitHub Desktop.
Revisions
-
eldarc revised this gist
Jul 7, 2018 . 1 changed file with 1 addition and 1 deletion.There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,6 +1,6 @@ const cors = require('cors') // Set `useWhitelist` to `false` if you want to accept all requests. const config = { useWhitelist: true } -
eldarc revised this gist
Jul 7, 2018 . 1 changed file with 1 addition and 3 deletions.There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -1,5 +1,4 @@ const cors = require('cors') // Set `useWhitelist` to `false` if you wanted to accept all requests. const config = { @@ -40,8 +39,7 @@ function _geolocation(req, res) { region: req.headers["x-appengine-region"], city: req.headers["x-appengine-city"], cityLatLong: req.headers["x-appengine-citylatlong"], userIP: req.headers["x-appengine-user-ip"] } res.json(data) -
eldarc created this gist
Jul 7, 2018 .There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters. Learn more about bidirectional Unicode charactersOriginal file line number Diff line number Diff line change @@ -0,0 +1,57 @@ const cors = require('cors') const cityTimezones = require('city-timezones'); // Set `useWhitelist` to `false` if you wanted to accept all requests. const config = { useWhitelist: true } // Define from which origins requests are allowed. const whitelist = [ // 'https://fiddle.jshell.net', 'https://ministryofprogramming.com', 'https://mop.ba' ]; // Parse the whitelist and decide if the request is allowed. const corsOptionsWhitelist = function (req, callback) { var corsOptions; if (whitelist.indexOf(req.header('Origin')) !== -1) { corsOptions = { origin: true } } else { corsOptions = { origin: false } } callback(null, corsOptions); } // Options when not using the whitelist. const corsOptions = { origin: true } // Handle the response within this function. It can be extended to include more data. function _geolocation(req, res) { // res.header('Cache-Control','no-cache'); const data = { country: req.headers["x-appengine-country"], region: req.headers["x-appengine-region"], city: req.headers["x-appengine-city"], cityLatLong: req.headers["x-appengine-citylatlong"], userIP: req.headers["x-appengine-user-ip"], cityData: cityTimezones.lookupViaCity(req.headers["x-appengine-city"]) } res.json(data) }; // Export the cloud function. exports.geolocation = (req, res) => { const corsHandler = config.useWhitelist ? cors(corsOptionsWhitelist) : cors(corsOptions); return corsHandler(req, res, function() { return _geolocation(req, res); }); };