//include stuff here #include #include #include #include #include #include #include #include #include #include #include #include "AglShellGrpcClient.h" #include "agl_shell.grpc.pb.h" namespace { const char kDefaultGrpcServiceAddress[] = "127.0.0.1:14005"; } GrpcClient::GrpcClient(bool wait_for_ready) { int retries = 10; struct timespec ts; if (clock_gettime(CLOCK_MONOTONIC, &ts)) throw std::runtime_error("Failed CLOCK_MONOTONIC"); auto channel = grpc::CreateChannel(kDefaultGrpcServiceAddress, grpc::InsecureChannelCredentials()); ts.tv_nsec = 500 * 1000 * 1000; ts.tv_sec = 0; wait_for_ready_ = wait_for_ready; deadline_ = std::chrono::milliseconds(2000); auto state = channel->GetState(true); // artificial delay otherwise to be sure req calls succeed while (retries-- > 0) { state = channel->GetState(true); if (state == GRPC_CHANNEL_READY) break; nanosleep(&ts, NULL); } if (state != GRPC_CHANNEL_READY) fprintf(stderr, "WARNING: channel not in ready state: %d\n", state); m_stub = agl_shell_ipc::AglShellManagerService::NewStub(channel); reader = new Reader(m_stub.get()); } bool GrpcClient::ActivateApp(const std::string& app_id, const std::string& output_name) { agl_shell_ipc::ActivateRequest request; request.set_app_id(app_id); request.set_output_name(output_name); grpc::ClientContext context; ::agl_shell_ipc::ActivateResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->ActivateApp(&context, request, &reply); return status.ok(); } bool GrpcClient::DeactivateApp(const std::string& app_id) { agl_shell_ipc::DeactivateRequest request; request.set_app_id(app_id); grpc::ClientContext context; ::agl_shell_ipc::DeactivateResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->DeactivateApp(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppFloat(const std::string& app_id, int32_t x_pos, int32_t y_pos) { agl_shell_ipc::FloatRequest request; request.set_app_id(app_id); request.set_x_pos(x_pos); request.set_y_pos(y_pos); grpc::ClientContext context; ::agl_shell_ipc::FloatResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppFloat(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppNormal(const std::string& app_id) { agl_shell_ipc::NormalRequest request; request.set_app_id(app_id); grpc::ClientContext context; ::agl_shell_ipc::NormalResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppNormal(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppFullscreen(const std::string& app_id) { agl_shell_ipc::FullscreenRequest request; request.set_app_id(app_id); grpc::ClientContext context; ::agl_shell_ipc::FullscreenResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppFullscreen(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppOnOutput(const std::string& app_id, const std::string &output) { agl_shell_ipc::AppOnOutputRequest request; request.set_app_id(app_id); request.set_output(output); grpc::ClientContext context; ::agl_shell_ipc::AppOnOutputResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppOnOutput(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppPosition(const std::string& app_id, int32_t x, int32_t y) { agl_shell_ipc::AppPositionRequest request; request.set_app_id(app_id); request.set_x(x); request.set_y(y); grpc::ClientContext context; ::agl_shell_ipc::AppPositionResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppPosition(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppScale(const std::string& app_id, int32_t width, int32_t height) { agl_shell_ipc::AppScaleRequest request; request.set_app_id(app_id); request.set_width(width); request.set_height(height); grpc::ClientContext context; ::agl_shell_ipc::AppScaleResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppScale(&context, request, &reply); return status.ok(); } bool GrpcClient::SetAppSplit(const std::string& app_id, uint32_t orientation, int32_t width, int32_t sticky, const std::string& output_name) { agl_shell_ipc::SplitRequest request; request.set_app_id(app_id); request.set_output_name(output_name); request.set_tile_orientation(orientation); request.set_width(width); request.set_sticky(sticky); grpc::ClientContext context; ::agl_shell_ipc::SplitResponse reply; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->SetAppSplit(&context, request, &reply); return status.ok(); } grpc::Status GrpcClient::Wait(void) { return reader->Await(); } void GrpcClient::AppStatusState(Callback callback) { reader->AppStatusState(callback); } std::vector GrpcClient::GetOutputs() { grpc::ClientContext context; std::vector v; ::agl_shell_ipc::OutputRequest request; ::agl_shell_ipc::ListOutputResponse response; if (wait_for_ready_) { context.set_wait_for_ready(true); context.set_deadline(std::chrono::system_clock::now() + deadline_); } grpc::Status status = m_stub->GetOutputs(&context, request, &response); if (!status.ok()) return std::vector(); for (int i = 0; i < response.outputs_size(); i++) { ::agl_shell_ipc::OutputResponse rresponse = response.outputs(i); v.push_back(rresponse.name()); } return v; }