/* -*- 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_Directory_h #define mozilla_dom_Directory_h #include "mozilla/Attributes.h" #include "mozilla/ErrorResult.h" #include "mozilla/dom/BindingDeclarations.h" #include "mozilla/dom/File.h" #include "nsCycleCollectionParticipant.h" #include "nsWrapperCache.h" // Resolve the name collision of Microsoft's API name with macros defined in // Windows header files. Undefine the macro of CreateDirectory to avoid // Directory#CreateDirectory being replaced by Directory#CreateDirectoryW. #ifdef CreateDirectory #undef CreateDirectory #endif // Undefine the macro of CreateFile to avoid Directory#CreateFile being replaced // by Directory#CreateFileW. #ifdef CreateFile #undef CreateFile #endif namespace mozilla { namespace dom { struct CreateFileOptions; class FileSystemBase; class Promise; class StringOrFileOrDirectory; class Directory final : public nsISupports , public nsWrapperCache { public: struct FileOrDirectoryPath { nsString mPath; enum { eFilePath, eDirectoryPath } mType; }; NS_DECL_CYCLE_COLLECTING_ISUPPORTS NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS(Directory) static bool DeviceStorageEnabled(JSContext* aCx, JSObject* aObj); static bool WebkitBlinkDirectoryPickerEnabled(JSContext* aCx, JSObject* aObj); static already_AddRefed GetRoot(FileSystemBase* aFileSystem, ErrorResult& aRv); static already_AddRefed Constructor(const GlobalObject& aGlobal, const nsAString& aRealPath, ErrorResult& aRv); static already_AddRefed Create(nsISupports* aParent, nsIFile* aDirectory, FileSystemBase* aFileSystem = 0); // ========= Begin WebIDL bindings. =========== nsISupports* GetParentObject() const; virtual JSObject* WrapObject(JSContext* aCx, JS::Handle aGivenProto) override; void GetName(nsAString& aRetval, ErrorResult& aRv); already_AddRefed CreateFile(const nsAString& aPath, const CreateFileOptions& aOptions, ErrorResult& aRv); already_AddRefed CreateDirectory(const nsAString& aPath, ErrorResult& aRv); already_AddRefed Get(const nsAString& aPath, ErrorResult& aRv); already_AddRefed Remove(const StringOrFileOrDirectory& aPath, ErrorResult& aRv); already_AddRefed RemoveDeep(const StringOrFileOrDirectory& aPath, ErrorResult& aRv); // From https://microsoftedge.github.io/directory-upload/proposal.html#directory-interface : void GetPath(nsAString& aRetval, ErrorResult& aRv); nsresult GetFullRealPath(nsAString& aPath); already_AddRefed GetFilesAndDirectories(ErrorResult& aRv); already_AddRefed GetFiles(bool aRecursiveFlag, ErrorResult& aRv); // =========== End WebIDL bindings.============ /** * Sets a semi-colon separated list of filters to filter-in or filter-out * certain types of files when the contents of this directory are requested * via a GetFilesAndDirectories() call. * * Currently supported keywords: * * * filter-out-sensitive * This keyword filters out files or directories that we don't wish to * make available to Web content because we are concerned that there is * a risk that users may unwittingly give Web content access to them * and suffer undesirable consequences. The details of what is * filtered out can be found in GetDirectoryListingTask::Work. * * In future, we will likely support filtering based on filename extensions * (for example, aFilters could be "*.jpg; *.jpeg; *.gif"), but that isn't * supported yet. Once supported, files that don't match a specified * extension (if any are specified) would be filtered out. This * functionality would allow us to apply the 'accept' attribute from * to the results of a directory * picker operation. */ void SetContentFilters(const nsAString& aFilters); FileSystemBase* GetFileSystem(ErrorResult& aRv); bool ClonableToDifferentThreadOrProcess() const; private: Directory(nsISupports* aParent, nsIFile* aFile, FileSystemBase* aFileSystem = nullptr); ~Directory(); /* * Convert relative DOM path to the absolute real path. */ nsresult DOMPathToRealPath(const nsAString& aPath, nsIFile** aFile) const; already_AddRefed RemoveInternal(const StringOrFileOrDirectory& aPath, bool aRecursive, ErrorResult& aRv); nsCOMPtr mParent; RefPtr mFileSystem; nsCOMPtr mFile; nsString mFilters; nsString mPath; }; } // namespace dom } // namespace mozilla #endif // mozilla_dom_Directory_h