// // Copyright (C) 2015 Google, Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at: // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // #pragma once #include <poll.h> #include <memory> #include <string> #include <unordered_map> #include "service/common/bluetooth/uuid.h" #include "service/gatt_server_old.h" namespace bluetooth { class Adapter; } // namespace bluetooth namespace ipc { // This implements a single threaded event loop which dispatches // reads from a set of FDs (pfds_) to a set of handlers. // Reads from the GATT pipe read end will result in a write to // to the IPC socket, and vise versa. class LinuxIPCHost { public: // LinuxIPCHost owns the passed sockfd. LinuxIPCHost(int sockfd, bluetooth::Adapter* adapter); ~LinuxIPCHost(); // Synchronously handle all events on input FDs. bool EventLoop(); private: // Handler for IPC message receives. // Decodes protocol and dispatches to another handler. bool OnMessage(); // Handler for GATT characteristic writes. // Encodes to protocol and transmits IPC. bool OnGattWrite(); // Applies adapter name changes to stack. bool OnSetAdapterName(const std::string& name); // Handles service creation. bool OnCreateService(const std::string& service_uuid); // Handles service destruction. bool OnDestroyService(const std::string& service_uuid); // Creates a characteristic for a service. bool OnAddCharacteristic(const std::string& service_uuid, const std::string& characteristic_uuid, const std::string& control_uuid, const std::string& options); // Sets the value of a characetistic. bool OnSetCharacteristicValue(const std::string& service_uuid, const std::string& characteristic_uuid, const std::string& value); // Applies settings to service advertisement. bool OnSetAdvertisement(const std::string& service_uuid, const std::string& advertise_uuids, const std::string& advertise_data, const std::string& manufacturer_data, const std::string& transmit_name); // Applies settings to scan response. bool OnSetScanResponse(const std::string& service_uuid, const std::string& advertise_uuids, const std::string& advertise_data, const std::string& manufacturer_data, const std::string& transmit_name); // Starts service (advertisement and connections) bool OnStartService(const std::string& service_uuid); // Stops service. bool OnStopService(const std::string& service_uuid); // weak reference. bluetooth::Adapter *adapter_; // File descripters that we will block against. std::vector<struct pollfd> pfds_; // Container for multiple GATT servers. Currently only one is supported. // TODO(icoolidge): support many to one for real. std::unordered_map<std::string, std::unique_ptr<bluetooth::gatt::Server>> gatt_servers_; }; } // namespace ipc