cache as ES6
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
|
||||
jasmine.DEFAULT_TIMEOUT_INTERVAL = 2000;
|
||||
|
||||
var cache = require('../src/cache');
|
||||
var cache = require('../src/cache').default;
|
||||
var DatabaseAdapter = require('../src/DatabaseAdapter');
|
||||
var express = require('express');
|
||||
var facebook = require('../src/oauth/facebook');
|
||||
|
||||
@@ -2,7 +2,7 @@ var deepcopy = require('deepcopy');
|
||||
var Parse = require('parse/node').Parse;
|
||||
var RestQuery = require('./RestQuery');
|
||||
|
||||
var cache = require('./cache');
|
||||
import cache from './cache';
|
||||
|
||||
// An Auth object tells you who is requesting something and whether
|
||||
// the master key was used.
|
||||
|
||||
@@ -2,10 +2,12 @@
|
||||
// configured.
|
||||
// mount is the URL for the root of the API; includes http, domain, etc.
|
||||
|
||||
import cache from './cache';
|
||||
|
||||
export class Config {
|
||||
|
||||
constructor(applicationId, mount) {
|
||||
var cache = require('./cache');
|
||||
|
||||
var DatabaseAdapter = require('./DatabaseAdapter');
|
||||
|
||||
var cacheInfo = cache.apps[applicationId];
|
||||
|
||||
@@ -13,11 +13,11 @@
|
||||
// * This list is incomplete and the database process is not fully modularized.
|
||||
//
|
||||
// Default is ExportAdapter, which uses mongo.
|
||||
import cache from './cache';
|
||||
|
||||
var ExportAdapter = require('./ExportAdapter');
|
||||
|
||||
var adapter = ExportAdapter;
|
||||
var cache = require('./cache');
|
||||
var dbConnections = {};
|
||||
var databaseURI = 'mongodb://localhost:27017/parse';
|
||||
var appDatabaseURIs = {};
|
||||
|
||||
@@ -2,10 +2,10 @@
|
||||
// that writes to the database.
|
||||
// This could be either a "create" or an "update".
|
||||
|
||||
import cache from './cache';
|
||||
var deepcopy = require('deepcopy');
|
||||
|
||||
var Auth = require('./Auth');
|
||||
var cache = require('./cache');
|
||||
var Config = require('./Config');
|
||||
var cryptoUtils = require('./cryptoUtils');
|
||||
var passwordCrypto = require('./password');
|
||||
@@ -114,7 +114,7 @@ RestWrite.prototype.validateSchema = function() {
|
||||
// Any change leads to our data being mutated.
|
||||
RestWrite.prototype.runBeforeTrigger = function() {
|
||||
// Avoid doing any setup for triggers if there is no 'beforeSave' trigger for this class.
|
||||
if (!triggers.triggerExists(this.className, triggers.Types.beforeSave)) {
|
||||
if (!triggers.triggerExists(this.className, triggers.Types.beforeSave, this.config.applicationId)) {
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
|
||||
40
src/cache.js
40
src/cache.js
@@ -1,45 +1,45 @@
|
||||
var apps = {};
|
||||
var stats = {};
|
||||
var isLoaded = false;
|
||||
var users = {};
|
||||
export var apps = {};
|
||||
export var stats = {};
|
||||
export var isLoaded = false;
|
||||
export var users = {};
|
||||
|
||||
function getApp(app, callback) {
|
||||
export function getApp(app, callback) {
|
||||
if (apps[app]) return callback(true, apps[app]);
|
||||
return callback(false);
|
||||
}
|
||||
|
||||
function updateStat(key, value) {
|
||||
export function updateStat(key, value) {
|
||||
stats[key] = value;
|
||||
}
|
||||
|
||||
function getUser(sessionToken) {
|
||||
export function getUser(sessionToken) {
|
||||
if (users[sessionToken]) return users[sessionToken];
|
||||
return undefined;
|
||||
}
|
||||
|
||||
function setUser(sessionToken, userObject) {
|
||||
export function setUser(sessionToken, userObject) {
|
||||
users[sessionToken] = userObject;
|
||||
}
|
||||
|
||||
function clearUser(sessionToken) {
|
||||
export function clearUser(sessionToken) {
|
||||
delete users[sessionToken];
|
||||
}
|
||||
|
||||
//So far used only in tests
|
||||
function clearCache() {
|
||||
export function clearCache() {
|
||||
apps = {};
|
||||
stats = {};
|
||||
users = {};
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
apps: apps,
|
||||
stats: stats,
|
||||
isLoaded: isLoaded,
|
||||
getApp: getApp,
|
||||
updateStat: updateStat,
|
||||
clearUser: clearUser,
|
||||
getUser: getUser,
|
||||
setUser: setUser,
|
||||
clearCache: clearCache,
|
||||
export default {
|
||||
apps,
|
||||
stats,
|
||||
isLoaded,
|
||||
getApp,
|
||||
updateStat,
|
||||
clearUser,
|
||||
getUser,
|
||||
setUser,
|
||||
clearCache,
|
||||
};
|
||||
|
||||
@@ -4,13 +4,13 @@ import 'babel-polyfill';
|
||||
|
||||
var batch = require('./batch'),
|
||||
bodyParser = require('body-parser'),
|
||||
cache = require('./cache'),
|
||||
DatabaseAdapter = require('./DatabaseAdapter'),
|
||||
express = require('express'),
|
||||
middlewares = require('./middlewares'),
|
||||
multer = require('multer'),
|
||||
Parse = require('parse/node').Parse;
|
||||
|
||||
import cache from './cache';
|
||||
import PromiseRouter from './PromiseRouter';
|
||||
import { GridStoreAdapter } from './Adapters/Files/GridStoreAdapter';
|
||||
import { S3Adapter } from './Adapters/Files/S3Adapter';
|
||||
|
||||
@@ -1,7 +1,8 @@
|
||||
import cache from './cache';
|
||||
|
||||
var Parse = require('parse/node').Parse;
|
||||
|
||||
var auth = require('./Auth');
|
||||
var cache = require('./cache');
|
||||
var Config = require('./Config');
|
||||
|
||||
// Checks that the request is authorized for this app and checks user
|
||||
|
||||
@@ -8,8 +8,8 @@
|
||||
// things.
|
||||
|
||||
var Parse = require('parse/node').Parse;
|
||||
import cache from './cache';
|
||||
|
||||
var cache = require('./cache');
|
||||
var RestQuery = require('./RestQuery');
|
||||
var RestWrite = require('./RestWrite');
|
||||
var triggers = require('./triggers');
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
// testing-routes.js
|
||||
import cache from './cache';
|
||||
|
||||
var express = require('express'),
|
||||
cache = require('./cache'),
|
||||
middlewares = require('./middlewares'),
|
||||
cryptoUtils = require('./cryptoUtils');
|
||||
|
||||
|
||||
@@ -1,49 +1,56 @@
|
||||
// triggers.js
|
||||
var Parse = require('parse/node').Parse,
|
||||
cache = require('./cache');
|
||||
import Parse from 'parse/node';
|
||||
import cache from './cache';
|
||||
|
||||
var Types = {
|
||||
export const Types = {
|
||||
beforeSave: 'beforeSave',
|
||||
afterSave: 'afterSave',
|
||||
beforeDelete: 'beforeDelete',
|
||||
afterDelete: 'afterDelete'
|
||||
};
|
||||
|
||||
var BaseStore = function() {
|
||||
this.Functions = {}
|
||||
this.Validators = {}
|
||||
this.Triggers = Object.keys(Types).reduce(function(base, key){
|
||||
const baseStore = function() {
|
||||
|
||||
let Validators = {};
|
||||
let Functions = {};
|
||||
let Triggers = Object.keys(Types).reduce(function(base, key){
|
||||
base[key] = {};
|
||||
return base;
|
||||
}, {});
|
||||
|
||||
return Object.freeze({
|
||||
Functions,
|
||||
Validators,
|
||||
Triggers
|
||||
});
|
||||
}
|
||||
|
||||
var _triggerStore = {};
|
||||
const _triggerStore = {};
|
||||
|
||||
function addFunction(functionName, handler, validationHandler, applicationId) {
|
||||
export function addFunction(functionName, handler, validationHandler, applicationId) {
|
||||
applicationId = applicationId || Parse.applicationId;
|
||||
_triggerStore[applicationId] = _triggerStore[applicationId] || new BaseStore();
|
||||
_triggerStore[applicationId] = _triggerStore[applicationId] || baseStore();
|
||||
_triggerStore[applicationId].Functions[functionName] = handler;
|
||||
_triggerStore[applicationId].Validators[functionName] = validationHandler;
|
||||
}
|
||||
|
||||
function addTrigger(type, className, handler, applicationId) {
|
||||
export function addTrigger(type, className, handler, applicationId) {
|
||||
applicationId = applicationId || Parse.applicationId;
|
||||
_triggerStore[applicationId] = _triggerStore[applicationId] || new BaseStore();
|
||||
_triggerStore[applicationId] = _triggerStore[applicationId] || baseStore();
|
||||
_triggerStore[applicationId].Triggers[type][className] = handler;
|
||||
}
|
||||
|
||||
function removeFunction(functionName, applicationId) {
|
||||
export function removeFunction(functionName, applicationId) {
|
||||
applicationId = applicationId || Parse.applicationId;
|
||||
delete _triggerStore[applicationId].Functions[functionName]
|
||||
}
|
||||
|
||||
function removeTrigger(type, className, applicationId) {
|
||||
export function removeTrigger(type, className, applicationId) {
|
||||
applicationId = applicationId || Parse.applicationId;
|
||||
delete _triggerStore[applicationId].Triggers[type][className]
|
||||
}
|
||||
|
||||
function _unregister(a,b,c,d) {
|
||||
export function _unregister(a,b,c,d) {
|
||||
if (d) {
|
||||
removeTrigger(c,d,a);
|
||||
delete _triggerStore[a][b][c][d];
|
||||
@@ -53,7 +60,7 @@ function _unregister(a,b,c,d) {
|
||||
}
|
||||
|
||||
|
||||
var getTrigger = function(className, triggerType, applicationId) {
|
||||
export function getTrigger(className, triggerType, applicationId) {
|
||||
if (!applicationId) {
|
||||
throw "Missing ApplicationID";
|
||||
}
|
||||
@@ -67,11 +74,11 @@ var getTrigger = function(className, triggerType, applicationId) {
|
||||
return undefined;
|
||||
};
|
||||
|
||||
function triggerExists(className: string, type: string): boolean {
|
||||
return (getTrigger(className, type) != undefined);
|
||||
export function triggerExists(className: string, type: string, applicationId: string): boolean {
|
||||
return (getTrigger(className, type, applicationId) != undefined);
|
||||
}
|
||||
|
||||
var getFunction = function(functionName, applicationId) {
|
||||
export function getFunction(functionName, applicationId) {
|
||||
var manager = _triggerStore[applicationId];
|
||||
if (manager && manager.Functions) {
|
||||
return manager.Functions[functionName];
|
||||
@@ -79,7 +86,7 @@ var getFunction = function(functionName, applicationId) {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
var getValidator = function(functionName, applicationId) {
|
||||
export function getValidator(functionName, applicationId) {
|
||||
var manager = _triggerStore[applicationId];
|
||||
if (manager && manager.Validators) {
|
||||
return manager.Validators[functionName];
|
||||
@@ -87,7 +94,7 @@ var getValidator = function(functionName, applicationId) {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
var getRequestObject = function(triggerType, auth, parseObject, originalParseObject) {
|
||||
export function getRequestObject(triggerType, auth, parseObject, originalParseObject) {
|
||||
var request = {
|
||||
triggerName: triggerType,
|
||||
object: parseObject,
|
||||
@@ -116,7 +123,7 @@ var getRequestObject = function(triggerType, auth, parseObject, originalParseObj
|
||||
// The API will call this with REST API formatted objects, this will
|
||||
// transform them to Parse.Object instances expected by Cloud Code.
|
||||
// Any changes made to the object in a beforeSave will be included.
|
||||
var getResponseObject = function(request, resolve, reject) {
|
||||
export function getResponseObject(request, resolve, reject) {
|
||||
return {
|
||||
success: function(response) {
|
||||
// Use the JSON response
|
||||
@@ -141,7 +148,7 @@ var getResponseObject = function(request, resolve, reject) {
|
||||
// Resolves to an object, empty or containing an object key. A beforeSave
|
||||
// trigger will set the object key to the rest format object to save.
|
||||
// originalParseObject is optional, we only need that for befote/afterSave functions
|
||||
var maybeRunTrigger = function(triggerType, auth, parseObject, originalParseObject, applicationId) {
|
||||
export function maybeRunTrigger(triggerType, auth, parseObject, originalParseObject, applicationId) {
|
||||
if (!parseObject) {
|
||||
return Promise.resolve({});
|
||||
}
|
||||
@@ -160,38 +167,10 @@ var maybeRunTrigger = function(triggerType, auth, parseObject, originalParseObje
|
||||
|
||||
// Converts a REST-format object to a Parse.Object
|
||||
// data is either className or an object
|
||||
function inflate(data, restObject) {
|
||||
export function inflate(data, restObject) {
|
||||
var copy = typeof data == 'object' ? data : {className: data};
|
||||
for (var key in restObject) {
|
||||
copy[key] = restObject[key];
|
||||
}
|
||||
return Parse.Object.fromJSON(copy);
|
||||
}
|
||||
|
||||
<<<<<<< 5fae41183ed476976ff29a4c247aa78b00b83a9e
|
||||
module.exports = {
|
||||
getTrigger: getTrigger,
|
||||
getRequestObject: getRequestObject,
|
||||
inflate: inflate,
|
||||
maybeRunTrigger: maybeRunTrigger,
|
||||
triggerExists: triggerExists,
|
||||
Types: Types
|
||||
};
|
||||
=======
|
||||
var TriggerManager = {};
|
||||
|
||||
TriggerManager.getTrigger = getTrigger;
|
||||
TriggerManager.getRequestObject = getRequestObject;
|
||||
TriggerManager.inflate = inflate;
|
||||
TriggerManager.maybeRunTrigger = maybeRunTrigger;
|
||||
TriggerManager.Types = Types;
|
||||
TriggerManager.addFunction = addFunction;
|
||||
TriggerManager.getFunction = getFunction;
|
||||
TriggerManager.removeTrigger = removeTrigger;
|
||||
TriggerManager.removeFunction = removeFunction;
|
||||
TriggerManager.getValidator = getValidator;
|
||||
TriggerManager.addTrigger = addTrigger;
|
||||
TriggerManager._unregister = _unregister;
|
||||
|
||||
module.exports = TriggerManager;
|
||||
>>>>>>> Adds Hooks API
|
||||
|
||||
Reference in New Issue
Block a user