Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(304)

Side by Side Diff: extensions/renderer/blob_native_handler.cc

Issue 280393003: Blobs: Catching browser-process created Blobs in extension code. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « extensions/extensions.gyp ('k') | extensions/renderer/dispatcher.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "extensions/renderer/blob_native_handler.h" 5 #include "extensions/renderer/blob_native_handler.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "third_party/WebKit/public/platform/WebCString.h" 8 #include "third_party/WebKit/public/platform/WebCString.h"
9 #include "third_party/WebKit/public/platform/WebURL.h" 9 #include "third_party/WebKit/public/platform/WebURL.h"
10 #include "third_party/WebKit/public/web/WebBlob.h" 10 #include "third_party/WebKit/public/web/WebBlob.h"
11 11
12 namespace { 12 namespace {
13 13
14 // Expects a single Blob argument. Returns the Blob's UUID. 14 // Expects a single Blob argument. Returns the Blob's UUID.
15 void GetBlobUuid(const v8::FunctionCallbackInfo<v8::Value>& args) { 15 void GetBlobUuid(const v8::FunctionCallbackInfo<v8::Value>& args) {
16 DCHECK_EQ(1, args.Length()); 16 DCHECK_EQ(1, args.Length());
17 blink::WebBlob blob = blink::WebBlob::fromV8Value(args[0]); 17 blink::WebBlob blob = blink::WebBlob::fromV8Value(args[0]);
18 args.GetReturnValue().Set( 18 args.GetReturnValue().Set(
19 v8::String::NewFromUtf8(args.GetIsolate(), blob.uuid().utf8().data())); 19 v8::String::NewFromUtf8(args.GetIsolate(), blob.uuid().utf8().data()));
20 } 20 }
21 21
22 // Take ownership of a Blob created on the browser process. Expects the Blob's
23 // UUID, type, and size as arguments. Returns the Blob we just took to
24 // Javascript. The Blob reference in the browser process is dropped through
25 // a separate flow to avoid leaking Blobs if the script context is destroyed.
26 void TakeBrowserProcessBlob(const v8::FunctionCallbackInfo<v8::Value>& args) {
27 DCHECK_EQ(3, args.Length());
28 DCHECK(args[0]->IsString());
29 DCHECK(args[1]->IsString());
30 DCHECK(args[2]->IsInt32());
31 std::string uuid(*v8::String::Utf8Value(args[0]->ToString()));
32 std::string type(*v8::String::Utf8Value(args[1]->ToString()));
33 blink::WebBlob blob =
34 blink::WebBlob::createFromUUID(blink::WebString::fromUTF8(uuid),
35 blink::WebString::fromUTF8(type),
36 args[2]->Int32Value());
37 args.GetReturnValue().Set(blob.toV8Value());
38 }
39
22 } // namespace 40 } // namespace
23 41
24 namespace extensions { 42 namespace extensions {
25 43
26 BlobNativeHandler::BlobNativeHandler(ScriptContext* context) 44 BlobNativeHandler::BlobNativeHandler(ScriptContext* context)
27 : ObjectBackedNativeHandler(context) { 45 : ObjectBackedNativeHandler(context) {
28 RouteFunction("GetBlobUuid", base::Bind(&GetBlobUuid)); 46 RouteFunction("GetBlobUuid", base::Bind(&GetBlobUuid));
47 RouteFunction("TakeBrowserProcessBlob", base::Bind(&TakeBrowserProcessBlob));
29 } 48 }
30 49
31 } // namespace extensions 50 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/extensions.gyp ('k') | extensions/renderer/dispatcher.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698