/* -*- 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_URLSearchParams_h #define mozilla_dom_URLSearchParams_h #include "mozilla/dom/BindingDeclarations.h" #include "mozilla/ErrorResult.h" #include "nsCycleCollectionParticipant.h" #include "nsWrapperCache.h" #include "nsISupports.h" #include "nsIUnicodeDecoder.h" namespace mozilla { namespace dom { class URLSearchParams; class URLSearchParamsObserver : public nsISupports { public: virtual ~URLSearchParamsObserver() {} virtual void URLSearchParamsUpdated(URLSearchParams* aFromThis) = 0; }; // This class is used in BasePrincipal and it's _extremely_ important that the // attributes are kept in the correct order. If this changes, please, update // BasePrincipal code. class URLParams final { public: URLParams() {} ~URLParams() { DeleteAll(); } explicit URLParams(const URLParams& aOther) : mParams(aOther.mParams) {} explicit URLParams(const URLParams&& aOther) : mParams(Move(aOther.mParams)) {} class ForEachIterator { public: virtual bool URLParamsIterator(const nsString& aName, const nsString& aValue) = 0; }; void ParseInput(const nsACString& aInput); bool ForEach(ForEachIterator& aIterator) const { for (uint32_t i = 0; i < mParams.Length(); ++i) { if (!aIterator.URLParamsIterator(mParams[i].mKey, mParams[i].mValue)) { return false; } } return true; } void Serialize(nsAString& aValue) const; void Get(const nsAString& aName, nsString& aRetval); void GetAll(const nsAString& aName, nsTArray& aRetval); void Set(const nsAString& aName, const nsAString& aValue); void Append(const nsAString& aName, const nsAString& aValue); bool Has(const nsAString& aName); // Returns true if aName was found and deleted, false otherwise. bool Delete(const nsAString& aName); void DeleteAll() { mParams.Clear(); } private: void DecodeString(const nsACString& aInput, nsAString& aOutput); void ConvertString(const nsACString& aInput, nsAString& aOutput); struct Param { nsString mKey; nsString mValue; }; nsTArray mParams; nsCOMPtr mDecoder; }; class URLSearchParams final : public nsISupports, public nsWrapperCache { ~URLSearchParams(); public: NS_DECL_CYCLE_COLLECTING_ISUPPORTS NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS(URLSearchParams) URLSearchParams(nsISupports* aParent, URLSearchParamsObserver* aObserver); URLSearchParams(nsISupports* aParent, const URLSearchParams& aOther); // WebIDL methods nsISupports* GetParentObject() const { return mParent; } virtual JSObject* WrapObject(JSContext* aCx, JS::Handle aGivenProto) override; static already_AddRefed Constructor(const GlobalObject& aGlobal, const nsAString& aInit, ErrorResult& aRv); static already_AddRefed Constructor(const GlobalObject& aGlobal, URLSearchParams& aInit, ErrorResult& aRv); void ParseInput(const nsACString& aInput); void Serialize(nsAString& aValue) const; void Get(const nsAString& aName, nsString& aRetval); void GetAll(const nsAString& aName, nsTArray& aRetval); void Set(const nsAString& aName, const nsAString& aValue); void Append(const nsAString& aName, const nsAString& aValue); bool Has(const nsAString& aName); void Delete(const nsAString& aName); void Stringify(nsString& aRetval) const { Serialize(aRetval); } typedef URLParams::ForEachIterator ForEachIterator; bool ForEach(ForEachIterator& aIterator) const { return mParams->ForEach(aIterator); return true; } private: void AppendInternal(const nsAString& aName, const nsAString& aValue); void DeleteAll(); void NotifyObserver(); UniquePtr mParams; nsCOMPtr mParent; nsRefPtr mObserver; }; } // namespace dom } // namespace mozilla #endif /* mozilla_dom_URLSearchParams_h */