c5b9f766f3
* chore: bump chromium in DEPS to 117.0.5921.0 * chore: update chromium patches * 4721409: Remove redundant ARC configuration in /components | https://chromium-review.googlesource.com/c/chromium/src/+/4721409 * 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * 4022621: Re-register status item when owner of status watcher is changed | https://chromium-review.googlesource.com/c/chromium/src/+/4022621 * chore: update V8/boringssl patches * fixup! 4643750: Add V8_LOW_PRIORITY_TQ for main thread | https://chromium-review.googlesource.com/c/chromium/src/+/4643750 * chore: bump chromium in DEPS to 117.0.5923.0 * build [debug]: remove assert 4722125: Update enterprise content analysis buildflags usage | https://chromium-review.googlesource.com/c/chromium/src/+/4722125 * chore: manually rollback to 117.0.5921.0 * build [arc]: ARC conversion in auto_updater * build [arc]: ARC conversion in browser/api * build [arc]: ARC conversion in notifications/mac * build [arc]: ARC conversion in in_app_purchase * build [arc]: ARC conversion in browser/ui * build [arc]: ARC conversion in ui/cocoa * build [arc]: ARC conversion in shell/common * build [arc]: ARC conversion in OSR * build [arc]: ARC conversion in login_helper * build [arc]: ARC conversion in app_mas * build [arc]: fix up ARC syntax (thanks @codebytere!) * 4726946: [Extensions] Work around dangling BrowserContext pointer. | https://chromium-review.googlesource.com/c/chromium/src/+/4726946 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com>
61 lines
2 KiB
Text
61 lines
2 KiB
Text
// Copyright (c) 2013 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/api/electron_api_app.h"
|
|
|
|
#include <string>
|
|
|
|
#import <Cocoa/Cocoa.h>
|
|
|
|
#include "base/strings/sys_string_conversions.h"
|
|
|
|
namespace electron::api {
|
|
|
|
// Callback passed to js which will stop accessing the given bookmark.
|
|
void OnStopAccessingSecurityScopedResource(NSURL* bookmarkUrl) {
|
|
[bookmarkUrl stopAccessingSecurityScopedResource];
|
|
}
|
|
|
|
// Get base64 encoded NSData, create a bookmark for it and start accessing it.
|
|
base::RepeatingCallback<void()> App::StartAccessingSecurityScopedResource(
|
|
gin::Arguments* args) {
|
|
std::string data;
|
|
args->GetNext(&data);
|
|
NSString* base64str = base::SysUTF8ToNSString(data);
|
|
NSData* bookmarkData = [[NSData alloc] initWithBase64EncodedString:base64str
|
|
options:0];
|
|
|
|
// Create bookmarkUrl from NSData.
|
|
BOOL isStale = false;
|
|
NSError* error = nil;
|
|
NSURL* bookmarkUrl = [NSURL
|
|
URLByResolvingBookmarkData:bookmarkData
|
|
options:NSURLBookmarkResolutionWithSecurityScope |
|
|
NSURLBookmarkResolutionWithoutMounting
|
|
relativeToURL:nil
|
|
bookmarkDataIsStale:&isStale
|
|
error:&error];
|
|
|
|
if (error != nil) {
|
|
NSString* err =
|
|
[NSString stringWithFormat:@"NSError: %@ %@", error, [error userInfo]];
|
|
gin_helper::ErrorThrower(args->isolate())
|
|
.ThrowError(base::SysNSStringToUTF8(err));
|
|
}
|
|
|
|
if (isStale) {
|
|
gin_helper::ErrorThrower(args->isolate())
|
|
.ThrowError("bookmarkDataIsStale - try recreating the bookmark");
|
|
}
|
|
|
|
if (error == nil && isStale == false) {
|
|
[bookmarkUrl startAccessingSecurityScopedResource];
|
|
}
|
|
|
|
// Return a js callback which will close the bookmark.
|
|
return base::BindRepeating(&OnStopAccessingSecurityScopedResource,
|
|
bookmarkUrl);
|
|
}
|
|
|
|
} // namespace electron::api
|