當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript https.onRequest方法代碼示例

本文整理匯總了TypeScript中firebase-functions.https.onRequest方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript https.onRequest方法的具體用法?TypeScript https.onRequest怎麽用?TypeScript https.onRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在firebase-functions.https的用法示例。


在下文中一共展示了https.onRequest方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: ingredientList

import * as functions from 'firebase-functions';
import { DialogflowApp } from 'actions-on-google';

// // Start writing Firebase Functions
// // https://firebase.google.com/docs/functions/typescript
//
export const helloWorld = functions.https.onRequest((request, response) => {
    console.log('Request headers: ' + JSON.stringify(request.headers));
    console.log('Request body: ' + JSON.stringify(request.body));


    let dialogApp = new DialogflowApp({ request, response });

    function ingredientList(app: DialogflowApp) {
        app.tell(`I see you want to know about ${app.getArgument('recipe_name')}`);
    }

    let actionMap = new Map();
    actionMap.set('IngredientList', ingredientList);

    dialogApp.handleRequest(actionMap);
});
開發者ID:wjones0,項目名稱:recipe,代碼行數:22,代碼來源:index.ts

示例2: addEvent

    });
  });
}

exports.addEventToCalendar = functions.https.onRequest((request, response) => {
  const eventData = {
    eventName: request.body.eventName,
    description: request.body.description,
    startTime: request.body.startTime,
    endTime: request.body.endTime
  };
  const oAuth2Client = new OAuth2(
    googleCredentials.web.client_id,
    googleCredentials.web.client_secret,
    googleCredentials.web.redirect_uris[0]
  );

  oAuth2Client.setCredentials({
    refresh_token: googleCredentials.refresh_token
  });

  addEvent(eventData, oAuth2Client).then(data => {
    response.status(200).send(data);
    return;
  }).catch(err => {
    console.error('Error adding event: ' + err.message);
    response.status(500).send(ERROR_RESPONSE);
    return;
  });
});
開發者ID:Meistercoach83,項目名稱:sfw,代碼行數:30,代碼來源:add-calendar-event.ts

示例3: require

const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./app/main');

const engine = ngExpressEngine({
  bootstrap: AppServerModuleNgFactory,
  providers: [
    provideModuleMap(LAZY_MODULE_MAP)
  ]
});

const document: string = fs.readFileSync(__dirname + '/app/index.html', 'utf8').toString();

const app = express();
app.get('**', (req, res) => {
  const url: string = req.path;
  engine(url, {
    req,
    res,
    url,
    document,
    bootstrap: AppServerModuleNgFactory,
    providers: [
      provideModuleMap(LAZY_MODULE_MAP)
    ]
  }, (err?: Error, html: string = 'oops') => {
    res.set('Cache-Control', 'public, max-age=3600, s-maxage=43200');
    res.send((err) ? err.message : html);
  });
});

export const ssr = functions.https.onRequest(app);
開發者ID:MichaelSolati,項目名稱:ng-portfolio,代碼行數:30,代碼來源:ssr.ts

示例4: getUsersDQ

import * as functions from 'firebase-functions';
import * as admin from "firebase-admin";
import { getUsersDQ } from "../getUsers";
import { getDaysCurrent } from "../util/getDaysCurrent";
import { getPeriodicityQuestion } from "./getPeriodicityQuestion";

export const activeQuestions = functions.https.onRequest((req, response) => {
  let isFlag = false;
  getUsersDQ().then((DQs:Array<any>) => {
    if(isFlag)
      return
    isFlag = true;
    for (const dq of DQs) {
      if (!dq)
        return;
      if(dq.answers) {
        for (let i = 0; i < dq.answers.length; i++)
          if(getDaysCurrent(dq,i) >= getPeriodicityQuestion(dq,i)) 
            admin.database().ref(`/${dq['uidCT']}/users/${dq['id']}/questions/${i}`).update({isActive: true})
      }
    }
    response.send("Questoes ativadas!");
  }).catch(() => console.log('Error para ativar as questĂľes'));
});
開發者ID:dekonunes,項目名稱:ConneCT-App,代碼行數:24,代碼來源:index.ts

示例5: setGithubStatus

export const payloadGithubStatus = https.onRequest(async (request, response) => {
  const authToken = request.header('auth-token');
  const commitSha = request.header('commit-sha');
  const packageName = request.header('package-name');
  const packageSize = parseFloat(request.header('package-full-size'));
  const packageDiff = parseFloat(request.header('package-size-diff'));

  if (!verifyToken(authToken)) {
    return response.status(403).json({message: 'Auth token is not valid'});
  }

  if (!commitSha) {
    return response.status(404).json({message: 'No commit has been specified'});
  }

  if (isNaN(packageDiff)) {
    return response.status(400).json({message: 'No valid package difference has been specified.'});
  }

  if (isNaN(packageSize)) {
    return response.status(400).json({message: 'No full size of the package has been specified.'});
  }

  if (!packageName) {
    return response.status(400).json({message: 'No package name has been specified.'});
  }

  if (packageDiff === 0) {
    return response.status(400).json({message: `The difference equals zero. Status won't be set.`});
  }

  // Better message about the diff that shows whether the payload increased or decreased.
  const diffMessage = packageDiff < 0 ? 'decrease' : 'increase';
  const diffFormatted = Math.abs(packageDiff).toFixed(2);

  await setGithubStatus(commitSha, {
    result: true,
    name: `${capitalizeFirstLetter(packageName)} Payload Size`,
    description: `${packageSize}kb / ${diffFormatted}kb ${diffMessage} (ES2015 bundle)`
  });

  response.json({message: 'Payload Github status successfully set.'});
});
開發者ID:attilacsanyi,項目名稱:material2,代碼行數:43,代碼來源:payload-github-status.ts

示例6: cors

export const linkedin = functions.https.onRequest((req, res) => {
  cors(req, res, () => {
    admin.database().ref('linkedin').once('value', (snapshot: admin.database.DataSnapshot) => {
      if (snapshot.exists() && snapshot.val().expires > new Date().getTime()) {
        return res.status(400).send('Functions only update data that\'s older than 24 hours.');
      } else {
        const tomorrow: number = new Date().getTime() + 86400000;
        admin.storage().bucket().file('linkedin.html', {})
          .getSignedUrl({ action: 'read', expires: tomorrow })
          .then((url: string[]) => {
            if (url.length !== 1) return res.status(400).send('No profile found');
            httpRequest({ method: 'GET', url: url[0] }, (error: any, response: any, body: string) => {
              if (error) { return res.status(error.code).send(error.message); }
              inScrape.getProfile(body)
                .then((profile) => {
                  const regex: RegExp = RegExp('<img.*?alt="' + profile.name + '".*?src=".\/linkedin_files\/(.*?)"', 'g');
                  const images: string[] = regex.exec(body);
                  if (Array.isArray(images) && images.length > 0) { profile.photo = 'https://media.licdn.com/mpr/mpr/' + images[1]; }
                  if (profile.experience && Array.isArray(profile.experience)) { profile.experience = orderExperience(profile.experience); }
                  const result = {
                    results: profile,
                    expires: tomorrow
                  };
                  admin.database().ref('linkedin').set(result).then(() => res.send(JSON.stringify(result.results)));
                }).catch(err => res.status(400).send(err));
            });
          })
          .catch(error => res.status(400).send(error));
      }
    });
  });
});
開發者ID:MichaelSolati,項目名稱:ng-portfolio,代碼行數:32,代碼來源:linkedin.ts

示例7: require

import * as functions from 'firebase-functions';
const next = require('next');

const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev, conf: { distDir: 'next' } });
const handle = app.getRequestHandler();

export const nextApp = functions.https.onRequest((req, res) => {
  console.log('File: ' + req.originalUrl);
  return app.prepare().then(() => handle(req, res));
});
開發者ID:CrowdArt,項目名稱:next.js,代碼行數:11,代碼來源:next.ts

示例8: pub

export const questionBotHandler = functions.https.onRequest(
  async (req, res) => {
    const body = req.body;

    // Slash Command
    if (body.command === '/ask') {
      await pub(body);
      res
        .status(200)
        .json({ text: BOT_RESPONSE, attachments: { text: BOT_RESPONSE } });
      return;
    }

    // Bot Question
    const { type, subtype } = body.event;
    const { thread_ts, text } = body.event.message || body.event;

    // Attempt to filter invalid questions
    const okType = type === 'message';
    const okUrl =
      thread_ts ||
      (text && text.includes('fireship.io')) ||
      subtype === 'message_deleted';

    // If OK, publish data
    if (okType && okUrl) {
      await pub(body);
      res.sendStatus(200);
    }
  }
);
開發者ID:janjachacz,項目名稱:fireship.io,代碼行數:31,代碼來源:slack.ts

示例9: getOpenPullRequestsWithMergeableState

import {https} from 'firebase-functions';
import {getOpenPullRequestsWithMergeableState} from './github/github-graphql-queries';

/**
 * Firebase HTTP trigger that responds with a list of Pull Requests that have merge conflicts.
 */
export const pullRequestsWithConflicts = https.onRequest(async (_request, response) => {
  const pullRequests = (await getOpenPullRequestsWithMergeableState())
    .filter(pullRequest => pullRequest.mergeable === 'CONFLICTING');

  response.status(200).json(pullRequests);
});

開發者ID:GuzmanPI,項目名稱:material2,代碼行數:12,代碼來源:pull-requests-with-conflicts.ts

示例10: corsOptions

import * as functions from 'firebase-functions'
import * as admin from 'firebase-admin';

import * as corsOptions from 'cors';

import serviceAccount from "./etc/service-key";
import { Forum } from './model/forum/forum';

const cors = corsOptions({ origin: true });

const app = admin.initializeApp({
  credential: admin.credential.cert(serviceAccount),
  databaseURL: "https://" + serviceAccount.project_id + ".firebaseio.com"
});
const db = app.database();

exports.postApi = functions.https.onRequest((req, res) => {

  cors(req, res, () => {
    console.log("postApi() begins!");
    let forum = new Forum(db.ref('/'));
    //res.send( JSON.stringify( req.body ) + JSON.stringify( req.params ) + JSON.stringify( req.query ) );
    forum.postApi(req.body)
      .then(x => res.send({code: 0, data: x}))
      .catch(e => res.send({ code: e.message, message: forum.getLastErrorMessage }));
    console.log("Send");
  });

});

開發者ID:kurama4u,項目名稱:demo-firebase-cms,代碼行數:29,代碼來源:index.ts


注:本文中的firebase-functions.https.onRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。