1 /* 2 * Copyright (C) 2021 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 // Wraps the transport layer of RPC. Implementation uses TLS. 18 19 #pragma once 20 21 #include <binder/RpcAuth.h> 22 #include <binder/RpcCertificateVerifier.h> 23 #include <binder/RpcTransport.h> 24 25 namespace android { 26 27 // RpcTransportCtxFactory with TLS enabled with self-signed certificate. 28 class RpcTransportCtxFactoryTls : public RpcTransportCtxFactory { 29 public: 30 static std::unique_ptr<RpcTransportCtxFactory> make(std::shared_ptr<RpcCertificateVerifier>, 31 std::unique_ptr<RpcAuth>); 32 33 std::unique_ptr<RpcTransportCtx> newServerCtx() const override; 34 std::unique_ptr<RpcTransportCtx> newClientCtx() const override; 35 const char* toCString() const override; 36 37 private: RpcTransportCtxFactoryTls(std::shared_ptr<RpcCertificateVerifier> verifier,std::unique_ptr<RpcAuth> auth)38 RpcTransportCtxFactoryTls(std::shared_ptr<RpcCertificateVerifier> verifier, 39 std::unique_ptr<RpcAuth> auth) 40 : mCertVerifier(std::move(verifier)), mAuth(std::move(auth)){}; 41 42 std::shared_ptr<RpcCertificateVerifier> mCertVerifier; 43 std::unique_ptr<RpcAuth> mAuth; 44 }; 45 46 } // namespace android 47