CHECK(job_factory_);
}
-mate::ObjectTemplateBuilder Protocol::GetObjectTemplateBuilder(
- v8::Isolate* isolate) {
- return mate::ObjectTemplateBuilder(isolate)
- .SetMethod("registerStandardSchemes", &Protocol::RegisterStandardSchemes)
- .SetMethod("registerServiceWorkerSchemes",
- &Protocol::RegisterServiceWorkerSchemes)
- .SetMethod("registerStringProtocol",
- &Protocol::RegisterProtocol<URLRequestStringJob>)
- .SetMethod("registerBufferProtocol",
- &Protocol::RegisterProtocol<URLRequestBufferJob>)
- .SetMethod("registerFileProtocol",
- &Protocol::RegisterProtocol<URLRequestAsyncAsarJob>)
- .SetMethod("registerHttpProtocol",
- &Protocol::RegisterProtocol<URLRequestFetchJob>)
- .SetMethod("unregisterProtocol", &Protocol::UnregisterProtocol)
- .SetMethod("isProtocolHandled", &Protocol::IsProtocolHandled)
- .SetMethod("interceptStringProtocol",
- &Protocol::InterceptProtocol<URLRequestStringJob>)
- .SetMethod("interceptBufferProtocol",
- &Protocol::InterceptProtocol<URLRequestBufferJob>)
- .SetMethod("interceptFileProtocol",
- &Protocol::InterceptProtocol<URLRequestAsyncAsarJob>)
- .SetMethod("interceptHttpProtocol",
- &Protocol::InterceptProtocol<URLRequestFetchJob>)
- .SetMethod("uninterceptProtocol", &Protocol::UninterceptProtocol);
-}
-
void Protocol::RegisterStandardSchemes(
const std::vector<std::string>& schemes) {
atom::AtomBrowserClient::SetCustomSchemes(schemes);
return mate::CreateHandle(isolate, new Protocol(browser_context));
}
-} // namespace api
-
-} // namespace atom
-
-namespace {
-
-void Initialize(v8::Local<v8::Object> exports, v8::Local<v8::Value> unused,
- v8::Local<v8::Context> context, void* priv) {
- v8::Isolate* isolate = context->GetIsolate();
- mate::Dictionary dict(isolate, exports);
- auto browser_context = static_cast<atom::AtomBrowserContext*>(
- atom::AtomBrowserMainParts::Get()->browser_context());
- dict.Set("protocol", atom::api::Protocol::Create(isolate, browser_context));
+// static
+void Protocol::BuildPrototype(v8::Isolate* isolate,
+ v8::Local<v8::ObjectTemplate> prototype) {
+ mate::ObjectTemplateBuilder(isolate, prototype)
+ .SetMethod("registerStandardSchemes", &Protocol::RegisterStandardSchemes)
+ .SetMethod("registerServiceWorkerSchemes",
+ &Protocol::RegisterServiceWorkerSchemes)
+ .SetMethod("registerStringProtocol",
+ &Protocol::RegisterProtocol<URLRequestStringJob>)
+ .SetMethod("registerBufferProtocol",
+ &Protocol::RegisterProtocol<URLRequestBufferJob>)
+ .SetMethod("registerFileProtocol",
+ &Protocol::RegisterProtocol<URLRequestAsyncAsarJob>)
+ .SetMethod("registerHttpProtocol",
+ &Protocol::RegisterProtocol<URLRequestFetchJob>)
+ .SetMethod("unregisterProtocol", &Protocol::UnregisterProtocol)
+ .SetMethod("isProtocolHandled", &Protocol::IsProtocolHandled)
+ .SetMethod("interceptStringProtocol",
+ &Protocol::InterceptProtocol<URLRequestStringJob>)
+ .SetMethod("interceptBufferProtocol",
+ &Protocol::InterceptProtocol<URLRequestBufferJob>)
+ .SetMethod("interceptFileProtocol",
+ &Protocol::InterceptProtocol<URLRequestAsyncAsarJob>)
+ .SetMethod("interceptHttpProtocol",
+ &Protocol::InterceptProtocol<URLRequestFetchJob>)
+ .SetMethod("uninterceptProtocol", &Protocol::UninterceptProtocol);
}
-} // namespace
+} // namespace api
-NODE_MODULE_CONTEXT_AWARE_BUILTIN(atom_browser_protocol, Initialize)
+} // namespace atom
#include <map>
#include <vector>
+#include "atom/browser/api/trackable_object.h"
#include "atom/browser/net/atom_url_request_job_factory.h"
#include "base/callback.h"
#include "base/containers/scoped_ptr_hash_map.h"
namespace api {
-class Protocol : public mate::Wrappable {
+class Protocol : public mate::TrackableObject<Protocol> {
public:
using Handler =
base::Callback<void(const net::URLRequest*, v8::Local<v8::Value>)>;
static mate::Handle<Protocol> Create(
v8::Isolate* isolate, AtomBrowserContext* browser_context);
+ // mate::TrackableObject:
+ static void BuildPrototype(v8::Isolate* isolate,
+ v8::Local<v8::ObjectTemplate> prototype);
+
protected:
explicit Protocol(AtomBrowserContext* browser_context);
- // mate::Wrappable implementations:
- virtual mate::ObjectTemplateBuilder GetObjectTemplateBuilder(
- v8::Isolate* isolate);
-
private:
// Possible errors.
enum ProtocolError {
#include "atom/browser/api/atom_api_cookies.h"
#include "atom/browser/api/atom_api_download_item.h"
+#include "atom/browser/api/atom_api_protocol.h"
#include "atom/browser/api/atom_api_web_contents.h"
#include "atom/browser/api/atom_api_web_request.h"
#include "atom/browser/api/save_page_handler.h"
return v8::Local<v8::Value>::New(isolate, cookies_);
}
+v8::Local<v8::Value> Session::Protocol(v8::Isolate* isolate) {
+ if (protocol_.IsEmpty()) {
+ auto handle = atom::api::Protocol::Create(isolate, browser_context());
+ protocol_.Reset(isolate, handle.ToV8());
+ }
+ return v8::Local<v8::Value>::New(isolate, protocol_);
+}
+
v8::Local<v8::Value> Session::WebRequest(v8::Isolate* isolate) {
if (web_request_.IsEmpty()) {
auto handle = atom::api::WebRequest::Create(isolate, browser_context());
&Session::SetPermissionRequestHandler)
.SetMethod("clearHostResolverCache", &Session::ClearHostResolverCache)
.SetProperty("cookies", &Session::Cookies)
+ .SetProperty("protocol", &Session::Protocol)
.SetProperty("webRequest", &Session::WebRequest);
}
mate::Arguments* args);
void ClearHostResolverCache(mate::Arguments* args);
v8::Local<v8::Value> Cookies(v8::Isolate* isolate);
+ v8::Local<v8::Value> Protocol(v8::Isolate* isolate);
v8::Local<v8::Value> WebRequest(v8::Isolate* isolate);
// Cached object.
v8::Global<v8::Value> cookies_;
+ v8::Global<v8::Value> protocol_;
v8::Global<v8::Value> web_request_;
scoped_refptr<AtomBrowserContext> browser_context_;
throw new Error('Can not initialize protocol module before app is ready');
}
-const protocol = process.atomBinding('protocol').protocol;
+const session = require('electron').session;
+
+// Returns the protocol property for default session.
+const protocol = session.defaultSession.protocol;
// Warn about removed APIs.
var logAndThrow = function(callback, message) {
}
};
+protocol.fromPartition = function(partition) {
+ return session.fromPartition(partition).protocol;
+};
+
protocol.registerProtocol = function(scheme, handler, callback) {
return logAndThrow(callback, 'registerProtocol API has been replaced by the register[File/Http/Buffer/String]Protocol API family, please switch to the new APIs.');
};
REFERENCE_MODULE(atom_browser_menu);
REFERENCE_MODULE(atom_browser_power_monitor);
REFERENCE_MODULE(atom_browser_power_save_blocker);
-REFERENCE_MODULE(atom_browser_protocol);
REFERENCE_MODULE(atom_browser_global_shortcut);
REFERENCE_MODULE(atom_browser_session);
REFERENCE_MODULE(atom_browser_tray);
const path = require('path');
const qs = require('querystring');
const remote = require('electron').remote;
+const BrowserWindow = remote.require('electron').BrowserWindow;
const protocol = remote.require('electron').protocol;
describe('protocol module', function() {
});
});
});
+
+ describe('protocol.fromPartition', function() {
+ var partitionName = 'temp';
+ var tempProtocol = protocol.fromPartition(partitionName);
+ var w = null;
+
+ beforeEach(function() {
+ if (w != null) {
+ w.destroy();
+ }
+ w = new BrowserWindow({
+ show: false,
+ width: 400,
+ height: 400,
+ webPreferences: {
+ partition: partitionName
+ }
+ });
+ });
+
+ afterEach(function() {
+ if (w != null) {
+ w.destroy();
+ }
+ w = null;
+ });
+
+ it('handles requests from a partition', function(done) {
+ var handler = function(error, callback) {
+ callback({
+ data: text
+ });
+ };
+ tempProtocol.registerStringProtocol(protocolName, handler, function(error) {
+ if (error) {
+ return done(error);
+ }
+ protocol.isProtocolHandled(protocolName, function(result) {
+ assert.equal(result, false);
+ });
+ tempProtocol.isProtocolHandled(protocolName, function(result) {
+ assert.equal(result, true);
+ });
+ });
+ w.webContents.on('did-finish-load', function() {
+ done();
+ });
+ w.loadURL(protocolName + "://fake-host");
+ });
+ });
});