| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| |
| public struct TApplicationError : TError { |
| public enum Code : TErrorCode { |
| case unknown |
| case unknownMethod(methodName: String?) |
| case invalidMessageType |
| case wrongMethodName(methodName: String?) |
| case badSequenceId |
| case missingResult(methodName: String?) |
| case internalError |
| case protocolError |
| case invalidTransform |
| case invalidProtocol |
| case unsupportedClientType |
| |
| |
| /// Initialize a TApplicationError with a Thrift error code |
| /// Normally this would be achieved with RawRepresentable however |
| /// by doing this we can allow for associated properties on enum cases for |
| /// case specific context data in a Swifty, type-safe manner. |
| /// |
| /// - parameter thriftErrorCode: Integer TApplicationError(exception) error code. |
| /// Default to 0 (.unknown) |
| public init(thriftErrorCode: Int) { |
| switch thriftErrorCode { |
| case 1: self = .unknownMethod(methodName: nil) |
| case 2: self = .invalidMessageType |
| case 3: self = .wrongMethodName(methodName: nil) |
| case 4: self = .badSequenceId |
| case 5: self = .missingResult(methodName: nil) |
| case 6: self = .internalError |
| case 7: self = .protocolError |
| case 8: self = .invalidProtocol |
| case 9: self = .invalidTransform |
| case 10: self = .unsupportedClientType |
| default: self = .unknown |
| } |
| } |
| public var thriftErrorCode: Int { |
| switch self { |
| case .unknown: return 0 |
| case .unknownMethod: return 1 |
| case .invalidMessageType: return 2 |
| case .wrongMethodName: return 3 |
| case .badSequenceId: return 4 |
| case .missingResult: return 5 |
| case .internalError: return 6 |
| case .protocolError: return 7 |
| case .invalidProtocol: return 8 |
| case .invalidTransform: return 9 |
| case .unsupportedClientType: return 10 |
| } |
| } |
| |
| public var description: String { |
| /// Output "for #methodName" if method is not nil else empty |
| let methodUnwrap: (String?) -> String = { method in |
| return "\(method == nil ? "" : " for \(method ?? "")")" |
| } |
| switch self { |
| case .unknown: return "Unknown TApplicationError" |
| case .unknownMethod(let method): return "Unknown Method\(methodUnwrap(method))" |
| case .invalidMessageType: return "Invalid Message Type" |
| case .wrongMethodName(let method): return "Wrong Method Name\(methodUnwrap(method))" |
| case .badSequenceId: return "Bad Sequence ID" |
| case .missingResult(let method): return "Missing Result\(methodUnwrap(method))" |
| case .internalError: return "Internal Error" |
| case .protocolError: return "Protocol Error" |
| case .invalidProtocol: return "Invalid Protocol" |
| case .invalidTransform: return "Invalid Transform" |
| case .unsupportedClientType: return "Unsupported Client Type" |
| } |
| } |
| } |
| |
| public init() { } |
| |
| public init(thriftErrorCode code: Int, message: String? = nil) { |
| self.error = Code(thriftErrorCode: code) |
| self.message = message |
| } |
| |
| public var error: Code = .unknown |
| public var message: String? = nil |
| public static var defaultCase: Code { return .unknown } |
| } |
| |
| extension TApplicationError : TSerializable { |
| public static var thriftType: TType { return .struct } |
| |
| public static func read(from proto: TProtocol) throws -> TApplicationError { |
| var errorCode: Int = 0 |
| var message: String? = nil |
| _ = try proto.readStructBegin() |
| fields: while true { |
| let (_, fieldType, fieldID) = try proto.readFieldBegin() |
| |
| switch (fieldID, fieldType) { |
| case (_, .stop): |
| break fields |
| case (1, .string): |
| message = try proto.read() |
| case (2, .i32): |
| errorCode = Int(try proto.read() as Int32) |
| |
| case let (_, unknownType): |
| try proto.skip(type: unknownType) |
| } |
| |
| try proto.readFieldEnd() |
| } |
| try proto.readStructEnd() |
| return TApplicationError(thriftErrorCode: errorCode, message: message) |
| } |
| |
| public func write(to proto: TProtocol) throws { |
| try proto.writeStructBegin(name: "TApplicationException") |
| |
| try proto.writeFieldBegin(name: "message", type: .string, fieldID: 1) |
| try proto.write(message ?? "") |
| try proto.writeFieldEnd() |
| |
| try proto.writeFieldBegin(name: "type", type: .i32, fieldID: 2) |
| let val = Int32(error.thriftErrorCode) |
| try proto.write(val) |
| try proto.writeFieldEnd() |
| try proto.writeFieldStop() |
| try proto.writeStructEnd() |
| } |
| } |
| |
| extension TApplicationError: Hashable { |
| public func hash(into hasher: inout Hasher) { |
| hasher.combine(error.thriftErrorCode) |
| hasher.combine(message) |
| } |
| } |
| |
| public func ==(lhs: TApplicationError, rhs: TApplicationError) -> Bool { |
| return lhs.error.thriftErrorCode == rhs.error.thriftErrorCode && lhs.message == rhs.message |
| } |