mirror of
https://review.haiku-os.org/haiku
synced 2025-01-22 14:24:48 +01:00
4849ab6c8b
When an HTTPS request uses an SSL certificate that OpenSSL considers untrusted, and the user decides to continue anyway, add the certificate to an exception list. Match certificates against this list and don't ask the user again if they are already there. Fixes #12004. Thanks to markh for the initial patch and peeking into the WebKit code!
58 lines
1.4 KiB
C++
58 lines
1.4 KiB
C++
/*
|
|
* Copyright 2010-2015 Haiku Inc. All rights reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
|
|
|
|
#ifndef _B_URL_CONTEXT_H_
|
|
#define _B_URL_CONTEXT_H_
|
|
|
|
|
|
#include <Certificate.h>
|
|
#include <HttpAuthentication.h>
|
|
#include <NetworkCookieJar.h>
|
|
#include <Referenceable.h>
|
|
|
|
|
|
namespace BPrivate {
|
|
template <class key, class value> class SynchronizedHashMap;
|
|
class HashString;
|
|
}
|
|
|
|
|
|
class BUrlContext: public BReferenceable {
|
|
public:
|
|
BUrlContext();
|
|
~BUrlContext();
|
|
|
|
// Context modifiers
|
|
void SetCookieJar(
|
|
const BNetworkCookieJar& cookieJar);
|
|
void AddAuthentication(const BUrl& url,
|
|
const BHttpAuthentication& authentication);
|
|
void SetProxy(BString host, uint16 port);
|
|
void AddCertificateException(const BCertificate& certificate);
|
|
|
|
// Context accessors
|
|
BNetworkCookieJar& GetCookieJar();
|
|
BHttpAuthentication& GetAuthentication(const BUrl& url);
|
|
bool UseProxy();
|
|
BString GetProxyHost();
|
|
uint16 GetProxyPort();
|
|
bool HasCertificateException(const BCertificate& certificate);
|
|
|
|
private:
|
|
BNetworkCookieJar fCookieJar;
|
|
typedef BPrivate::SynchronizedHashMap<BPrivate::HashString,
|
|
BHttpAuthentication*> BHttpAuthenticationMap;
|
|
BHttpAuthenticationMap* fAuthenticationMap;
|
|
typedef BObjectList<const BCertificate> BCertificateSet;
|
|
BCertificateSet fCertificates;
|
|
|
|
BString fProxyHost;
|
|
uint16 fProxyPort;
|
|
};
|
|
|
|
|
|
#endif // _B_URL_CONTEXT_H_
|