blob: 784460354c122cc7bddf77e9ea37baf311b629e6 [file] [log] [blame]
// Copyright 2020 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/android/jni_android.h"
#include "base/memory/scoped_refptr.h"
#include "base/memory/weak_ptr.h"
#include "base/sequenced_task_runner.h"
#include "net/base/net_export.h"
#include "net/base/network_change_notifier.h"
namespace net {
namespace android {
// NetworkActivationRequest asks Android to activate a network connection which
// fits a specified set of constraints. The system may choose to fulfill the
// request with an already-established network connection, or it may activate a
// new connection specifically to satisfy this request. In the latter case the
// connection may be deactivated upon destruction of this object.
class NET_EXPORT_PRIVATE NetworkActivationRequest {
using NetworkHandle = NetworkChangeNotifier::NetworkHandle;
enum class TransportType {
// Requests a network connection which uses a mobile network for transport.
// Requests an Internet-connected network which satisfies the given
// `transport` constraint.
explicit NetworkActivationRequest(TransportType transport);
NetworkActivationRequest(const NetworkActivationRequest&) = delete;
NetworkActivationRequest& operator=(const NetworkActivationRequest&) = delete;
// Exposes a handle to the network currently activated by the system on behalf
// of this request, if any.
const base::Optional<NetworkHandle>& activated_network() const {
return activated_network_;
// Called from Java via JNI. May be called from any thread, but the ability
// to call it is managed synchronously at construction and destruction of this
// NetworkActivationRequest.
void NotifyAvailable(JNIEnv* env, NetworkHandle network);
void NotifyAvailableOnCorrectSequence(NetworkHandle network);
const scoped_refptr<base::SequencedTaskRunner> task_runner_;
base::WeakPtr<NetworkActivationRequest> weak_self_;
base::android::ScopedJavaGlobalRef<jobject> java_request_;
base::Optional<NetworkHandle> activated_network_;
base::WeakPtrFactory<NetworkActivationRequest> weak_ptr_factory_{this};
} // namespace android
} // namespace net