From 5b2e81f9a3b81a9d07225236a57b22810d77fa9e Mon Sep 17 00:00:00 2001 From: Pat Nakajima Date: Tue, 6 Feb 2024 16:34:19 -0600 Subject: [PATCH] Improve error messages (#240) * let errors be more descriptive * remove test * bump the podspec --- Sources/XMTPiOS/ApiClient.swift | 15 ++++++++++++++- Sources/XMTPiOS/Client.swift | 9 ++++++++- .../Codecs/RemoteAttachmentCodec.swift | 19 ++++++++++++++++++- Sources/XMTPiOS/Conversations.swift | 13 ++++++++++++- Sources/XMTPiOS/Messages/PrivateKey.swift | 13 ++++++++++++- .../XMTPiOS/Messages/SealedInvitation.swift | 6 +++++- Sources/XMTPiOS/Messages/Signature.swift | 6 +++++- XMTP.podspec | 2 +- .../xcshareddata/swiftpm/Package.resolved | 4 ++-- 9 files changed, 77 insertions(+), 10 deletions(-) diff --git a/Sources/XMTPiOS/ApiClient.swift b/Sources/XMTPiOS/ApiClient.swift index d85692fd..e4411b50 100644 --- a/Sources/XMTPiOS/ApiClient.swift +++ b/Sources/XMTPiOS/ApiClient.swift @@ -17,11 +17,24 @@ public typealias QueryRequest = Xmtp_MessageApi_V1_QueryRequest public typealias QueryResponse = Xmtp_MessageApi_V1_QueryResponse public typealias SubscribeRequest = Xmtp_MessageApi_V1_SubscribeRequest -public enum ApiClientError: Error { +public enum ApiClientError: Error, CustomStringConvertible { case batchQueryError(String) case queryError(String) case publishError(String) case subscribeError(String) + + public var description: String { + switch self { + case .batchQueryError(let err): + return "ApiClientError.batchQueryError: \(err)" + case .queryError(let err): + return "ApiClientError.queryError: \(err)" + case .publishError(let err): + return "ApiClientError.publishError: \(err)" + case .subscribeError(let err): + return "ApiClientError.subscribeError: \(err)" + } + } } protocol ApiClient: Sendable { diff --git a/Sources/XMTPiOS/Client.swift b/Sources/XMTPiOS/Client.swift index 7e6199a8..6822721a 100644 --- a/Sources/XMTPiOS/Client.swift +++ b/Sources/XMTPiOS/Client.swift @@ -11,8 +11,15 @@ import web3 public typealias PreEventCallback = () async throws -> Void -public enum ClientError: Error { +public enum ClientError: Error, CustomStringConvertible { case creationError(String) + + public var description: String { + switch self { + case .creationError(let err): + return "ClientError.creationError: \(err)" + } + } } /// Specify configuration options for creating a ``Client``. diff --git a/Sources/XMTPiOS/Codecs/RemoteAttachmentCodec.swift b/Sources/XMTPiOS/Codecs/RemoteAttachmentCodec.swift index 62af9969..32c1b103 100644 --- a/Sources/XMTPiOS/Codecs/RemoteAttachmentCodec.swift +++ b/Sources/XMTPiOS/Codecs/RemoteAttachmentCodec.swift @@ -11,8 +11,25 @@ import web3 public let ContentTypeRemoteAttachment = ContentTypeID(authorityID: "xmtp.org", typeID: "remoteStaticAttachment", versionMajor: 1, versionMinor: 0) -public enum RemoteAttachmentError: Error { +public enum RemoteAttachmentError: Error, CustomStringConvertible { case invalidURL, v1NotSupported, invalidParameters(String), invalidDigest(String), invalidScheme(String), payloadNotFound + + public var description: String { + switch self { + case .invalidURL: + return "RemoteAttachmentError.invalidURL" + case .v1NotSupported: + return "RemoteAttachmentError.v1NotSupported" + case .invalidParameters(let string): + return "RemoteAttachmentError.invalidParameters: \(string)" + case .invalidDigest(let string): + return "RemoteAttachmentError.invalidDigest: \(string)" + case .invalidScheme(let string): + return "RemoteAttachmentError.invalidScheme: \(string)" + case .payloadNotFound: + return "RemoteAttachmentError.payloadNotFound" + } + } } protocol RemoteContentFetcher { diff --git a/Sources/XMTPiOS/Conversations.swift b/Sources/XMTPiOS/Conversations.swift index b6e2072a..12aba501 100644 --- a/Sources/XMTPiOS/Conversations.swift +++ b/Sources/XMTPiOS/Conversations.swift @@ -1,7 +1,18 @@ import Foundation -public enum ConversationError: Error { +public enum ConversationError: Error, CustomStringConvertible { case recipientNotOnNetwork, recipientIsSender, v1NotSupported(String) + + public var description: String { + switch self { + case .recipientIsSender: + return "ConversationError.recipientIsSender: Recipient cannot be sender" + case .recipientNotOnNetwork: + return "ConversationError.recipientNotOnNetwork: Recipient is not on network" + case .v1NotSupported(let str): + return "ConversationError.v1NotSupported: V1 does not support: \(str)" + } + } } /// Handles listing and creating Conversations. diff --git a/Sources/XMTPiOS/Messages/PrivateKey.swift b/Sources/XMTPiOS/Messages/PrivateKey.swift index 4e2f4186..8d862dd3 100644 --- a/Sources/XMTPiOS/Messages/PrivateKey.swift +++ b/Sources/XMTPiOS/Messages/PrivateKey.swift @@ -13,8 +13,19 @@ import CryptoKit /// to create a ``Client``. public typealias PrivateKey = Xmtp_MessageContents_PrivateKey -enum PrivateKeyError: Error { +enum PrivateKeyError: Error, CustomStringConvertible { case invalidSignatureText, invalidPrefix, invalidSignature + + var description: String { + switch self { + case .invalidSignatureText: + return "PrivateKeyError.invalidSignatureText" + case .invalidPrefix: + return "PrivateKeyError.invalidPrefix" + case .invalidSignature: + return "PrivateKeyError.invalidSignature" + } + } } extension PrivateKey: SigningKey { diff --git a/Sources/XMTPiOS/Messages/SealedInvitation.swift b/Sources/XMTPiOS/Messages/SealedInvitation.swift index 2d5cae01..920ee2fc 100644 --- a/Sources/XMTPiOS/Messages/SealedInvitation.swift +++ b/Sources/XMTPiOS/Messages/SealedInvitation.swift @@ -10,8 +10,12 @@ import Foundation typealias SealedInvitation = Xmtp_MessageContents_SealedInvitation -enum SealedInvitationError: Error { +enum SealedInvitationError: Error, CustomStringConvertible { case noSignature + + var description: String { + "SealedInvitationError.noSignature" + } } extension SealedInvitation { diff --git a/Sources/XMTPiOS/Messages/Signature.swift b/Sources/XMTPiOS/Messages/Signature.swift index 01bf381f..e2964e36 100644 --- a/Sources/XMTPiOS/Messages/Signature.swift +++ b/Sources/XMTPiOS/Messages/Signature.swift @@ -11,8 +11,12 @@ import LibXMTP /// Represents a secp256k1 compact recoverable signature. public typealias Signature = Xmtp_MessageContents_Signature -enum SignatureError: Error { +enum SignatureError: Error, CustomStringConvertible { case invalidMessage + + var description: String { + return "SignatureError.invalidMessage" + } } public extension Signature { diff --git a/XMTP.podspec b/XMTP.podspec index bf9cb3e9..cb5e0eae 100644 --- a/XMTP.podspec +++ b/XMTP.podspec @@ -16,7 +16,7 @@ Pod::Spec.new do |spec| # spec.name = "XMTP" - spec.version = "0.8.0" + spec.version = "0.8.1" spec.summary = "XMTP SDK Cocoapod" # This description is used to generate tags and improve search results. diff --git a/XMTPiOSExample/XMTPiOSExample.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved b/XMTPiOSExample/XMTPiOSExample.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved index 30e11be1..4ce86ce4 100644 --- a/XMTPiOSExample/XMTPiOSExample.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved +++ b/XMTPiOSExample/XMTPiOSExample.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved @@ -51,7 +51,7 @@ "location" : "https://github.com/kishikawakatsumi/KeychainAccess", "state" : { "branch" : "master", - "revision" : "ecb18d8ce4d88277cc4fb103973352d91e18c535" + "revision" : "e0c7eebc5a4465a3c4680764f26b7a61f567cdaf" } }, { @@ -231,7 +231,7 @@ "location" : "https://github.com/WalletConnect/WalletConnectSwiftV2", "state" : { "branch" : "main", - "revision" : "13446a81e678e8eddc6ab506e85c522df0163f1f" + "revision" : "f2db5e796976e6294b40da01c443f39a16b4732a" } }, {