Loading mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebRequest.java +16 −0 Original line number Diff line number Diff line Loading @@ -49,6 +49,9 @@ public class WebRequest extends WebMessage { /** The value of the Referer header for this request. */ public final @Nullable String referrer; /** The value of the origin of this request. */ public final @Nullable String origin; @Retention(RetentionPolicy.SOURCE) @IntDef({ CACHE_MODE_DEFAULT, Loading Loading @@ -110,6 +113,7 @@ public class WebRequest extends WebMessage { cacheMode = builder.mCacheMode; referrer = builder.mReferrer; beConservative = builder.mBeConservative; origin = builder.mOrigin; if (builder.mBody != null) { body = builder.mBody.asReadOnlyBuffer(); Loading @@ -126,6 +130,7 @@ public class WebRequest extends WebMessage { /* package */ int mCacheMode = CACHE_MODE_DEFAULT; /* package */ String mReferrer; /* package */ boolean mBeConservative; /* package */ String mOrigin; /** * Construct a Builder instance with the specified URI. Loading Loading @@ -236,6 +241,17 @@ public class WebRequest extends WebMessage { return this; } /** * Set the origin URI. * * @param origin A URI String * @return This Builder instance. */ public @NonNull Builder origin(final @Nullable String origin) { mOrigin = origin; return this; } /** * @return A {@link WebRequest} constructed with the values from this Builder instance. */ Loading widget/android/WebExecutorSupport.cpp +8 −0 Original line number Diff line number Diff line Loading @@ -490,6 +490,14 @@ nsresult WebExecutorSupport::CreateStreamLoader( MOZ_ASSERT(cookieJarSettings); nsCOMPtr<nsILoadInfo> loadInfo = channel->LoadInfo(); if (const auto origin = req->Origin(); origin) { RefPtr<nsIURI> originUri; rv = NS_NewURI(getter_AddRefs(originUri), origin->ToString()); NS_ENSURE_SUCCESS(rv, NS_ERROR_MALFORMED_URI); OriginAttributes attrs = loadInfo->GetOriginAttributes(); attrs.SetFirstPartyDomain(true, originUri); loadInfo->SetOriginAttributes(attrs); } loadInfo->SetCookieJarSettings(cookieJarSettings); } Loading Loading
mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebRequest.java +16 −0 Original line number Diff line number Diff line Loading @@ -49,6 +49,9 @@ public class WebRequest extends WebMessage { /** The value of the Referer header for this request. */ public final @Nullable String referrer; /** The value of the origin of this request. */ public final @Nullable String origin; @Retention(RetentionPolicy.SOURCE) @IntDef({ CACHE_MODE_DEFAULT, Loading Loading @@ -110,6 +113,7 @@ public class WebRequest extends WebMessage { cacheMode = builder.mCacheMode; referrer = builder.mReferrer; beConservative = builder.mBeConservative; origin = builder.mOrigin; if (builder.mBody != null) { body = builder.mBody.asReadOnlyBuffer(); Loading @@ -126,6 +130,7 @@ public class WebRequest extends WebMessage { /* package */ int mCacheMode = CACHE_MODE_DEFAULT; /* package */ String mReferrer; /* package */ boolean mBeConservative; /* package */ String mOrigin; /** * Construct a Builder instance with the specified URI. Loading Loading @@ -236,6 +241,17 @@ public class WebRequest extends WebMessage { return this; } /** * Set the origin URI. * * @param origin A URI String * @return This Builder instance. */ public @NonNull Builder origin(final @Nullable String origin) { mOrigin = origin; return this; } /** * @return A {@link WebRequest} constructed with the values from this Builder instance. */ Loading
widget/android/WebExecutorSupport.cpp +8 −0 Original line number Diff line number Diff line Loading @@ -490,6 +490,14 @@ nsresult WebExecutorSupport::CreateStreamLoader( MOZ_ASSERT(cookieJarSettings); nsCOMPtr<nsILoadInfo> loadInfo = channel->LoadInfo(); if (const auto origin = req->Origin(); origin) { RefPtr<nsIURI> originUri; rv = NS_NewURI(getter_AddRefs(originUri), origin->ToString()); NS_ENSURE_SUCCESS(rv, NS_ERROR_MALFORMED_URI); OriginAttributes attrs = loadInfo->GetOriginAttributes(); attrs.SetFirstPartyDomain(true, originUri); loadInfo->SetOriginAttributes(attrs); } loadInfo->SetCookieJarSettings(cookieJarSettings); } Loading