1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
|
/* -*- 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_Location_h
#define mozilla_dom_Location_h
#include "js/TypeDecls.h"
#include "mozilla/ErrorResult.h"
#include "mozilla/dom/BrowsingContext.h"
#include "mozilla/dom/LocationBase.h"
#include "nsCycleCollectionParticipant.h"
#include "nsString.h"
#include "nsWrapperCache.h"
class nsIDocShell;
class nsIPrincipal;
class nsIURI;
class nsPIDOMWindowInner;
namespace mozilla {
namespace dom {
//*****************************************************************************
// Location: Script "location" object
//*****************************************************************************
class Location final : public nsISupports,
public LocationBase,
public nsWrapperCache {
public:
typedef BrowsingContext::LocationProxy RemoteProxy;
Location(nsPIDOMWindowInner* aWindow, BrowsingContext* aBrowsingContext);
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS(Location)
// WebIDL API:
void Assign(const nsAString& aUrl, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void Reload(bool aForceget, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError) {
if (!CallerSubsumes(&aSubjectPrincipal)) {
aError.Throw(NS_ERROR_DOM_SECURITY_ERR);
return;
}
Reload(aForceget, aError);
}
void GetHref(nsAString& aHref, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError) {
if (!CallerSubsumes(&aSubjectPrincipal)) {
aError.Throw(NS_ERROR_DOM_SECURITY_ERR);
return;
}
aError = GetHref(aHref);
}
void GetOrigin(nsAString& aOrigin, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetProtocol(nsAString& aProtocol, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetProtocol(const nsAString& aProtocol, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetHost(nsAString& aHost, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetHost(const nsAString& aHost, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetHostname(nsAString& aHostname, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetHostname(const nsAString& aHostname, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetPort(nsAString& aPort, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetPort(const nsAString& aPort, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetPathname(nsAString& aPathname, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetPathname(const nsAString& aPathname, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetSearch(nsAString& aSeach, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetSearch(const nsAString& aSeach, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void GetHash(nsAString& aHash, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
void SetHash(const nsAString& aHash, nsIPrincipal& aSubjectPrincipal,
ErrorResult& aError);
nsPIDOMWindowInner* GetParentObject() const { return mInnerWindow; }
virtual JSObject* WrapObject(JSContext* aCx,
JS::Handle<JSObject*> aGivenProto) override;
// Non WebIDL methods:
nsresult GetHref(nsAString& aHref);
nsresult ToString(nsAString& aString) { return GetHref(aString); }
void Reload(bool aForceget, ErrorResult& aRv);
protected:
virtual ~Location();
BrowsingContext* GetBrowsingContext() override;
already_AddRefed<nsIDocShell> GetDocShell() override;
// In the case of jar: uris, we sometimes want the place the jar was
// fetched from as the URI instead of the jar: uri itself. Pass in
// true for aGetInnermostURI when that's the case.
// Note, this method can return NS_OK with a null value for aURL. This happens
// if the docShell is null.
nsresult GetURI(nsIURI** aURL, bool aGetInnermostURI = false);
bool CallerSubsumes(nsIPrincipal* aSubjectPrincipal);
nsString mCachedHash;
nsCOMPtr<nsPIDOMWindowInner> mInnerWindow;
uint64_t mBrowsingContextId = 0;
};
} // namespace dom
} // namespace mozilla
#endif // mozilla_dom_Location_h
|