xref: /aosp_15_r20/external/webrtc/sdk/objc/api/peerconnection/RTCCertificate.mm (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker/*
2*d9f75844SAndroid Build Coastguard Worker *  Copyright 2018 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker *
4*d9f75844SAndroid Build Coastguard Worker *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker */
10*d9f75844SAndroid Build Coastguard Worker
11*d9f75844SAndroid Build Coastguard Worker#import "RTCCertificate.h"
12*d9f75844SAndroid Build Coastguard Worker
13*d9f75844SAndroid Build Coastguard Worker#import "base/RTCLogging.h"
14*d9f75844SAndroid Build Coastguard Worker
15*d9f75844SAndroid Build Coastguard Worker#include "rtc_base/logging.h"
16*d9f75844SAndroid Build Coastguard Worker#include "rtc_base/rtc_certificate_generator.h"
17*d9f75844SAndroid Build Coastguard Worker#include "rtc_base/ssl_identity.h"
18*d9f75844SAndroid Build Coastguard Worker
19*d9f75844SAndroid Build Coastguard Worker@implementation RTC_OBJC_TYPE (RTCCertificate)
20*d9f75844SAndroid Build Coastguard Worker
21*d9f75844SAndroid Build Coastguard Worker@synthesize private_key = _private_key;
22*d9f75844SAndroid Build Coastguard Worker@synthesize certificate = _certificate;
23*d9f75844SAndroid Build Coastguard Worker
24*d9f75844SAndroid Build Coastguard Worker- (id)copyWithZone:(NSZone *)zone {
25*d9f75844SAndroid Build Coastguard Worker  id copy = [[[self class] alloc] initWithPrivateKey:[self.private_key copyWithZone:zone]
26*d9f75844SAndroid Build Coastguard Worker                                         certificate:[self.certificate copyWithZone:zone]];
27*d9f75844SAndroid Build Coastguard Worker  return copy;
28*d9f75844SAndroid Build Coastguard Worker}
29*d9f75844SAndroid Build Coastguard Worker
30*d9f75844SAndroid Build Coastguard Worker- (instancetype)initWithPrivateKey:(NSString *)private_key certificate:(NSString *)certificate {
31*d9f75844SAndroid Build Coastguard Worker  if (self = [super init]) {
32*d9f75844SAndroid Build Coastguard Worker    _private_key = [private_key copy];
33*d9f75844SAndroid Build Coastguard Worker    _certificate = [certificate copy];
34*d9f75844SAndroid Build Coastguard Worker  }
35*d9f75844SAndroid Build Coastguard Worker  return self;
36*d9f75844SAndroid Build Coastguard Worker}
37*d9f75844SAndroid Build Coastguard Worker
38*d9f75844SAndroid Build Coastguard Worker+ (nullable RTC_OBJC_TYPE(RTCCertificate) *)generateCertificateWithParams:(NSDictionary *)params {
39*d9f75844SAndroid Build Coastguard Worker  rtc::KeyType keyType = rtc::KT_ECDSA;
40*d9f75844SAndroid Build Coastguard Worker  NSString *keyTypeString = [params valueForKey:@"name"];
41*d9f75844SAndroid Build Coastguard Worker  if (keyTypeString && [keyTypeString isEqualToString:@"RSASSA-PKCS1-v1_5"]) {
42*d9f75844SAndroid Build Coastguard Worker    keyType = rtc::KT_RSA;
43*d9f75844SAndroid Build Coastguard Worker  }
44*d9f75844SAndroid Build Coastguard Worker
45*d9f75844SAndroid Build Coastguard Worker  NSNumber *expires = [params valueForKey:@"expires"];
46*d9f75844SAndroid Build Coastguard Worker  rtc::scoped_refptr<rtc::RTCCertificate> cc_certificate = nullptr;
47*d9f75844SAndroid Build Coastguard Worker  if (expires != nil) {
48*d9f75844SAndroid Build Coastguard Worker    uint64_t expirationTimestamp = [expires unsignedLongLongValue];
49*d9f75844SAndroid Build Coastguard Worker    cc_certificate = rtc::RTCCertificateGenerator::GenerateCertificate(rtc::KeyParams(keyType),
50*d9f75844SAndroid Build Coastguard Worker                                                                       expirationTimestamp);
51*d9f75844SAndroid Build Coastguard Worker  } else {
52*d9f75844SAndroid Build Coastguard Worker    cc_certificate =
53*d9f75844SAndroid Build Coastguard Worker        rtc::RTCCertificateGenerator::GenerateCertificate(rtc::KeyParams(keyType), absl::nullopt);
54*d9f75844SAndroid Build Coastguard Worker  }
55*d9f75844SAndroid Build Coastguard Worker  if (!cc_certificate) {
56*d9f75844SAndroid Build Coastguard Worker    RTCLogError(@"Failed to generate certificate.");
57*d9f75844SAndroid Build Coastguard Worker    return nullptr;
58*d9f75844SAndroid Build Coastguard Worker  }
59*d9f75844SAndroid Build Coastguard Worker  // grab PEMs and create an NS RTCCerticicate
60*d9f75844SAndroid Build Coastguard Worker  rtc::RTCCertificatePEM pem = cc_certificate->ToPEM();
61*d9f75844SAndroid Build Coastguard Worker  std::string pem_private_key = pem.private_key();
62*d9f75844SAndroid Build Coastguard Worker  std::string pem_certificate = pem.certificate();
63*d9f75844SAndroid Build Coastguard Worker  RTC_LOG(LS_INFO) << "CERT PEM ";
64*d9f75844SAndroid Build Coastguard Worker  RTC_LOG(LS_INFO) << pem_certificate;
65*d9f75844SAndroid Build Coastguard Worker
66*d9f75844SAndroid Build Coastguard Worker  RTC_OBJC_TYPE(RTCCertificate) *cert =
67*d9f75844SAndroid Build Coastguard Worker      [[RTC_OBJC_TYPE(RTCCertificate) alloc] initWithPrivateKey:@(pem_private_key.c_str())
68*d9f75844SAndroid Build Coastguard Worker                                                    certificate:@(pem_certificate.c_str())];
69*d9f75844SAndroid Build Coastguard Worker  return cert;
70*d9f75844SAndroid Build Coastguard Worker}
71*d9f75844SAndroid Build Coastguard Worker
72*d9f75844SAndroid Build Coastguard Worker@end
73