2
0

TLSVerificationHandler.swift 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright 2019, gRPC Authors All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. import Foundation
  17. import Logging
  18. import NIO
  19. import NIOSSL
  20. import NIOTLS
  21. /// Application protocol identifiers for ALPN.
  22. internal enum GRPCApplicationProtocolIdentifier: String, CaseIterable {
  23. // This is not in the IANA ALPN protocol ID registry, but may be used by servers to indicate that
  24. // they serve only gRPC traffic. It is part of the gRPC core implementation.
  25. case gRPC = "grpc-exp"
  26. case h2
  27. }
  28. internal class TLSVerificationHandler: ChannelInboundHandler, RemovableChannelHandler {
  29. typealias InboundIn = Any
  30. private let logger: Logger
  31. init(logger: Logger) {
  32. self.logger = logger
  33. }
  34. func userInboundEventTriggered(context: ChannelHandlerContext, event: Any) {
  35. if let tlsEvent = event as? TLSUserEvent {
  36. switch tlsEvent {
  37. case let .handshakeCompleted(negotiatedProtocol: .some(`protocol`)):
  38. self.logger.debug("TLS handshake completed, negotiated protocol: \(`protocol`)")
  39. case .handshakeCompleted(negotiatedProtocol: nil):
  40. self.logger.debug("TLS handshake completed, no protocol negotiated")
  41. case .shutdownCompleted:
  42. ()
  43. }
  44. }
  45. context.fireUserInboundEventTriggered(event)
  46. }
  47. }