Firepad获取并保存内容

时间:2014-05-06 15:18:50

标签: javascript firebase firepad

我需要的是定期将firepad的内容(html)保存在数据库中。

我尝试使用cron服务保存该信息,该服务调用带有ajax请求的页面将内容发送到执行该任务的第二个php页面。

如果我手动调用此url全部工作,但如果cron服务调用url,则javascript不会执行。

我该怎么做?

1 个答案:

答案 0 :(得分:4)

不幸的是,现在还没有直接实现这一目标的方法。你对cron工作有一个好主意,但由于javascript必须执行,除非你使用像phantomjs之类的无头浏览器来加载页面,否则它将无法工作。你可以尝试一下。

或者,我们的一个firepad用户Clément Wehrung使用一些棘手的节点代码解决了这个问题,该代码在后端服务器的节点内部运行firepad.js。我还没有玩过代码,但它可能是一个很好的起点。

节点firepad.js:

/* jshint evil: true */

var jsdom = require('jsdom');
var fs = require('fs');

var Firepad = {};

/**
* Load Dependencies Sources
*/

// HACK: Make Firepad expose FirebaseAdapter
Firepad.FirepadSource = fs.readFileSync(__dirname+'/firepad.js').toString().replace('return firepad.Firepad;', 'firepad.Firepad.FirebaseAdapter = firepad.FirebaseAdapter; return firepad.Firepad;').replace('= global.CodeMirror', '= window.CodeMirror || global.CodeMirror');
Firepad.CodeMirrorSource = fs.readFileSync(__dirname+'/codemirror.js');

/**
* Node Firepad Proxy Loader
*/

Firepad.load = function(ref, callback) {

 jsdom.env('<head></head><body><div id="firepad"></div></body>', function (errors, window) {

   /**
    * Load CodeMirror
    */

   var document = document || window.document;
   var navigator = navigator || { userAgent:'', platform:'' };
   eval(Firepad.CodeMirrorSource+'');
   var CodeMirror = window.CodeMirror;

   /**
    * Load Firepad
    */

   eval(Firepad.FirepadSource+'');
   // HACK: disable cursor
   Firepad.FirebaseAdapter.prototype.sendCursor = function(){};
   Firepad.FirebaseAdapter.prototype.setColor = function(){};

   /**
    * Launch
    */

   var codeMirror_ = CodeMirror(window.document.getElementById('firepad'), { lineWrapping: true }, window);

   var firepad_ = Firepad.fromCodeMirror(ref, codeMirror_,
       { richTextShortcuts: true, richTextToolbar: true });

   if (callback) callback(firepad_, window, errors, document);
 });
};

module.exports = Firepad;

然后您可以使用以下内容:

var FirepadManager = require(__dirname+’/node-firepad’);

FirepadManager.load(firebaseRef, function(firepad, window, errors, document) {
  // The callback is called as soon as the Firepad instance is created.
  // Hence, you can perform stuff like adding your entities support at this point...
  addEntitiesToFirepad(firepad, document);
  firepad.on('ready', function() {
    if (callback) callback(firepad, window, errors, document);
  });
});

如果你走这条路并遇到麻烦,请告诉我(michael@firebase.com)。我也许可以帮忙。祝你好运!