diff options
author | Michael Lumish <mlumish@google.com> | 2015-06-01 08:46:35 -0700 |
---|---|---|
committer | Michael Lumish <mlumish@google.com> | 2015-06-01 08:46:35 -0700 |
commit | ee066371bbc83e3fdc0dd069d191335c32b9b6db (patch) | |
tree | 24cbf25bcdb436415da9084ccb60e3492b39b99b /src | |
parent | 273f80b4757ff34269243eb626f40523df751c13 (diff) | |
parent | f1c368c0680f22667b25f46b3555ab5ce581a809 (diff) |
Merge pull request #1839 from jcanizales/fix-certs-bundle
Fix problem loading certs for tests of library projects
Diffstat (limited to 'src')
-rw-r--r-- | src/objective-c/GRPCClient/private/GRPCSecureChannel.m | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/src/objective-c/GRPCClient/private/GRPCSecureChannel.m b/src/objective-c/GRPCClient/private/GRPCSecureChannel.m index 47bdfe3f28..2cbc6e0f83 100644 --- a/src/objective-c/GRPCClient/private/GRPCSecureChannel.m +++ b/src/objective-c/GRPCClient/private/GRPCSecureChannel.m @@ -38,13 +38,17 @@ @implementation GRPCSecureChannel - (instancetype)initWithHost:(NSString *)host { - // TODO(jcanizales): Load certs only once. - NSURL *certsURL = [[NSBundle mainBundle] URLForResource:@"gRPC.bundle/roots" withExtension:@"pem"]; - NSData *certsData = [NSData dataWithContentsOfURL:certsURL]; - NSString *certsString = [[NSString alloc] initWithData:certsData encoding:NSUTF8StringEncoding]; - - grpc_credentials *credentials = grpc_ssl_credentials_create(certsString.UTF8String, NULL); - return (self = [super initWithChannel:grpc_secure_channel_create(credentials, + static const grpc_credentials *kCredentials; + static dispatch_once_t loading; + dispatch_once(&loading, ^{ + // Do not use NSBundle.mainBundle, as it's nil for tests of library projects. + NSBundle *bundle = [NSBundle bundleForClass:self.class]; + NSString *certsPath = [bundle pathForResource:@"gRPC.bundle/roots" ofType:@"pem"]; + NSData *certsData = [NSData dataWithContentsOfFile:certsPath]; + NSString *certsString = [[NSString alloc] initWithData:certsData encoding:NSUTF8StringEncoding]; + kCredentials = grpc_ssl_credentials_create(certsString.UTF8String, NULL); + }); + return (self = [super initWithChannel:grpc_secure_channel_create(kCredentials, host.UTF8String, NULL)]); } |