blob: d0e16f7bb52593c7992fac9dd2cfb9579f858d3b [file] [log] [blame]
/*
* Copyright (C) 2009 Apple Inc. All Rights Reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#include "Credential.h"
#include "ProtectionSpaceHash.h"
#include "SecurityOriginData.h"
#include <wtf/HashMap.h>
#include <wtf/HashSet.h>
#include <wtf/text/StringHash.h>
#include <wtf/text/WTFString.h>
namespace WebCore {
class ProtectionSpace;
class CredentialStorage {
public:
// WebCore session credential storage.
WEBCORE_EXPORT void set(const String&, const Credential&, const ProtectionSpace&, const URL&);
WEBCORE_EXPORT Credential get(const String&, const ProtectionSpace&);
WEBCORE_EXPORT void remove(const String&, const ProtectionSpace&);
WEBCORE_EXPORT void removeCredentialsWithOrigin(const SecurityOriginData&);
// OS credential storage.
WEBCORE_EXPORT static Credential getFromPersistentStorage(const ProtectionSpace&);
WEBCORE_EXPORT static HashSet<SecurityOriginData> originsWithSessionCredentials();
WEBCORE_EXPORT static void removeSessionCredentialsWithOrigins(const Vector<SecurityOriginData>& origins);
WEBCORE_EXPORT static void clearSessionCredentials();
WEBCORE_EXPORT void clearCredentials();
// These methods work for authentication schemes that support sending credentials without waiting for a request. E.g., for HTTP Basic authentication scheme
// a client should assume that all paths at or deeper than the depth of a known protected resource share are within the same protection space.
WEBCORE_EXPORT bool set(const String&, const Credential&, const URL&); // Returns true if the URL corresponds to a known protection space, so credentials could be updated.
WEBCORE_EXPORT Credential get(const String&, const URL&);
WEBCORE_EXPORT HashSet<SecurityOriginData> originsWithCredentials() const;
private:
HashMap<std::pair<String /* partitionName */, ProtectionSpace>, Credential> m_protectionSpaceToCredentialMap;
HashSet<String> m_originsWithCredentials;
typedef HashMap<String, ProtectionSpace> PathToDefaultProtectionSpaceMap;
PathToDefaultProtectionSpaceMap m_pathToDefaultProtectionSpaceMap;
PathToDefaultProtectionSpaceMap::iterator findDefaultProtectionSpaceForURL(const URL&);
};
} // namespace WebCore