1*e7b1675dSTing-Kang Chang // Copyright 2020 Google LLC
2*e7b1675dSTing-Kang Chang //
3*e7b1675dSTing-Kang Chang // Licensed under the Apache License, Version 2.0 (the "License");
4*e7b1675dSTing-Kang Chang // you may not use this file except in compliance with the License.
5*e7b1675dSTing-Kang Chang // You may obtain a copy of the License at
6*e7b1675dSTing-Kang Chang //
7*e7b1675dSTing-Kang Chang // http://www.apache.org/licenses/LICENSE-2.0
8*e7b1675dSTing-Kang Chang //
9*e7b1675dSTing-Kang Chang // Unless required by applicable law or agreed to in writing, software
10*e7b1675dSTing-Kang Chang // distributed under the License is distributed on an "AS IS" BASIS,
11*e7b1675dSTing-Kang Chang // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*e7b1675dSTing-Kang Chang // See the License for the specific language governing permissions and
13*e7b1675dSTing-Kang Chang // limitations under the License.
14*e7b1675dSTing-Kang Chang //
15*e7b1675dSTing-Kang Chang ///////////////////////////////////////////////////////////////////////////////
16*e7b1675dSTing-Kang Chang
17*e7b1675dSTing-Kang Chang // Implementation of a Hybrid encryption service
18*e7b1675dSTing-Kang Chang #include "hybrid_impl.h"
19*e7b1675dSTing-Kang Chang
20*e7b1675dSTing-Kang Chang #include <memory>
21*e7b1675dSTing-Kang Chang #include <string>
22*e7b1675dSTing-Kang Chang #include <utility>
23*e7b1675dSTing-Kang Chang
24*e7b1675dSTing-Kang Chang #include "tink/hybrid_decrypt.h"
25*e7b1675dSTing-Kang Chang #include "tink/hybrid_encrypt.h"
26*e7b1675dSTing-Kang Chang #include "tink/util/statusor.h"
27*e7b1675dSTing-Kang Chang #include "create.h"
28*e7b1675dSTing-Kang Chang #include "proto/testing_api.grpc.pb.h"
29*e7b1675dSTing-Kang Chang
30*e7b1675dSTing-Kang Chang namespace tink_testing_api {
31*e7b1675dSTing-Kang Chang
32*e7b1675dSTing-Kang Chang using ::crypto::tink::util::StatusOr;
33*e7b1675dSTing-Kang Chang
CreateHybridEncrypt(grpc::ServerContext * context,const CreationRequest * request,CreationResponse * response)34*e7b1675dSTing-Kang Chang ::grpc::Status HybridImpl::CreateHybridEncrypt(grpc::ServerContext* context,
35*e7b1675dSTing-Kang Chang const CreationRequest* request,
36*e7b1675dSTing-Kang Chang CreationResponse* response) {
37*e7b1675dSTing-Kang Chang return CreatePrimitiveForRpc<crypto::tink::HybridEncrypt>(request, response);
38*e7b1675dSTing-Kang Chang }
39*e7b1675dSTing-Kang Chang
CreateHybridDecrypt(grpc::ServerContext * context,const CreationRequest * request,CreationResponse * response)40*e7b1675dSTing-Kang Chang ::grpc::Status HybridImpl::CreateHybridDecrypt(grpc::ServerContext* context,
41*e7b1675dSTing-Kang Chang const CreationRequest* request,
42*e7b1675dSTing-Kang Chang CreationResponse* response) {
43*e7b1675dSTing-Kang Chang return CreatePrimitiveForRpc<crypto::tink::HybridDecrypt>(request, response);
44*e7b1675dSTing-Kang Chang }
45*e7b1675dSTing-Kang Chang
Encrypt(grpc::ServerContext * context,const HybridEncryptRequest * request,HybridEncryptResponse * response)46*e7b1675dSTing-Kang Chang ::grpc::Status HybridImpl::Encrypt(grpc::ServerContext* context,
47*e7b1675dSTing-Kang Chang const HybridEncryptRequest* request,
48*e7b1675dSTing-Kang Chang HybridEncryptResponse* response) {
49*e7b1675dSTing-Kang Chang StatusOr<std::unique_ptr<crypto::tink::HybridEncrypt>> hybrid_encrypt_result =
50*e7b1675dSTing-Kang Chang PrimitiveFromSerializedBinaryProtoKeyset<crypto::tink::HybridEncrypt>(
51*e7b1675dSTing-Kang Chang request->public_annotated_keyset());
52*e7b1675dSTing-Kang Chang if (!hybrid_encrypt_result.ok()) {
53*e7b1675dSTing-Kang Chang response->set_err(std::string(hybrid_encrypt_result.status().message()));
54*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
55*e7b1675dSTing-Kang Chang }
56*e7b1675dSTing-Kang Chang auto enc_result = hybrid_encrypt_result.value()->Encrypt(
57*e7b1675dSTing-Kang Chang request->plaintext(), request->context_info());
58*e7b1675dSTing-Kang Chang if (!enc_result.ok()) {
59*e7b1675dSTing-Kang Chang response->set_err(std::string(enc_result.status().message()));
60*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
61*e7b1675dSTing-Kang Chang }
62*e7b1675dSTing-Kang Chang response->set_ciphertext(enc_result.value());
63*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
64*e7b1675dSTing-Kang Chang }
65*e7b1675dSTing-Kang Chang
66*e7b1675dSTing-Kang Chang // Decrypts a ciphertext
Decrypt(grpc::ServerContext * context,const HybridDecryptRequest * request,HybridDecryptResponse * response)67*e7b1675dSTing-Kang Chang ::grpc::Status HybridImpl::Decrypt(grpc::ServerContext* context,
68*e7b1675dSTing-Kang Chang const HybridDecryptRequest* request,
69*e7b1675dSTing-Kang Chang HybridDecryptResponse* response) {
70*e7b1675dSTing-Kang Chang StatusOr<std::unique_ptr<crypto::tink::HybridDecrypt>> hybrid_decrypt_result =
71*e7b1675dSTing-Kang Chang PrimitiveFromSerializedBinaryProtoKeyset<crypto::tink::HybridDecrypt>(
72*e7b1675dSTing-Kang Chang request->private_annotated_keyset());
73*e7b1675dSTing-Kang Chang if (!hybrid_decrypt_result.ok()) {
74*e7b1675dSTing-Kang Chang response->set_err(std::string(hybrid_decrypt_result.status().message()));
75*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
76*e7b1675dSTing-Kang Chang }
77*e7b1675dSTing-Kang Chang auto dec_result = hybrid_decrypt_result.value()->Decrypt(
78*e7b1675dSTing-Kang Chang request->ciphertext(), request->context_info());
79*e7b1675dSTing-Kang Chang if (!dec_result.ok()) {
80*e7b1675dSTing-Kang Chang response->set_err(std::string(dec_result.status().message()));
81*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
82*e7b1675dSTing-Kang Chang }
83*e7b1675dSTing-Kang Chang response->set_plaintext(dec_result.value());
84*e7b1675dSTing-Kang Chang return ::grpc::Status::OK;
85*e7b1675dSTing-Kang Chang }
86*e7b1675dSTing-Kang Chang
87*e7b1675dSTing-Kang Chang } // namespace tink_testing_api
88