/*
* Copyright 2016 Canonical Ltd.
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 3, as published
* by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranties of
* MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see .
*
* Authors:
* Charles Kerr
*/
#pragma once
#include
#include
#include
#include
/**
* Receives public key requests from ADBD and sends a response back.
*
* AdbClient only provides a receive/respond mechanism. The decision
* of what response gets sent is delegated out to a listener via
* the on_pk_request signal.
*
* The decider should connect to on_pk_request, listen for PKRequests,
* and call the request's `respond' method with the desired response.
*/
class AdbdClient
{
public:
virtual ~AdbdClient();
enum class PKResponse { DENY, ALLOW };
struct PKRequest {
std::string public_key;
std::string fingerprint;
std::function respond;
};
virtual core::Signal& on_pk_request() =0;
protected:
AdbdClient() =default;
};
/**
* An AdbdClient designed to work with GLib's event loop.
*
* The on_pk_request() signal will be called in global GMainContext's thread;
* ie, just like a function passed to g_idle_add() or g_timeout_add().
*/
class GAdbdClient: public AdbdClient
{
public:
explicit GAdbdClient(const std::string& socket_path);
~GAdbdClient();
core::Signal& on_pk_request() override;
private:
class Impl;
std::unique_ptr impl;
};