Summary: This change isolates the usage of folly async from Flipper. Is now self-contained in Flipper Folly schedulers. Users of Flipper can decide not to use the types defined in that header and implement their own. NOTE: changes are minimal, we are just replacing direct calls to folly event base with a scheduler which simply relays this on to folly. Reviewed By: fabiomassimo Differential Revision: D36626483 fbshipit-source-id: add0241caf4af0aa5c3b5c2e7efc2e725f5400ab
80 lines
2.5 KiB
C++
80 lines
2.5 KiB
C++
/*
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <memory>
|
|
#include "FlipperScheduler.h"
|
|
|
|
namespace facebook {
|
|
namespace flipper {
|
|
|
|
class FlipperSocket;
|
|
class FlipperConnectionManager;
|
|
class ConnectionContextStore;
|
|
struct FlipperConnectionEndpoint;
|
|
struct FlipperSocketBasePayload;
|
|
|
|
/**
|
|
A socket provider is responsible of the creation of FlipperSocket instances.
|
|
It also defines static factory methods that can be used to construct such
|
|
instances.
|
|
*/
|
|
class FlipperSocketProvider {
|
|
public:
|
|
virtual ~FlipperSocketProvider() {}
|
|
/**
|
|
Create an instance of FlipperSocket.
|
|
@param endpoint Endpoint to connect to.
|
|
@param payload Any configuration payload to establish a connection with
|
|
the specified endpoint.
|
|
@param scheduler An scheduler used to schedule and execute connection
|
|
operations.
|
|
*/
|
|
virtual std::unique_ptr<FlipperSocket> create(
|
|
FlipperConnectionEndpoint endpoint,
|
|
std::unique_ptr<FlipperSocketBasePayload> payload,
|
|
Scheduler* scheduler) = 0;
|
|
/**
|
|
Create an instance of FlipperSocket.
|
|
@param endpoint Endpoint to connect to.
|
|
@param payload Any configuration payload to establish a connection with
|
|
the specified endpoint.
|
|
@param scheduler An scheduler used to schedule and execute connection
|
|
operations.
|
|
@param connectionContextStore A connection context store used for obtaining
|
|
the certificate used for secure connections.
|
|
*/
|
|
virtual std::unique_ptr<FlipperSocket> create(
|
|
FlipperConnectionEndpoint endpoint,
|
|
std::unique_ptr<FlipperSocketBasePayload> payload,
|
|
Scheduler* scheduler,
|
|
ConnectionContextStore* connectionContextStore) = 0;
|
|
|
|
static std::unique_ptr<FlipperSocket> socketCreate(
|
|
FlipperConnectionEndpoint endpoint,
|
|
std::unique_ptr<FlipperSocketBasePayload> payload,
|
|
Scheduler* scheduler);
|
|
static std::unique_ptr<FlipperSocket> socketCreate(
|
|
FlipperConnectionEndpoint endpoint,
|
|
std::unique_ptr<FlipperSocketBasePayload> payload,
|
|
Scheduler* scheduler,
|
|
ConnectionContextStore* connectionContextStore);
|
|
|
|
static void setDefaultProvider(
|
|
std::unique_ptr<FlipperSocketProvider> provider);
|
|
|
|
static bool hasProvider();
|
|
|
|
private:
|
|
static std::unique_ptr<FlipperSocketProvider> provider_;
|
|
static std::unique_ptr<FlipperSocketProvider> shelvedProvider_;
|
|
};
|
|
|
|
} // namespace flipper
|
|
} // namespace facebook
|