gecko-dev/dom/filesystem/FileSystemSecurity.h
Andrea Marchesini a628be7b36 Bug 1344415 - Introduce a security check about which files can be opened by a content process, r=ehsan
Entries API gives access to the filesystem. With this patch we allow that only
to patches, previously shared by a FilePicker or a DataTransfer event.
2017-03-16 08:53:49 +01:00

49 lines
1.2 KiB
C++

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef mozilla_dom_FileSystemSecurity_h
#define mozilla_dom_FileSystemSecurity_h
#include "mozilla/dom/ipc/IdType.h"
#include "nsClassHashtable.h"
#include "nsISupportsImpl.h"
namespace mozilla {
namespace dom {
class FileSystemSecurity final
{
public:
NS_INLINE_DECL_REFCOUNTING(FileSystemSecurity)
static already_AddRefed<FileSystemSecurity>
Get();
static already_AddRefed<FileSystemSecurity>
GetOrCreate();
void
GrantAccessToContentProcess(ContentParentId aId,
const nsAString& aDirectoryPath);
void
Forget(ContentParentId aId);
bool
ContentProcessHasAccessTo(ContentParentId aId, const nsAString& aPath);
private:
FileSystemSecurity();
~FileSystemSecurity();
nsClassHashtable<nsUint64HashKey, nsTArray<nsString>> mPaths;
};
} // dom namespace
} // mozilla namespace
#endif // mozilla_dom_FileSystemSecurity_h