"passport-facebook-token": "^3.3.0",
  
    
      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 characters
    
  
  
    
  | =CONCAT(CONCAT(CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122)))&CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122))), CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122)))&CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122)))), CONCAT(CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122)))&CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122))), CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122)))&CHOOSE(RANDBETWEEN(1,2),CHAR(RANDBETWEEN(65,90)),CHAR(RANDBETWEEN(97,122))))) | 
  
    
      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 characters
    
  
  
    
  | var express = require('express'); | |
| var app = express(); | |
| var url = "https://username.jsreportonline.net/"; | |
| var client = require("jsreport-client")(url, "[email protected]", "password"); | |
| app.get('/', function (req, res) { | |
| res.send('Go to /report or /base64'); | 
  
    
      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 characters
    
  
  
    
  | npm install --save passport-facebook-token | |
| Then add this entry in providers.json: | |
| "facebook-mobile" : { | |
| "provider": "facebook-token", | |
| "module": "passport-facebook-token", | |
| "strategy": "FacebookTokenStrategy", | |
| "clientID": "XXXXXXX", | |
| "clientSecret": "XXXXXXX", | |
| "callbackPath": "/auth/facebook-token/callback", | 
  
    
      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 characters
    
  
  
    
  | // common/models/model.js | |
| app.models.Model.beforeRemote('create', function(ctx, modelInstance, next) { | |
| ctx.args.data.userId = ctx.req.accessToken.userId; | |
| next(); | |
| }); | 
  
    
      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 characters
    
  
  
    
  | // server/boot/authentication.js | |
| server.middleware('auth', loopback.token({ | |
| model: server.models.accessToken, | |
| currentUserLiteral: 'me' | |
| })); | 
  
    
      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 characters
    
  
  
    
  | // App/Services/Normalizer.js | |
| import { Schema, arrayOf, normalize } from 'normalizr' | |
| import { camelizeKeys } from 'humps' | |
| const normalizer = (data, schema) => { | |
| const camelizedJson = camelizeKeys(data) | |
| return normalize(camelizedJson, schema) | |
| } | 
  
    
      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 characters
    
  
  
    
  | module.exports = function(Place) { | |
| Place.nearby = function(here,cb){ | |
| Place.find({where: {location: {near: here}}, limit:3}, function(err, nearbyPlaces) { | |
| cb(null, nearbyPlaces); | |
| }); | |
| }; | |
| Place.remoteMethod('nearby', { | |
| accepts: [ | |
| {arg: 'here', type: 'GeoPoint', required: true, description: 'geo location (lat & lng)'} | 
  
    
      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 characters
    
  
  
    
  | var FILTERED_PROPERTIES = ['createdAt', 'updatedAt']; | |
| Model.observe('before save', function filterProperties(ctx, next) { | |
| if (ctx.options && ctx.options.skipPropertyFilter) return next(); | |
| if (ctx.instance) { | |
| FILTERED_PROPERTIES.forEach(function(p) { ctx.instance.unsetAttribute(p); }); | |
| } else { | |
| FILTERED_PROPERTIES.forEach(function(p) { delete ctx.data[p]; }); | |
| } | |
| next(); | |
| }); |