1*cc02d7e2SAndroid Build Coastguard Worker /* 2*cc02d7e2SAndroid Build Coastguard Worker * 3*cc02d7e2SAndroid Build Coastguard Worker * Copyright 2019 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker * 5*cc02d7e2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker * You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker * 9*cc02d7e2SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker * 11*cc02d7e2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker * limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker * 17*cc02d7e2SAndroid Build Coastguard Worker */ 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Worker // The interface for a transport implementation 20*cc02d7e2SAndroid Build Coastguard Worker 21*cc02d7e2SAndroid Build Coastguard Worker #import "GRPCInterceptor.h" 22*cc02d7e2SAndroid Build Coastguard Worker 23*cc02d7e2SAndroid Build Coastguard Worker NS_ASSUME_NONNULL_BEGIN 24*cc02d7e2SAndroid Build Coastguard Worker 25*cc02d7e2SAndroid Build Coastguard Worker #pragma mark Transport ID 26*cc02d7e2SAndroid Build Coastguard Worker 27*cc02d7e2SAndroid Build Coastguard Worker /** 28*cc02d7e2SAndroid Build Coastguard Worker * The default transport implementations available in gRPC. These implementations will be provided 29*cc02d7e2SAndroid Build Coastguard Worker * by gRPC by default unless explicitly excluded by the build system. 30*cc02d7e2SAndroid Build Coastguard Worker */ 31*cc02d7e2SAndroid Build Coastguard Worker extern const struct GRPCDefaultTransportImplList { 32*cc02d7e2SAndroid Build Coastguard Worker const GRPCTransportID core_secure; 33*cc02d7e2SAndroid Build Coastguard Worker const GRPCTransportID core_insecure; 34*cc02d7e2SAndroid Build Coastguard Worker } GRPCDefaultTransportImplList; 35*cc02d7e2SAndroid Build Coastguard Worker 36*cc02d7e2SAndroid Build Coastguard Worker /** Returns whether two transport id's are identical. */ 37*cc02d7e2SAndroid Build Coastguard Worker BOOL TransportIDIsEqual(GRPCTransportID lhs, GRPCTransportID rhs); 38*cc02d7e2SAndroid Build Coastguard Worker 39*cc02d7e2SAndroid Build Coastguard Worker /** Returns the hash value of a transport id. */ 40*cc02d7e2SAndroid Build Coastguard Worker NSUInteger TransportIDHash(GRPCTransportID); 41*cc02d7e2SAndroid Build Coastguard Worker 42*cc02d7e2SAndroid Build Coastguard Worker #pragma mark Transport and factory 43*cc02d7e2SAndroid Build Coastguard Worker 44*cc02d7e2SAndroid Build Coastguard Worker @protocol GRPCInterceptorInterface; 45*cc02d7e2SAndroid Build Coastguard Worker @protocol GRPCResponseHandler; 46*cc02d7e2SAndroid Build Coastguard Worker @class GRPCTransportManager; 47*cc02d7e2SAndroid Build Coastguard Worker @class GRPCRequestOptions; 48*cc02d7e2SAndroid Build Coastguard Worker @class GRPCCallOptions; 49*cc02d7e2SAndroid Build Coastguard Worker @class GRPCTransport; 50*cc02d7e2SAndroid Build Coastguard Worker 51*cc02d7e2SAndroid Build Coastguard Worker /** The factory to create a transport. */ 52*cc02d7e2SAndroid Build Coastguard Worker @protocol GRPCTransportFactory <NSObject> 53*cc02d7e2SAndroid Build Coastguard Worker 54*cc02d7e2SAndroid Build Coastguard Worker /** Create a transport implementation instance. */ 55*cc02d7e2SAndroid Build Coastguard Worker - (GRPCTransport *)createTransportWithManager:(GRPCTransportManager *)transportManager; 56*cc02d7e2SAndroid Build Coastguard Worker 57*cc02d7e2SAndroid Build Coastguard Worker /** Get a list of factories for transport inteceptors. */ 58*cc02d7e2SAndroid Build Coastguard Worker @property(nonatomic, readonly) NSArray<id<GRPCInterceptorFactory>> *transportInterceptorFactories; 59*cc02d7e2SAndroid Build Coastguard Worker 60*cc02d7e2SAndroid Build Coastguard Worker @end 61*cc02d7e2SAndroid Build Coastguard Worker 62*cc02d7e2SAndroid Build Coastguard Worker /** The registry of transport implementations. */ 63*cc02d7e2SAndroid Build Coastguard Worker @interface GRPCTransportRegistry : NSObject 64*cc02d7e2SAndroid Build Coastguard Worker 65*cc02d7e2SAndroid Build Coastguard Worker + (instancetype)sharedInstance; 66*cc02d7e2SAndroid Build Coastguard Worker 67*cc02d7e2SAndroid Build Coastguard Worker /** 68*cc02d7e2SAndroid Build Coastguard Worker * Register a transport implementation with the registry. All transport implementations to be used 69*cc02d7e2SAndroid Build Coastguard Worker * in a process must register with the registry on process start-up in its +load: class method. 70*cc02d7e2SAndroid Build Coastguard Worker * Parameter \p transportID is the identifier of the implementation, and \p factory is the factory 71*cc02d7e2SAndroid Build Coastguard Worker * object to create the corresponding transport instance. 72*cc02d7e2SAndroid Build Coastguard Worker */ 73*cc02d7e2SAndroid Build Coastguard Worker - (void)registerTransportWithID:(GRPCTransportID)transportID 74*cc02d7e2SAndroid Build Coastguard Worker factory:(id<GRPCTransportFactory>)factory; 75*cc02d7e2SAndroid Build Coastguard Worker 76*cc02d7e2SAndroid Build Coastguard Worker @end 77*cc02d7e2SAndroid Build Coastguard Worker 78*cc02d7e2SAndroid Build Coastguard Worker /** 79*cc02d7e2SAndroid Build Coastguard Worker * Base class for transport implementations. All transport implementation should inherit from this 80*cc02d7e2SAndroid Build Coastguard Worker * class. 81*cc02d7e2SAndroid Build Coastguard Worker */ 82*cc02d7e2SAndroid Build Coastguard Worker @interface GRPCTransport : NSObject <GRPCInterceptorInterface> 83*cc02d7e2SAndroid Build Coastguard Worker 84*cc02d7e2SAndroid Build Coastguard Worker @end 85*cc02d7e2SAndroid Build Coastguard Worker 86*cc02d7e2SAndroid Build Coastguard Worker NS_ASSUME_NONNULL_END 87