WebSecurityOrigin.h [plain text]
#ifndef WebSecurityOrigin_h
#define WebSecurityOrigin_h
#include "APIObject.h"
#include <WebCore/SecurityOrigin.h>
#include <wtf/PassRefPtr.h>
namespace WebKit {
class WebSecurityOrigin : public APIObject {
public:
static const Type APIType = TypeSecurityOrigin;
static PassRefPtr<WebSecurityOrigin> createFromString(const String& string)
{
RefPtr<WebCore::SecurityOrigin> securityOrigin = WebCore::SecurityOrigin::createFromString(string);
if (!securityOrigin)
return 0;
return adoptRef(new WebSecurityOrigin(securityOrigin.release()));
}
static PassRefPtr<WebSecurityOrigin> createFromDatabaseIdentifier(const String& identifier)
{
RefPtr<WebCore::SecurityOrigin> securityOrigin = WebCore::SecurityOrigin::createFromDatabaseIdentifier(identifier);
if (!securityOrigin)
return 0;
return adoptRef(new WebSecurityOrigin(securityOrigin.release()));
}
static PassRefPtr<WebSecurityOrigin> create(const String& protocol, const String& host, int port)
{
RefPtr<WebCore::SecurityOrigin> securityOrigin = WebCore::SecurityOrigin::create(protocol, host, port);
if (!securityOrigin)
return 0;
return adoptRef(new WebSecurityOrigin(securityOrigin.release()));
}
const String protocol() const { return m_securityOrigin->protocol(); }
const String host() const { return m_securityOrigin->host(); }
unsigned short port() const { return m_securityOrigin->port(); }
const String databaseIdentifier() const { return m_securityOrigin->databaseIdentifier(); }
const String toString() const { return m_securityOrigin->toString(); }
private:
WebSecurityOrigin(PassRefPtr<WebCore::SecurityOrigin> securityOrigin)
: m_securityOrigin(securityOrigin)
{
}
virtual Type type() const { return APIType; }
RefPtr<WebCore::SecurityOrigin> m_securityOrigin;
};
}
#endif