
The JS API supports two operations which have never been implemented in the iOS counterpart: - generate a new certificate - use this certificate when creating a new PeerConnection Both functions are illustrated in the generateCertificate example code: - https://developer.mozilla.org/en-US/docs/Web/API/RTCPeerConnection/generateCertificate Currently, on iOS, a new certificate is automatically generated for every PeerConnection with no programmatic way to set a specific certificate. Work sponsored by |pipe| Bug: webrtc:9498 Change-Id: Ic1936c3de8b8bd18aef67c784727b72f90e7157c Reviewed-on: https://webrtc-review.googlesource.com/87303 Commit-Queue: Steve Anton <steveanton@webrtc.org> Reviewed-by: Kári Helgason <kthelgason@webrtc.org> Reviewed-by: Steve Anton <steveanton@webrtc.org> Cr-Commit-Position: refs/heads/master@{#24276}
45 lines
1.3 KiB
Objective-C
45 lines
1.3 KiB
Objective-C
/*
|
|
* Copyright 2018 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
#import <WebRTC/RTCMacros.h>
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
RTC_EXPORT
|
|
@interface RTCCertificate : NSObject <NSCopying>
|
|
|
|
/** Private key in PEM. */
|
|
@property(nonatomic, readonly, copy) NSString *private_key;
|
|
|
|
/** Public key in an x509 cert encoded in PEM. */
|
|
@property(nonatomic, readonly, copy) NSString *certificate;
|
|
|
|
/**
|
|
* Initialize an RTCCertificate with PEM strings for private_key and certificate.
|
|
*/
|
|
- (instancetype)initWithPrivateKey:(NSString *)private_key
|
|
certificate:(NSString *)certificate NS_DESIGNATED_INITIALIZER;
|
|
|
|
- (instancetype)init NS_UNAVAILABLE;
|
|
|
|
/** Generate a new certificate for 're' use.
|
|
*
|
|
* Optional dictionary of parameters. Defaults to KeyType ECDSA if none are
|
|
* provided.
|
|
* - name: "ECDSA" or "RSASSA-PKCS1-v1_5"
|
|
*/
|
|
+ (nullable RTCCertificate *)generateCertificateWithParams:(NSDictionary *)params;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|