diff --git a/dydx/Pods/Local Podspecs/MagicSDK.podspec.json b/dydx/Pods/Local Podspecs/MagicSDK.podspec.json deleted file mode 100644 index 773979e73..000000000 --- a/dydx/Pods/Local Podspecs/MagicSDK.podspec.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "name": "MagicSDK", - "version": "6.2.0", - "summary": "Magic IOS SDK", - "description": "TODO: Add long description of the pod here.", - "homepage": "https://github.com/magiclabs/magic-ios", - "license": { - "type": "MIT", - "file": "LICENSE" - }, - "authors": { - "Jerry Liu": "jerry@magic.link" - }, - "source": { - "git": "https://github.com/magiclabs/magic-ios.git", - "tag": "6.2.0" - }, - "swift_versions": "5.0", - "platforms": { - "ios": "10.0" - }, - "source_files": "Sources/MagicSDK/**/*", - "dependencies": { - "MagicSDK-Web3": [ - "~> 1.0" - ], - "MagicSDK-Web3/ContractABI": [ - "~> 1.0" - ], - "MagicSDK-Web3/PromiseKit": [ - "~> 1.0" - ], - "PromiseKit/CorePromise": [ - "~> 6.15" - ] - }, - "pod_target_xcconfig": { - "EXCLUDED_ARCHS[sdk=iphonesimulator*]": "arm64" - }, - "swift_version": "5.0" -} diff --git a/dydx/Pods/MagicSDK/LICENSE b/dydx/Pods/MagicSDK/LICENSE deleted file mode 100644 index 7335bc897..000000000 --- a/dydx/Pods/MagicSDK/LICENSE +++ /dev/null @@ -1,177 +0,0 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ - - TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION - - 1. Definitions. - - "License" shall mean the terms and conditions for use, reproduction, - and distribution as defined by Sections 1 through 9 of this document. - - "Licensor" shall mean the copyright owner or entity authorized by - the copyright owner that is granting the License. - - "Legal Entity" shall mean the union of the acting entity and all - other entities that control, are controlled by, or are under common - control with that entity. For the purposes of this definition, - "control" means (i) the power, direct or indirect, to cause the - direction or management of such entity, whether by contract or - otherwise, or (ii) ownership of fifty percent (50%) or more of the - outstanding shares, or (iii) beneficial ownership of such entity. - - "You" (or "Your") shall mean an individual or Legal Entity - exercising permissions granted by this License. - - "Source" form shall mean the preferred form for making modifications, - including but not limited to software source code, documentation - source, and configuration files. - - "Object" form shall mean any form resulting from mechanical - transformation or translation of a Source form, including but - not limited to compiled object code, generated documentation, - and conversions to other media types. - - "Work" shall mean the work of authorship, whether in Source or - Object form, made available under the License, as indicated by a - copyright notice that is included in or attached to the work - (an example is provided in the Appendix below). - - "Derivative Works" shall mean any work, whether in Source or Object - form, that is based on (or derived from) the Work and for which the - editorial revisions, annotations, elaborations, or other modifications - represent, as a whole, an original work of authorship. For the purposes - of this License, Derivative Works shall not include works that remain - separable from, or merely link (or bind by name) to the interfaces of, - the Work and Derivative Works thereof. - - "Contribution" shall mean any work of authorship, including - the original version of the Work and any modifications or additions - to that Work or Derivative Works thereof, that is intentionally - submitted to Licensor for inclusion in the Work by the copyright owner - or by an individual or Legal Entity authorized to submit on behalf of - the copyright owner. For the purposes of this definition, "submitted" - means any form of electronic, verbal, or written communication sent - to the Licensor or its representatives, including but not limited to - communication on electronic mailing lists, source code control systems, - and issue tracking systems that are managed by, or on behalf of, the - Licensor for the purpose of discussing and improving the Work, but - excluding communication that is conspicuously marked or otherwise - designated in writing by the copyright owner as "Not a Contribution." - - "Contributor" shall mean Licensor and any individual or Legal Entity - on behalf of whom a Contribution has been received by Licensor and - subsequently incorporated within the Work. - - 2. Grant of Copyright License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - copyright license to reproduce, prepare Derivative Works of, - publicly display, publicly perform, sublicense, and distribute the - Work and such Derivative Works in Source or Object form. - - 3. Grant of Patent License. Subject to the terms and conditions of - this License, each Contributor hereby grants to You a perpetual, - worldwide, non-exclusive, no-charge, royalty-free, irrevocable - (except as stated in this section) patent license to make, have made, - use, offer to sell, sell, import, and otherwise transfer the Work, - where such license applies only to those patent claims licensable - by such Contributor that are necessarily infringed by their - Contribution(s) alone or by combination of their Contribution(s) - with the Work to which such Contribution(s) was submitted. If You - institute patent litigation against any entity (including a - cross-claim or counterclaim in a lawsuit) alleging that the Work - or a Contribution incorporated within the Work constitutes direct - or contributory patent infringement, then any patent licenses - granted to You under this License for that Work shall terminate - as of the date such litigation is filed. - - 4. Redistribution. You may reproduce and distribute copies of the - Work or Derivative Works thereof in any medium, with or without - modifications, and in Source or Object form, provided that You - meet the following conditions: - - (a) You must give any other recipients of the Work or - Derivative Works a copy of this License; and - - (b) You must cause any modified files to carry prominent notices - stating that You changed the files; and - - (c) You must retain, in the Source form of any Derivative Works - that You distribute, all copyright, patent, trademark, and - attribution notices from the Source form of the Work, - excluding those notices that do not pertain to any part of - the Derivative Works; and - - (d) If the Work includes a "NOTICE" text file as part of its - distribution, then any Derivative Works that You distribute must - include a readable copy of the attribution notices contained - within such NOTICE file, excluding those notices that do not - pertain to any part of the Derivative Works, in at least one - of the following places: within a NOTICE text file distributed - as part of the Derivative Works; within the Source form or - documentation, if provided along with the Derivative Works; or, - within a display generated by the Derivative Works, if and - wherever such third-party notices normally appear. The contents - of the NOTICE file are for informational purposes only and - do not modify the License. You may add Your own attribution - notices within Derivative Works that You distribute, alongside - or as an addendum to the NOTICE text from the Work, provided - that such additional attribution notices cannot be construed - as modifying the License. - - You may add Your own copyright statement to Your modifications and - may provide additional or different license terms and conditions - for use, reproduction, or distribution of Your modifications, or - for any such Derivative Works as a whole, provided Your use, - reproduction, and distribution of the Work otherwise complies with - the conditions stated in this License. - - 5. Submission of Contributions. Unless You explicitly state otherwise, - any Contribution intentionally submitted for inclusion in the Work - by You to the Licensor shall be under the terms and conditions of - this License, without any additional terms or conditions. - Notwithstanding the above, nothing herein shall supersede or modify - the terms of any separate license agreement you may have executed - with Licensor regarding such Contributions. - - 6. Trademarks. This License does not grant permission to use the trade - names, trademarks, service marks, or product names of the Licensor, - except as required for reasonable and customary use in describing the - origin of the Work and reproducing the content of the NOTICE file. - - 7. Disclaimer of Warranty. Unless required by applicable law or - agreed to in writing, Licensor provides the Work (and each - Contributor provides its Contributions) on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or - implied, including, without limitation, any warranties or conditions - of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A - PARTICULAR PURPOSE. You are solely responsible for determining the - appropriateness of using or redistributing the Work and assume any - risks associated with Your exercise of permissions under this License. - - 8. Limitation of Liability. In no event and under no legal theory, - whether in tort (including negligence), contract, or otherwise, - unless required by applicable law (such as deliberate and grossly - negligent acts) or agreed to in writing, shall any Contributor be - liable to You for damages, including any direct, indirect, special, - incidental, or consequential damages of any character arising as a - result of this License or out of the use or inability to use the - Work (including but not limited to damages for loss of goodwill, - work stoppage, computer failure or malfunction, or any and all - other commercial damages or losses), even if such Contributor - has been advised of the possibility of such damages. - - 9. Accepting Warranty or Additional Liability. While redistributing - the Work or Derivative Works thereof, You may choose to offer, - and charge a fee for, acceptance of support, warranty, indemnity, - or other liability obligations and/or rights consistent with this - License. However, in accepting such obligations, You may act only - on Your own behalf and on Your sole responsibility, not on behalf - of any other Contributor, and only if You agree to indemnify, - defend, and hold each Contributor harmless for any liability - incurred by, or claims asserted against, such Contributor by reason - of your accepting any such warranty or additional liability. - - END OF TERMS AND CONDITIONS - diff --git a/dydx/Pods/MagicSDK/README.md b/dydx/Pods/MagicSDK/README.md deleted file mode 100644 index f90421cb9..000000000 --- a/dydx/Pods/MagicSDK/README.md +++ /dev/null @@ -1,41 +0,0 @@ -# MagicSDK -[![CI Status](https://img.shields.io/travis/Ethella/MagicSDK.svg?style=flat)](https://travis-ci.org/Ethella/MagicSDK) -[![Version](https://img.shields.io/cocoapods/v/MagicSDK.svg?style=flat)](https://cocoapods.org/pods/MagicSDK) -[![License](https://img.shields.io/cocoapods/l/MagicSDK.svg?style=flat)](https://cocoapods.org/pods/MagicSDK) -[![Platform](https://img.shields.io/cocoapods/p/MagicSDK.svg?style=flat)](https://cocoapods.org/pods/MagicSDK) - -Cocoapods ---- -## Set up the local development env -1. To start the demo app with local development SDK, download following projects -```bash -# demo app -$ git clone https://github.com/magiclabs/magic-ios-demo -# ios SDK -$ git clone https://github.com/magiclabs/magic-ios -``` - -2. To enable the demo use the local development SDK. Navigate to `magic-ios-demo/Podfile` and edit the following lines. -This will make pod file install local dependencies instead of the ones distributed. - -```ruby -# Distributed Library on Cocoapods -# pod 'MagicSDK', '~> 4.0' -# pod 'MagicExt-OAuth', '~> 1.0' - -# Local development library -pod 'MagicSDK', :path => '../magic-ios/MagicSDK.podspec' -pod 'MagicExt-OAuth', :path => '../magic-ios-ext/MagicExt-OAuth.podspec' -``` - -```bash -$ cd /YOUR/PATH/TO/magic-ios-demo - -# Install dependencies -$ pod install -``` - -3. Open `/YOUR/PATH/TO/magic-ios-demo/magic-ios-demo.xcworkspace` with XCode and try it out! - ---- - diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Magic.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Magic.swift deleted file mode 100644 index 56e60760c..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Magic.swift +++ /dev/null @@ -1,101 +0,0 @@ -// -// Magic.swift -// Magic ios SDK -// -// Created by Jerry Liu on 1/20/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// -import MagicSDK_Web3 -import WebKit - - -internal enum ProductType{ - case MA - case MC -} - -/// An instance of the Magic SDK -public class Magic: MagicCore { - - // MARK: - Module - public let user: UserModule - public let auth: AuthModule - - /// Shared instance of `Magic` - public static var shared: Magic! - - // MARK: - Initialization - - /// Initialize an instance of `Magic` - /// - /// - Parameters: - /// - apiKey: Your client ID. From https://dashboard.Magic.com - /// - ethNetwork: Network setting - public convenience init(apiKey: String, network: EthNetwork, locale: String = Locale.current.identifier) { - self.init(urlBuilder: URLBuilder(apiKey: apiKey, locale: locale, productType: .MA)) - } - - public convenience init(apiKey: String, customNode: CustomNodeConfiguration, locale: String = Locale.current.identifier) { - let urlBuilder = URLBuilder(apiKey: apiKey, customNode: customNode, locale: locale, productType: ProductType.MA) - self.init(urlBuilder: urlBuilder) - } - - public convenience init(apiKey: String, locale: String = Locale.current.identifier) { - self.init(urlBuilder: URLBuilder(apiKey: apiKey, locale: locale, productType: .MA)) - } - - /// Core constructor - private init(urlBuilder: URLBuilder) { - let rpcProvider = RpcProvider(urlBuilder: urlBuilder) - self.user = UserModule(rpcProvider: rpcProvider) - self.auth = AuthModule(rpcProvider: rpcProvider) - super.init(rpcProvider: rpcProvider) - } -} - -/// An instance of the Magic SDK -public class MagicConnect: MagicCore { - - public let connect: ConnectModule - - /// Shared instance of `Magic` - public static var shared: MagicConnect! - - public convenience init(apiKey: String) { - let urlBuilder = URLBuilder(apiKey: apiKey, ethNetwork: EthNetwork.mainnet, locale: "en_US", productType: ProductType.MC) - self.init(urlBuilder: urlBuilder) - } - - public convenience init(apiKey: String, network: EthNetwork) { - let urlBuilder = URLBuilder(apiKey: apiKey, ethNetwork: network, locale: "en_US", productType: ProductType.MC) - self.init(urlBuilder: urlBuilder) - } - - private init(urlBuilder: URLBuilder) { - let rpcProvider = RpcProvider(urlBuilder: urlBuilder) - self.connect = ConnectModule(rpcProvider: rpcProvider) - super.init(rpcProvider: rpcProvider) - } -} - -public class MagicCore: NSObject { - - public var rpcProvider: RpcProvider - - internal init(rpcProvider: RpcProvider) { - self.rpcProvider = rpcProvider - } -} - - -// Handles Specific RpcError -extension Web3Response { - public var magicAuthError: RpcProvider.ProviderError? { - switch self.status { - case .failure(let error): - return error as? RpcProvider.ProviderError - case .success: - return nil - } - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/NetworkClient.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/NetworkClient.swift deleted file mode 100644 index eb7c5ed4d..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/NetworkClient.swift +++ /dev/null @@ -1,109 +0,0 @@ -// -// NetworkClient.swift -// Magic -// -// Created by Jerry Liu on 2/09/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import PromiseKit - -/// A base networking class that can send http requests -public class NetworkClient { - - /// Various errors that may occur while processing Web3 requests - public enum Error: Swift.Error { - /// The response did not include expected results - case unexpectedResponse(Swift.Error?) - /// The server returned an unexpected response code - case invalidResponseCode - } - - /// Internal queue for handling requests - let queue: DispatchQueue - - /// Internal URLSession for this Web3Provider's RPC requests - let session: URLSession = URLSession(configuration: .default) - - /// JSONEncoder for encoding RPCRequests - let encoder = JSONEncoder() - - /// JSONDecoder for parsing RPCResponses - let decoder = JSONDecoder() - - /// HTTP headers to add to all requests - public var headers = [ - "Content-Type": "application/json" - ] - - init() { - self.queue = DispatchQueue(label: "MagicHttpProvider", attributes: .concurrent) - } - - /// Encode an object with or without a prefix into data - /// - /// - Parameters: - /// - body: Object to encode. Must be Encodable. - /// - prefix: Optional string to prefix the body with - /// - Returns: Promise resolving with the encoded Data - func encode(body: T, withPrefix prefix: String? = nil) -> Promise { - return Promise { resolver in - queue.async { - do { - let encoded: Data - if let prefix = prefix { - encoded = try self.encoder.encode([prefix: body]) - } else { - encoded = try self.encoder.encode(body) - } - resolver.fulfill(encoded) - } catch { - resolver.reject(error) - } - } - } - } - - /// Sends a basic http request. - /// This method will create a URLRequest, and then run a URLSessionDataTask with the URLRequest. - /// Once a response is received, the response will be validated for data and a valid status code - /// before calling the callback with the resulting data or error. - /// - /// - Parameters: - /// - url: url for the request - /// - method: HTTP method to use - /// - body: Optional request body to include - /// - Returns: Promise resolving with Data from the response if it's successful - func postRequest(url: URL, method: String, body: Data?) -> Promise { - return Promise { resolver in - queue.async { - var req = URLRequest(url: url) - req.httpMethod = method - req.httpBody = body - - // Add default headers - for (k, v) in self.headers { - req.addValue(v, forHTTPHeaderField: k) - } - - // Create the URLSessionTask - let task = self.session.dataTask(with: req) { data, urlResponse, error in - guard let urlResponse = urlResponse as? HTTPURLResponse, let data = data, error == nil else { - resolver.reject(Error.unexpectedResponse(error)) - return - } - - guard urlResponse.statusCode >= 200 && urlResponse.statusCode < 300 else { - resolver.reject(Error.invalidResponseCode) - return - } - - resolver.fulfill(data) - } - task.resume() - } - } - } - -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/RpcProvider.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/RpcProvider.swift deleted file mode 100644 index a75ee57c9..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Provider/RpcProvider.swift +++ /dev/null @@ -1,91 +0,0 @@ -// -// RpcProvider.swift -// MagicSDK -// -// Created by Jerry Liu on 1/20/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import MagicSDK_Web3 -import WebKit -import PromiseKit - -/// A custom Web3 HttpProvider that is specifically configured for use with Magic Links. -public class RpcProvider: NetworkClient, Web3Provider { - - /// Various errors that may occur while processing Web3 requests - public enum ProviderError: Swift.Error { - /// The provider is not configured with an authDelegate - case encodingFailed(Swift.Error?) - /// Decoding the JSON-RPC request failed - case decodingFailed(json: String) - /// Convert string failed - case invalidJsonResponse(json: String) - /// Missing callback - case missingPayloadCallback(json: String) - } - - let overlay: WebViewController - public let urlBuilder: URLBuilder - - required init(urlBuilder: URLBuilder) { - self.overlay = WebViewController(url: urlBuilder) - self.urlBuilder = urlBuilder - super.init() - } - - // MARK: - Sending Requests - - /// Sends an RPCRequest and parses the result - /// Web3 Provider protocal conformed - /// - /// - Parameters: - /// - request: RPCRequest to send - /// - response: A completion handler for the response. Includes either the result or an error. - public func send(request: RPCRequest, response: @escaping Web3ResponseCompletion) { - let msgType = OutboundMessageType.MAGIC_HANDLE_REQUEST - - // Re-assign ID to the payload - let newRequest = RPCRequest(method: request.method, params: request.params) - - // construct message data - let eventMessage = RequestData(msgType: "\(msgType.rawValue)-\(urlBuilder.encodedParams)", payload: newRequest) - - // encode to JSON - firstly { - encode(body: eventMessage) - }.done {body throws -> Void in - - let str = try String(body) - - // enqueue and send to webview - try self.overlay.enqueue(message: str, id: newRequest.id) { ( responseString: String) in - guard let jsonData = responseString.data(using: .utf8) else { - throw ProviderError.invalidJsonResponse(json: str) - } - - // Decode JSON string into string - do { - let rpcResponse = try self.decoder.decode(ResponseData>.self, from: jsonData) - let result = Web3Response(rpcResponse: rpcResponse.response) - response(result) - } catch { - throw ProviderError.decodingFailed(json: responseString) - } - } - }.catch { error in - let errResponse = Web3Response(error: ProviderError.encodingFailed(error)) - response(errResponse) -// handleRollbarError(error, log: false) - } - } -} - -public typealias Web3ResponseCompletion = (_ resp: Web3Response) -> Void - -internal extension Web3BytesInitializable { - init(_ bytes: Web3BytesRepresentable) throws { - let bytes = try bytes.makeBytes() - try self.init(bytes) - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValue.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValue.swift deleted file mode 100644 index b925e7ba3..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValue.swift +++ /dev/null @@ -1,264 +0,0 @@ -// -// AnyValue.swift -// MagicSDK -// -// Created by Jerry Liu on 7/13/20. -// - -import Foundation - -/** - * A `Codable`, Ethereum representable value. - */ -public struct AnyValue: Codable { - - /// The internal type of this value - public let valueType: ValueType - - public enum ValueType { - - /// A string value - case string(String) - - /// An int value - case int(Int) - - /// A bool value - case bool(Bool) - - /// An array value - case array([AnyValue]) - - /// A special case nil value - case `nil` - } - - public init(valueType: ValueType) { - self.valueType = valueType - } - - public init(from decoder: Decoder) throws { - let container = try decoder.singleValueContainer() - - if let str = try? container.decode(String.self) { - valueType = .string(str) - } else if let bool = try? container.decode(Bool.self) { - valueType = .bool(bool) - } else if let int = try? container.decode(Int.self) { - valueType = .int(int) - } else if let array = try? container.decode([AnyValue].self) { - valueType = .array(array) - } else if container.decodeNil() { - valueType = .nil - } else { - throw Error.unsupportedType - } - } - - /// Encoding and Decoding errors specific to AnyValue - public enum Error: Swift.Error { - - /// The type set is not convertible to AnyValue - case unsupportedType - } - - public func encode(to encoder: Encoder) throws { - var container = encoder.singleValueContainer() - - switch valueType { - case .string(let string): - try container.encode(string) - case .int(let int): - try container.encode(int) - case .bool(let bool): - try container.encode(bool) - case .array(let array): - try container.encode(array) - case .nil: - try container.encodeNil() - } - } -} - -// MARK: - Convenient Initializers - -extension AnyValue: ExpressibleByStringLiteral { - - public typealias StringLiteralType = String - - public init(stringLiteral value: StringLiteralType) { - valueType = .string(value) - } -} - -extension AnyValue: ExpressibleByIntegerLiteral { - - public typealias IntegerLiteralType = Int - - public init(integerLiteral value: IntegerLiteralType) { - valueType = .int(value) - } -} - -extension AnyValue: ExpressibleByBooleanLiteral { - - public typealias BooleanLiteralType = Bool - - public init(booleanLiteral value: BooleanLiteralType) { - valueType = .bool(value) - } -} - -extension AnyValue: ExpressibleByArrayLiteral { - - public typealias ArrayLiteralElement = AnyValueRepresentable - - public init(array: [AnyValueRepresentable]) { - let values = array.map({ $0.anyValue() }) - valueType = .array(values) - } - - public init(arrayLiteral elements: ArrayLiteralElement...) { - self.init(array: elements) - } -} - -// MARK: - Convenient Setters - -public extension AnyValue { - - static func string(_ string: String) -> AnyValue { - return self.init(stringLiteral: string) - } - - static func int(_ int: Int) -> AnyValue { - return self.init(integerLiteral: int) - } - - static func bool(_ bool: Bool) -> AnyValue { - return self.init(booleanLiteral: bool) - } - - static func array(_ array: [AnyValueRepresentable]) -> AnyValue { - return self.init(array: array) - } -} - -// MARK: - Convenient Getters - -public extension AnyValue { - - var string: String? { - if case .string(let string) = valueType { - return string - } - - return nil - } - - var int: Int? { - if case .int(let int) = valueType { - return int - } - - return nil - } - - var bool: Bool? { - if case .bool(let bool) = valueType { - return bool - } - - return nil - } - - var array: [AnyValue]? { - if case .array(let array) = valueType { - return array - } - - return nil - } -} - -// MARK: - AnyValueConvertible - -extension AnyValue: AnyValueConvertible { - - public init(anyValue: AnyValue) { - self = anyValue - } - - public func anyValue() -> AnyValue { - return self - } -} - -// MARK: - Equatable - -extension AnyValue.ValueType: Equatable { - - public static func ==(_ lhs: AnyValue.ValueType, _ rhs: AnyValue.ValueType) -> Bool { - switch lhs { - case .string(let str): - if case .string(let rStr) = rhs { - return str == rStr - } - return false - case .int(let int): - if case .int(let rInt) = rhs { - return int == rInt - } - return false - case .bool(let bool): - if case .bool(let rBool) = rhs { - return bool == rBool - } - return false - case .array(let array): - if case .array(let rArray) = rhs { - return array == rArray - } - return false - case .nil: - if case .nil = rhs { - return true - } - return false - } - } -} - -extension AnyValue: Equatable { - - public static func ==(_ lhs: AnyValue, _ rhs: AnyValue) -> Bool { - return lhs.valueType == rhs.valueType - } -} - -// MARK: - Hashable - -extension AnyValue.ValueType: Hashable { - - public func hash(into hasher: inout Hasher) { - switch self { - case .string(let str): - hasher.combine(str) - case .int(let int): - hasher.combine(int) - case .bool(let bool): - hasher.combine(bool) - case .array(let array): - hasher.combine(array) - case .nil: - hasher.combine(0x00) - } - } -} - -extension AnyValue: Hashable { - - public func hash(into hasher: inout Hasher) { - hasher.combine(valueType) - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValueConvertible.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValueConvertible.swift deleted file mode 100644 index ad097dbf7..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/AnyValueConvertible.swift +++ /dev/null @@ -1,76 +0,0 @@ -// -// AnyValueConvertible.swift -// MagicSDK -// -// Created by Jerry Liu on 07/13/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -/** - * Objects which can be converted to `AnyValue` can implement this. - */ -public protocol AnyValueRepresentable: Encodable { - - /** - * Converts `self` to `AnyValue`. - * - * - returns: The generated `AnyValue`. - */ - func anyValue() -> AnyValue -} - -/** - * Objects which can be initialized with `AnyValue`'s can implement this. - */ -public protocol AnyValueInitializable: Decodable { - - /** - * Initializes `self` with the given `AnyValue` if possible. Throws otherwise. - * - * - parameter AnyValue: The `AnyValue` to be converted to `self`. - */ - init(anyValue: AnyValue) throws -} - -/** - * Objects which are both representable and initializable by and with `AnyValue`'s. - */ -public typealias AnyValueConvertible = AnyValueRepresentable & AnyValueInitializable - -extension AnyValueInitializable { - - public init(anyValue: AnyValueRepresentable) throws { - let e = anyValue.anyValue() - try self.init(anyValue: e) - } -} - -// MARK: - Default Codable - -extension AnyValueRepresentable { - - public func encode(to encoder: Encoder) throws { - try anyValue().encode(to: encoder) - } -} - -extension AnyValueInitializable { - - public init(from decoder: Decoder) throws { - try self.init(anyValue: AnyValue(from: decoder)) - } -} - -// MARK: - Errors - -public enum AnyValueRepresentableError: Swift.Error { - - case notRepresentable -} - -public enum AnyValueInitializableError: Swift.Error { - - case notInitializable -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/BasicTypes.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/BasicTypes.swift deleted file mode 100644 index baacf0fba..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/Types/BasicTypes.swift +++ /dev/null @@ -1,33 +0,0 @@ -// -// Type.swift -// Magic -// -// Created by Jerry Liu on 2/6/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -enum InboundMessageType: String, CaseIterable { - case MAGIC_HANDLE_RESPONSE - case MAGIC_OVERLAY_READY - case MAGIC_SHOW_OVERLAY - case MAGIC_HIDE_OVERLAY - case MAGIC_HANDLE_EVENT -} - -enum OutboundMessageType: String, CaseIterable { - case MAGIC_HANDLE_REQUEST -} - -struct RequestData: Codable { - - let msgType: String - let payload: T -} - -struct ResponseData: Codable { - - let msgType: String - let response: T -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/URLBuilder.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/URLBuilder.swift deleted file mode 100644 index 19c0e7209..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/URLBuilder.swift +++ /dev/null @@ -1,117 +0,0 @@ -// -// URLBuilder.swift -// Magic -// -// Created by Jerry Liu on 3/16/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -// MARK: - URLBuilder init -// -// Construct a URI with options encoded -// -public struct URLBuilder { - - let encodedParams, url: String - static let host = "https://box.magic.link" - - public let apiKey: String - - init(apiKey: String, customNode: CustomNodeConfiguration? = nil, ethNetwork: EthNetwork? = nil, locale: String, productType: ProductType) { - - let data = try! JSONEncoder().encode(paramsEncodable(apiKey: apiKey, ethNetwork: ethNetwork, customNode: customNode, locale: locale, productType: productType)) - self.init(data: data, host: URLBuilder.host, apiKey: apiKey, productType: productType) - } - - private init(data: Data, host: String, apiKey: String, productType: ProductType) { - let jsonString = String(data: data, encoding: .utf8)! - let string = jsonString.replacingOccurrences(of: "\\", with: "") - // Encode instantiate option to params - self.apiKey = apiKey - self.encodedParams = btoa(jsonString: string) - self.url = "\(host)/send/?params=\(self.encodedParams)" - } - - // MARK: - Options structs - struct paramsEncodable: Encodable { - let API_KEY: String - let locale: String - let customNode: CustomNodeConfiguration? - let ethNetwork: EthNetwork? - let productType: ProductType - init(apiKey: String, ethNetwork: EthNetwork?, customNode: CustomNodeConfiguration?, locale: String, productType: ProductType) { - self.productType = productType - self.customNode = customNode - self.ethNetwork = ethNetwork - self.API_KEY = apiKey - self.locale = locale - } - - enum CodingKeys: String, CodingKey { - case sdk, bundleId, API_KEY, host, ETH_NETWORK, ext - } - - func encode(to encoder: Encoder) throws { - var container = encoder.container(keyedBy: CodingKeys.self) - try container.encode("magic-sdk-ios", forKey: .sdk) - try container.encode(Bundle.main.bundleIdentifier, forKey: .bundleId) - try container.encode(self.API_KEY, forKey: .API_KEY) - try container.encode(URLBuilder.host, forKey: .host) - - /// Network - if (customNode != nil) { - try container.encode(customNode, forKey: .ETH_NETWORK) - } - if (ethNetwork != nil) { - try container.encode(ethNetwork?.rawValue, forKey: .ETH_NETWORK) - } - - try container.encode(ExtensionObject(productType: productType), forKey: .ext) - } - } -} - -// MARK: -- Network -public struct CustomNodeConfiguration: Encodable { - let rpcUrl: String - let chainId: Int? - - public init (rpcUrl: String, chainId: Int? = nil) { - self.rpcUrl = rpcUrl - self.chainId = chainId - } -} - - -// MARK: -- Extension -struct ExtensionObject: Encodable { - - let productType: ProductType - - init(productType: ProductType) { - self.productType = productType - } - - enum CodingKeys: String, CodingKey { - case connect - } - - func encode(to encoder: Encoder) throws { - var container = encoder.container(keyedBy: CodingKeys.self) - - switch productType { - case .MC: - try container.encode(MCConfig(), forKey: .connect) - break - default: - break - } - - } -} - -internal struct MCConfig: Encodable { - let mc = true -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/WebViewController.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/WebViewController.swift deleted file mode 100644 index 712c5b195..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Core/Relayer/WebViewController.swift +++ /dev/null @@ -1,299 +0,0 @@ -// -// WebViewController.swift -// Magic -// -// Created by Jerry Liu on 2/1/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import WebKit -import UIKit - -/// An instance of the Fortmatc Phantom WebView -class WebViewController: UIViewController, WKUIDelegate, WKScriptMessageHandler, WKNavigationDelegate, UIScrollViewDelegate { - - /// Various errors that may occur while processing Web3 requests - public enum AuthRelayerError: Error { - - ///Message encode fail - case messageEncodeFailed(message: String) - - case webviewAttachedFailed - case topMostWindowNotFound - } - - /// This name is reserved for internal use - let messageName = "fortmaticIOS" - - var webView: WKWebView! - - /// X source url - var urlBuilder: URLBuilder! - - /// Overlay Ready - var overlayReady = false - var webViewFinishLoading = false - - /// Queue and callbackss - var queue: [String] = [] - var messageHandlers: Dictionary = [:] - - typealias MessageHandler = (String) throws -> Void - - // MARK: - init - init(url: URLBuilder) { - self.urlBuilder = url - super.init(nibName: nil, bundle: nil) - } - - // Required provided by subclass of 'UIViewController' - required init?(coder aDecoder: NSCoder) { - super.init(coder: aDecoder) - } - - // MARK: - Message Queue - func enqueue(message: String, id: Int, closure: @escaping MessageHandler) throws -> Void { - queue.append(message) - messageHandlers[id] = closure - try self.dequeue() - } - - private func dequeue() throws -> Void { - - // Check if UI is appeneded properly to current screen before dequeue - guard let window = UIApplication.shared.keyWindow else { return try attachWebView() } - - if self.view.isDescendant(of: window) { - - if !queue.isEmpty && overlayReady && webViewFinishLoading { - let message = queue.removeFirst() - try self.postMessage(message: message) - - // Recursive calls till queue is Empty - try self.dequeue() - } - } else { - try attachWebView() - } - } - - - // MARK: - Receive Messages - - /// handler for received messages - /// conforming WKScriptMessageHandler - func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) { - - do { - if message.name == messageName { - guard let payloadStr = message.body as? String else { return } - - if payloadStr.contains(InboundMessageType.MAGIC_OVERLAY_READY.rawValue) { - overlayReady = true - try? self.dequeue() - } else if payloadStr.contains(InboundMessageType.MAGIC_SHOW_OVERLAY.rawValue) { - try bringWebViewToFront() - } else if payloadStr.contains(InboundMessageType.MAGIC_HIDE_OVERLAY.rawValue) { - try sendSubviewToBack() - } else if payloadStr.contains(InboundMessageType.MAGIC_HANDLE_EVENT.rawValue) { - try handleEvent(payloadStr: payloadStr) - } else if payloadStr.contains(InboundMessageType.MAGIC_HANDLE_RESPONSE.rawValue) { - try handleResponse(payloadStr: payloadStr) - } - } - try self.dequeue() - }catch let error { - print("Magic internal error: \(error.localizedDescription)") - } - } - - private func handleEvent(payloadStr: String) throws -> Void { - - // Decode here to get the event name - let eventData = payloadStr.data(using: .utf8)! - let eventResponse = try JSONDecoder().decode(ResponseData>.self, from: eventData) - - // post event to the obeserver - let event = eventResponse.response - let eventName = event.result.event - NotificationCenter.default.post(name: Notification.Name.init(eventName), object: nil, userInfo: ["event": event.result]) - } - - private func handleResponse(payloadStr: String) throws -> Void { - - /// Take id out from JSON string - if let range = payloadStr.range(of: "(?<=\"id\":)(.*?)(?=,)", options: .regularExpression) { - - guard let id = Int(payloadStr[range]) else { - - /// throws when response has no matching id - throw RpcProvider.ProviderError.invalidJsonResponse(json: payloadStr) - } - - // Call callback stored - if let callback = self.messageHandlers[id] { - try callback(payloadStr) - self.messageHandlers[id] = nil - } else { - - /// throws when response couldn't match a callback - throw RpcProvider.ProviderError.missingPayloadCallback(json: payloadStr) - } - } else { - throw RpcProvider.ProviderError.invalidJsonResponse(json: payloadStr) - } - } - - - // MARK: - Post Messages - - - /// post Message to HTML via evaluateJavaScript - /// - internal func postMessage(message: String) throws -> Void { - - let data: [String: String] = ["data": message] - - guard let json = try? JSONEncoder().encode(data), - let jsonString = String(data: json, encoding: .utf8) else { - throw AuthRelayerError.messageEncodeFailed(message: message) - } - - let execString = String(format: "window.dispatchEvent(new MessageEvent('message', \(jsonString)));") - webView.evaluateJavaScript(execString) - } - - - - - // MARK: - view loading - /// loadView will be triggered when addsubview is called. It will create a webview to post messages to auth relayer - override func loadView() { - - // Display Full screen - let cgRect = CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height) - let webView: WKWebView = { - - let webCfg:WKWebViewConfiguration = WKWebViewConfiguration() - let userController:WKUserContentController = WKUserContentController() - - // Add a script message handler for receiving messages over `fortmatic` messageHandler. The controller needs to conform - // with WKScriptMessageHandler protocol - userController.add(self, name: messageName) - webCfg.userContentController = userController; - - let webView = WKWebView(frame: cgRect, configuration: webCfg) - - // Transparent background - webView.backgroundColor = UIColor.clear - webView.scrollView.backgroundColor = UIColor.clear - webView.isOpaque = false - - webView.uiDelegate = self - - // conforming WKNavigationDelegate - webView.navigationDelegate = self - - return webView - }() - self.webView = webView - view = webView - } - - override func viewWillAppear(_ animated: Bool) { - super.viewWillAppear(animated) - let myURL = URL(string: urlBuilder.url) - let myRequest = URLRequest(url: myURL!) - webView.load(myRequest) - } - - override func viewDidLoad() { - super.viewDidLoad() - webView.scrollView.delegate = self // disable zoom - } - - /// Check did finished navigating, conforming WKNavigationDelegate - func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) { - webViewFinishLoading = true - do { - try self.dequeue() - } catch {} - } - - // handle external link clicked events - func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) { - // Check for links. - if navigationAction.navigationType == .linkActivated { - // Make sure the URL is set. - guard let url = navigationAction.request.url else { - decisionHandler(.allow) - return - } - - // Check for the scheme component. - let components = URLComponents(url: url, resolvingAgainstBaseURL: false) - if components?.scheme == "http" || components?.scheme == "https" { - // Open the link in the external browser. - UIApplication.shared.open(url) - // Cancel the decisionHandler because we managed the navigationAction. - decisionHandler(.cancel) - } else { - decisionHandler(.allow) - } - } else { - decisionHandler(.allow) - } - } - - - - // MARK: - View - - /// Disable zooming for webview - func viewForZooming(in: UIScrollView) -> UIView? { - return nil; - } - - private func sendSubviewToBack() throws -> Void { - - let keyWindow = try getKeyWindow() - keyWindow.sendSubviewToBack(self.view) - } - - private func bringWebViewToFront() throws -> Void { - - let keyWindow = try getKeyWindow() - keyWindow.bringSubviewToFront(self.view) - } - - private func getKeyWindow() throws -> UIWindow { - - guard let keyWindow = UIApplication.shared.windows.filter({$0.isKeyWindow}).first else { - throw AuthRelayerError.topMostWindowNotFound - } - - return keyWindow - } - - private func attachWebView() throws -> Void { - - let keyWindow = try getKeyWindow() - - keyWindow.addSubview(self.view) - keyWindow.sendSubviewToBack(self.view) - - // find topmost view controller from the hierarchy and move webview to it - if var topController = keyWindow.rootViewController { - while let presentedViewController = topController.presentedViewController { - topController = presentedViewController - } - - self.didMove(toParent: topController) - - } else { - throw AuthRelayerError.webviewAttachedFailed - } - } -} - - diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthConfiguration.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthConfiguration.swift deleted file mode 100644 index b60fdf88e..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthConfiguration.swift +++ /dev/null @@ -1,42 +0,0 @@ -// -// Configuration.swift -// MagicSDK -// -// Created by Jerry Liu on 5/14/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -/// LoginWithMagicLink configuration -public struct LoginWithMagicLinkConfiguration: BaseConfiguration { - - /// Shows UI if sets to true - public var showUI: Bool - public var email: String - - public init(showUI: Bool = true, email: String) { - self.showUI = showUI - self.email = email - } -} - -public struct LoginWithSmsConfiguration: BaseConfiguration { - - /// - public var phoneNumber: String - var showUI = true - - public init(phoneNumber: String) { - self.phoneNumber = phoneNumber - } -} - -public struct LoginWithEmailOTPConfiguration: BaseConfiguration { - - public var email: String - - public init(email: String) { - self.email = email - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthMethod.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthMethod.swift deleted file mode 100644 index b2941f906..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthMethod.swift +++ /dev/null @@ -1,17 +0,0 @@ -// -// AuthMessage.swift -// MagicSDK -// -// Created by Jerry Liu on 5/17/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -internal enum AuthMethod: String, CaseIterable { - - // Auth - case magic_auth_login_with_magic_link - case magic_auth_login_with_sms - case magic_auth_login_with_email_otp -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthModule.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthModule.swift deleted file mode 100644 index ffd85f658..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Auth/AuthModule.swift +++ /dev/null @@ -1,62 +0,0 @@ -// -// AuthModule.swift -// Magic -// -// Created by Jerry Liu on 3/3/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 -import PromiseKit - -public class AuthModule: BaseModule { - - // MARK: - Login with magic link - public func loginWithMagicLink (_ configuration: LoginWithMagicLinkConfiguration, response: @escaping Web3ResponseCompletion ) { - let request = RPCRequest<[LoginWithMagicLinkConfiguration]>(method: AuthMethod.magic_auth_login_with_magic_link.rawValue, params: [configuration]) - self.provider.send(request: request, response: response) - } - - public func loginWithMagicLink (_ configuration: LoginWithMagicLinkConfiguration) -> Promise { - return Promise { resolver in - loginWithMagicLink(configuration, response: promiseResolver(resolver)) - } - } - - public func loginWithMagicLink (_ configuration: LoginWithMagicLinkConfiguration, eventLog: Bool) -> MagicEventPromise { - return MagicEventPromise (eventCenter: self.magicEventCenter, eventLog: eventLog) { resolver in - self.loginWithMagicLink(configuration, response: promiseResolver(resolver)) - } - } - - // MARK: - Login with SMS - public func loginWithSMS (_ configuration: LoginWithSmsConfiguration, response: @escaping Web3ResponseCompletion ) { - let request = RPCRequest<[LoginWithSmsConfiguration]>(method: AuthMethod.magic_auth_login_with_sms.rawValue, params: [configuration]) - self.provider.send(request: request, response: response) - } - - public func loginWithSMS (_ configuration: LoginWithSmsConfiguration) -> Promise { - return Promise { resolver in - loginWithSMS(configuration, response: promiseResolver(resolver)) - } - } - - // MARK: - Login with EmailOTP - public func loginWithEmailOTP (_ configuration: LoginWithEmailOTPConfiguration, response: @escaping Web3ResponseCompletion ) { - let request = RPCRequest<[LoginWithEmailOTPConfiguration]>(method: AuthMethod.magic_auth_login_with_email_otp.rawValue, params: [configuration]) - self.provider.send(request: request, response: response) - } - - public func loginWithEmailOTP (_ configuration: LoginWithEmailOTPConfiguration) -> Promise { - return Promise { resolver in - loginWithEmailOTP(configuration, response: promiseResolver(resolver)) - } - } - - public enum LoginWithMagicLinkEvent: String { - case emailNotDeliverable = "email-not-deliverable" - case emailSent = "email-sent" - case retry = "retry" - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseConfiguration.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseConfiguration.swift deleted file mode 100644 index d4d96f2a6..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseConfiguration.swift +++ /dev/null @@ -1,11 +0,0 @@ -// -// BaseConfiguration.swift -// Magic Labs -// -// Created by Jerry Liu on 5/15/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -public protocol BaseConfiguration: Codable {} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseModule.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseModule.swift deleted file mode 100644 index 9c71f4acc..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/BaseModule.swift +++ /dev/null @@ -1,32 +0,0 @@ -// -// BaseModule.swift -// Magic Labs -// -// Created by Jerry Liu on 3/3/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 -import PromiseKit - -open class BaseModule { - - public let provider: RpcProvider - public let magicEventCenter = EventCenter() - - public init(rpcProvider: RpcProvider) { - self.provider = rpcProvider - } -} - -public func promiseResolver(_ resolver: Resolver) -> (_ result: Web3Response) -> Void { - return { result in - switch result.status { - case let .success(value): - resolver.fulfill(value) - case let .failure(error): - resolver.reject(error) - } - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectConfiguration.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectConfiguration.swift deleted file mode 100644 index 804f9577e..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectConfiguration.swift +++ /dev/null @@ -1,18 +0,0 @@ -// -// ConnectConfiguration.swift -// -// -// Created by Jerry Liu on 9/16/22. -// - -import Foundation - -public struct RequestUserInfoConfiguration: BaseConfiguration { - - /// - public var isResponseRequired = false - - public init(isResponseRequired: Bool = false) { - self.isResponseRequired = isResponseRequired - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectMethod.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectMethod.swift deleted file mode 100644 index db03efd70..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectMethod.swift +++ /dev/null @@ -1,17 +0,0 @@ -// -// ConnectMethod.swift -// -// -// Created by Jerry Liu on 9/6/22. -// - -import Foundation - -internal enum ConnectMethod: String, CaseIterable { - - // MC - case mc_get_wallet_info - case mc_wallet - case mc_request_user_info - case mc_disconnect -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectModule.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectModule.swift deleted file mode 100644 index 5f65b27af..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectModule.swift +++ /dev/null @@ -1,53 +0,0 @@ -// -// ConnectModule.swift -// -// -// Created by Jerry Liu on 9/6/22. -// - -import Foundation -import MagicSDK_Web3 - -public class ConnectModule: BaseModule { - - /** - getWalletInfo - */ - public func getWalletInfo(response: @escaping Web3ResponseCompletion) { - - let request = BasicRPCRequest(method: ConnectMethod.mc_get_wallet_info.rawValue, params: []) - - return self.provider.send(request: request, response: response) - } - - - /** - showWallet - */ - public func showWallet(response: @escaping Web3ResponseCompletion) { - - let request = BasicRPCRequest(method: ConnectMethod.mc_wallet.rawValue, params: []) - - return self.provider.send(request: request, response: response) - } - - /** - requestUserInfo - */ - public func requestUserInfo(_ configuration: RequestUserInfoConfiguration = RequestUserInfoConfiguration(), response: @escaping Web3ResponseCompletion) { - - let request = RPCRequest<[RequestUserInfoConfiguration]>(method: ConnectMethod.mc_request_user_info.rawValue, params: [configuration]) - - return self.provider.send(request: request, response: response) - } - - /** - disconnect - */ - public func disconnect(response: @escaping Web3ResponseCompletion) { - - let request = BasicRPCRequest(method: ConnectMethod.mc_disconnect.rawValue, params: []) - - return self.provider.send(request: request, response: response) - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectResponse.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectResponse.swift deleted file mode 100644 index 95006fe78..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Connect/ConnectResponse.swift +++ /dev/null @@ -1,17 +0,0 @@ -// -// ConnectResponse.swift -// -// -// Created by Wentao Liu on 9/22/22. -// - -import Foundation - -public struct UserInfoResponse: MagicResponse { - - public let email: String? -} - -public struct WalletInfoResponse: MagicResponse { - public let walletType: String? -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventCenter.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventCenter.swift deleted file mode 100644 index ebd552f07..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventCenter.swift +++ /dev/null @@ -1,44 +0,0 @@ -// -// PromiEvent.swift -// MagicSDK -// -// Created by Jerry Liu on 7/10/20. -// - -import Foundation -import PromiseKit - -public class EventCenter { - - enum Error: Swift.Error{ - case eventCallbackMissing - } - private var eventLog = false - - private typealias EventCompletion = () -> Void - private var eventHandlerDict: Dictionary = [:] - - func addOnceObserver (eventName: String, eventLog: Bool, completion: @escaping () -> Void) -> Void { - NotificationCenter.default.addObserver(self, selector: #selector(self.onDidReceiveEventOnce(_:)), name: Notification.Name.init(eventName), object: nil) - self.eventLog = eventLog - eventHandlerDict[eventName] = completion - } - - /// Recieve events - @objc func onDidReceiveEventOnce(_ notification: Notification) { - - if let eventResult = (notification.userInfo?["event"]) as? MagicEventResult<[AnyValue]>, let handler = eventHandlerDict[eventResult.event] { - - if (eventLog) { - print("MagicSDK Event: \(eventResult)") - } - - NotificationCenter.default.removeObserver(self, name: Notification.Name(eventResult.event), object: nil) - handler() - } else { -// handleRollbarError(Error.eventCallbackMissing) - } - } - - init (){} -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventPromise.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventPromise.swift deleted file mode 100644 index 5216aeb4a..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventPromise.swift +++ /dev/null @@ -1,33 +0,0 @@ -// -// PromiEvent.swift -// MagicSDK -// -// Created by Jerry Liu on 7/10/20. -// - -import Foundation -import PromiseKit - -public class MagicEventPromise { - - private var donePromise: Promise - private var eventCenter: EventCenter - private var eventLog = false - - typealias EventCompletion = () -> Void - - public func once(eventName: String, completion: @escaping () -> Void) -> MagicEventPromise { - eventCenter.addOnceObserver(eventName: eventName, eventLog: eventLog, completion: completion) - return self - } - - public func done(on: DispatchQueue? = conf.Q.return, flags: DispatchWorkItemFlags? = nil, _ body: @escaping(T) throws -> Void) -> Promise { - return self.donePromise.done(on: on, flags: flags, body) - } - - init (eventCenter: EventCenter, eventLog: Bool, _ resolver: @escaping (_ resolver: Resolver) -> Void) { - self.donePromise = Promise(resolver: resolver) - self.eventCenter = eventCenter - self.eventLog = eventLog - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventResponse.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventResponse.swift deleted file mode 100644 index a6249516b..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Event/EventResponse.swift +++ /dev/null @@ -1,43 +0,0 @@ -// -// PromiEvents.swift -// MagicSDK -// -// Created by Jerry Liu on 7/10/20. -// - -import Foundation - - -internal struct MagicEventResponse: Codable { - - /// The rpc id - public let id: Int - - /// The jsonrpc version. Typically 2.0 - public let jsonrpc: String - - /// The result - public let result: MagicEventResult - - /// The error - public let error: Error? - - public struct Error: Swift.Error, Codable { - - /// The error code - public let code: Int - - /// The error message - public let message: String - - /// Description - public var localizedDescription: String { - return "Magic Event Error (\(code)) \(message)" - } - } -} - -internal struct MagicEventResult: Codable { - let event: String - let params: Params -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserConfiguration.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserConfiguration.swift deleted file mode 100644 index c4f822a02..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserConfiguration.swift +++ /dev/null @@ -1,49 +0,0 @@ -// -// UserConfiguration.swift -// Magic -// -// Created by Jerry Liu on 3/4/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 - -/// Get Id Token configuration -public class GetIdTokenConfiguration: BaseConfiguration { - - var lifespan: Int - - public init(lifespan: Int = 900) { - self.lifespan = lifespan - } -} - - -public class GenerateIdTokenConfiguration: BaseConfiguration { - var attachment: String - var lifespan: Int - - public init(lifespan: Int = 900, attachment: String = "none") { - self.lifespan = lifespan - self.attachment = attachment - } -} - -public class UpdateEmailConfiguration: BaseConfiguration { - var email: String - var showUI: Bool - - public init(email: String, showUI: Bool = true){ - self.email = email - self.showUI = showUI - } -} - -public class RecoverAccountConfiguration: BaseConfiguration { - var email: String - - public init(email: String){ - self.email = email - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserMethod.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserMethod.swift deleted file mode 100644 index 34f5ca7d3..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserMethod.swift +++ /dev/null @@ -1,23 +0,0 @@ -// -// UserMessage.swift -// MagicSDK -// -// Created by Jerry Liu on 5/17/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation - -internal enum UserMethod: String, CaseIterable { - - // Auth - case magic_auth_get_id_token - case magic_auth_generate_id_token - case magic_auth_get_metadata - case magic_auth_logout - case magic_auth_settings - case magic_auth_update_email - case magic_auth_is_logged_in - case magic_auth_update_phone_number - case magic_auth_recover_account -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserModule.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserModule.swift deleted file mode 100644 index bdfd1fb8a..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserModule.swift +++ /dev/null @@ -1,153 +0,0 @@ -// -// PhantomUser.swift -// -// Created by Jerry Liu on 3/2/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 -import PromiseKit - -public class UserModule: BaseModule { - - /** - GetIdToken - */ - public func getIdToken(_ configuration: GetIdTokenConfiguration? = nil, response: @escaping Web3ResponseCompletion) { - - let request = RPCRequest<[GetIdTokenConfiguration?]>(method: UserMethod.magic_auth_get_id_token.rawValue, params: [configuration]) - - return self.provider.send(request: request, response: response) - } - - public func getIdToken(_ configuration: GetIdTokenConfiguration? = nil) -> Promise { - return Promise { resolver in - getIdToken(configuration, response: promiseResolver(resolver)) - } - } - - /** - Generate Id Token - */ - public func generateIdToken(_ configuration: GenerateIdTokenConfiguration? = nil, response: @escaping Web3ResponseCompletion) { - - let request = RPCRequest<[GenerateIdTokenConfiguration?]>(method: UserMethod.magic_auth_generate_id_token.rawValue, params: [configuration]) - - return self.provider.send(request: request, response: response) - } - - public func generateIdToken(_ configuration: GenerateIdTokenConfiguration? = nil) -> Promise { - return Promise { resolver in - generateIdToken(configuration, response: promiseResolver(resolver)) - } - } - - - /** - Get Metadata - */ - public func getMetadata(response: @escaping Web3ResponseCompletion) { - let request = BasicRPCRequest(method: UserMethod.magic_auth_get_metadata.rawValue, params: []) - return self.provider.send(request: request, response: response) - } - - public func getMetadata() -> Promise { - return Promise { resolver in - getMetadata(response: promiseResolver(resolver)) - } - } - - /** - IsLogged In - */ - public func isLoggedIn(response: @escaping Web3ResponseCompletion) { - let request = BasicRPCRequest(method: UserMethod.magic_auth_is_logged_in.rawValue, params: []) - self.provider.send(request: request, response: response) - } - - public func isLoggedIn() -> Promise { - return Promise { resolver in - isLoggedIn(response: promiseResolver(resolver)) - } - } - - /** - * Update Email - */ - public func updateEmail(_ configuration: UpdateEmailConfiguration, response: @escaping Web3ResponseCompletion) { - - let request = RPCRequest<[UpdateEmailConfiguration]>(method: UserMethod.magic_auth_update_email.rawValue, params: [configuration]) - - return self.provider.send(request: request, response: response) - } - - public func updateEmail(_ configuration: UpdateEmailConfiguration) -> Promise { - return Promise { resolver in - updateEmail(configuration, response: promiseResolver(resolver)) - } - } - - public func updateEmail(_ configuration: UpdateEmailConfiguration, eventLog: Bool) -> MagicEventPromise { - return MagicEventPromise (eventCenter: self.magicEventCenter, eventLog: eventLog){ resolver in - self.updateEmail(configuration, response: promiseResolver(resolver)) - } - } - - /** - Logout - */ - public func logout (response: @escaping Web3ResponseCompletion) { - let request = BasicRPCRequest(method: UserMethod.magic_auth_logout.rawValue, params: []) - self.provider.send(request: request, response: response) - } - - public func logout() -> Promise { - return Promise { resolver in - logout(response: promiseResolver(resolver)) - } - } - /** - showSettings - */ - public func showSettings(response: @escaping Web3ResponseCompletion) { - let request = BasicRPCRequest(method: UserMethod.magic_auth_settings.rawValue, params: []) - self.provider.send(request: request, response: response) - } - - public func showSettings() -> Promise { - return Promise { resolver in - showSettings(response: promiseResolver(resolver)) - } - } - - /** - updatePhoneNumber - */ - public func updatePhoneNumber(response: @escaping Web3ResponseCompletion) { - let request = BasicRPCRequest(method: UserMethod.magic_auth_update_phone_number.rawValue, params: []) - self.provider.send(request: request, response: response) - } - - public func updatePhoneNumber() -> Promise { - return Promise { resolver in - updatePhoneNumber(response: promiseResolver(resolver)) - } - } - - /** - recoverAccount - */ - public func recoverAccount(_ configuration: RecoverAccountConfiguration, response: @escaping Web3ResponseCompletion) { - - let request = RPCRequest<[RecoverAccountConfiguration]>(method: UserMethod.magic_auth_recover_account.rawValue, params: [configuration]) - - return self.provider.send(request: request, response: response) - } - - public func recoverAccount(_ configuration: RecoverAccountConfiguration) -> Promise { - return Promise { resolver in - recoverAccount(configuration, response: promiseResolver(resolver)) - } - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserResponse.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserResponse.swift deleted file mode 100644 index a6324842e..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/User/UserResponse.swift +++ /dev/null @@ -1,20 +0,0 @@ -// -// UserResponse.swift -// Magic -// -// Created by Jerry Liu on 3/16/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 - -public protocol MagicResponse: Codable {} - -/// Get Id Token configuration -public struct UserMetadata: MagicResponse { - - public let issuer: String? - public let publicAddress: String? - public let email: String? -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/EIP712TypedData.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/EIP712TypedData.swift deleted file mode 100644 index 616fbb7b6..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/EIP712TypedData.swift +++ /dev/null @@ -1,108 +0,0 @@ -// -// EthereumTypedData.swift -// Web3 -// -// Created by Yehor Popovych on 3/19/19. -// From: https://github.com/Boilertalk/Web3.swift/pull/75/commits/24c556f970115d15d38a4497952767fc4582b2b2 -import Foundation -import MagicSDK_Web3 - - -// MARK: - EIP 712 -public struct EIP712TypedData: Codable, Equatable { - public struct `Type`: Codable, Equatable { - let name: String - let type: String - } - - public struct Domain: Codable, Equatable { - let name: String? - let version: String? - let chainId: Int? - let verifyingContract: String? - let salt: UInt32? - } - - public let types: Dictionary> - public let primaryType: String - public let domain: Domain - public let message: Dictionary - - public init( - primaryType: String, - domain: Domain, - types: Dictionary>, - message: Dictionary - ) { - self.primaryType = primaryType - self.domain = domain - self.types = types - self.message = message - } -} - -public struct SignTypedDataCallParams: Codable, Equatable { - public let account: EthereumAddress - public let data: EIP712TypedData - - public init(account: EthereumAddress, data: EIP712TypedData) { - self.account = account - self.data = data - } - - public init(from decoder: Decoder) throws { - var container = try decoder.unkeyedContainer() - let account = try container.decode(EthereumAddress.self) - let data = try container.decode(EIP712TypedData.self) - self.init(account: account, data: data) - } - - public func encode(to encoder: Encoder) throws { - var container = encoder.unkeyedContainer() - try container.encode(account) - try container.encode(data) - } -} - - -// MARK: - EIP 712 legacy -public struct EIP712TypedDataLegacyFields: Codable, Equatable { - - public let type: String - public let name: String - public let value: String - - public init( - type: String, - name: String, - value: String - ) { - self.type = type - self.name = name - self.value = value - } -} - - -public struct SignTypedDataLegacyCallParams: Codable, Equatable { - public let data: [EIP712TypedDataLegacyFields] - public let account: EthereumAddress - - public init(data: [EIP712TypedDataLegacyFields], account: EthereumAddress) { - self.data = data - self.account = account - } - - public init(from decoder: Decoder) throws { - var container = try decoder.unkeyedContainer() - let data = try container.decode(EIP712TypedDataLegacyFields.self) - let account = try container.decode(EthereumAddress.self) - self.init(data: [data], account: account) - } - - public func encode(to encoder: Encoder) throws { - var container = encoder.unkeyedContainer() - try container.encode(data) - try container.encode(account) - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/JSONValue.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/JSONValue.swift deleted file mode 100644 index 8070c33e6..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/JSONValue.swift +++ /dev/null @@ -1,144 +0,0 @@ -// -// JSONValue.swift -// Web3 -// -// Created by Yehor Popovych on 3/19/19. -// from https://github.com/Boilertalk/Web3.swift/pull/75/commits/24c556f970115d15d38a4497952767fc4582b2b2 -import Foundation - -public enum JSONValue: Equatable { - case null - case bool(Bool) - case number(Double) - case string(String) - case array(Array) - case object(Dictionary) -} - -extension JSONValue: Codable { - public func encode(to encoder: Encoder) throws { - var container = encoder.singleValueContainer() - switch self { - case let .array(array): - try container.encode(array) - case let .object(object): - try container.encode(object) - case let .string(string): - try container.encode(string) - case let .number(number): - try container.encode(number) - case let .bool(bool): - try container.encode(bool) - case .null: - try container.encodeNil() - } - } - - public init(from decoder: Decoder) throws { - let container = try decoder.singleValueContainer() - if let object = try? container.decode([String: JSONValue].self) { - self = .object(object) - } else if let array = try? container.decode([JSONValue].self) { - self = .array(array) - } else if let string = try? container.decode(String.self) { - self = .string(string) - } else if let bool = try? container.decode(Bool.self) { - self = .bool(bool) - } else if let number = try? container.decode(Double.self) { - self = .number(number) - } else if container.decodeNil() { - self = .null - } else { - throw DecodingError.dataCorrupted( - .init(codingPath: decoder.codingPath, debugDescription: "Invalid JSON value.") - ) - } - } -} - -extension JSONValue: CustomDebugStringConvertible { - public var debugDescription: String { - switch self { - case .string(let str): - return str.debugDescription - case .number(let num): - return num.debugDescription - case .bool(let bool): - return bool.description - case .null: - return "null" - default: - let encoder = JSONEncoder() - encoder.outputFormatting = [.prettyPrinted] - return try! String(data: encoder.encode(self), encoding: .utf8)! - } - } -} - -public extension JSONValue { - /// Return the string value if this is a `.string`, otherwise `nil` - var string: String? { - if case .string(let value) = self { - return value - } - return nil - } - - /// Return the double value if this is a `.number`, otherwise `nil` - var number: Double? { - if case .number(let value) = self { - return value - } - return nil - } - - /// Return the bool value if this is a `.bool`, otherwise `nil` - var bool: Bool? { - if case .bool(let value) = self { - return value - } - return nil - } - - /// Return the object value if this is an `.object`, otherwise `nil` - var objec: Dictionary? { - if case .object(let value) = self { - return value - } - return nil - } - - /// Return the array value if this is an `.array`, otherwise `nil` - var array: Array? { - if case .array(let value) = self { - return value - } - return nil - } - - /// Return `true` if this is `.null` - var isNull: Bool { - if case .null = self { - return true - } - return false - } - - /// If this is an `.array`, return item at index - /// - /// If this is not an `.array` or the index is out of bounds, returns `nil`. - subscript(index: Int) -> JSONValue? { - if case .array(let arr) = self, arr.indices.contains(index) { - return arr[index] - } - return nil - } - - /// If this is an `.object`, return item at key - subscript(key: String) -> JSONValue? { - if case .object(let dict) = self { - return dict[key] - } - return nil - } -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/Web3Extension.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/Web3Extension.swift deleted file mode 100644 index f63e733ed..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Modules/Web3/Web3Extension.swift +++ /dev/null @@ -1,136 +0,0 @@ -// -// Web3Extension.swift -// Magic -// -// Created by Jerry Liu on 2/9/20. -// Copyright © 2020 Magic Labs Inc. All rights reserved. -// - -import Foundation -import MagicSDK_Web3 -import PromiseKit - -// MARK: - web3 extension with closure -public extension Web3.Eth { - - func getCoinbase(response: @escaping Web3.Web3ResponseCompletion) { - let req = BasicRPCRequest( - id: properties.rpcId, - jsonrpc: Web3.jsonrpc, - method: "eth_coinbase", - params: [] - ) - properties.provider.send(request: req, response: response) - } - - func sign(from: EthereumAddress, message: EthereumData, response: @escaping Web3.Web3ResponseCompletion) { - let req = RPCRequest( - id: properties.rpcId, - jsonrpc: Web3.jsonrpc, - method: "eth_sign", - params: [from, message] - ) - properties.provider.send(request: req, response: response) - } - - func signTypedDataV1( - data: [EIP712TypedDataLegacyFields], - account: EthereumAddress, - response: @escaping Web3ResponseCompletion - ) { - let req = RPCRequest( - id: properties.rpcId, - jsonrpc: Web3.jsonrpc, - method: "eth_signTypedData", - params: SignTypedDataLegacyCallParams( - data: data, account: account - ) - ) - properties.provider.send(request: req, response: response) - } - - func signTypedDataV3( - account: EthereumAddress, - data: EIP712TypedData, - response: @escaping Web3ResponseCompletion - ) { - let req = RPCRequest( - id: properties.rpcId, - jsonrpc: Web3.jsonrpc, - method: "eth_signTypedData_v3", - params: SignTypedDataCallParams( - account: account, data: data - ) - ) - properties.provider.send(request: req, response: response) - } - - func signTypedDataV4( - account: EthereumAddress, - data: EIP712TypedData, - response: @escaping Web3ResponseCompletion - ) { - let req = RPCRequest( - id: properties.rpcId, - jsonrpc: Web3.jsonrpc, - method: "eth_signTypedData_v4", - params: SignTypedDataCallParams( - account: account, data: data - ) - ) - properties.provider.send(request: req, response: response) - } -} - -// MARK: - web3 extension Promises -/// -public extension Web3.Eth { - - func getCoinbase() -> Promise { - return Promise { resolver in - getCoinbase(response: promiseResolver(resolver)) - } - } - - func sign(from: EthereumAddress, message: EthereumData) -> Promise { - return Promise { resolver in - sign(from: from, message: message, response: promiseResolver(resolver)) - } - } - - func signTypedDataLegacy( - account: EthereumAddress, data: [EIP712TypedDataLegacyFields]) -> Promise { - return Promise { resolver in - signTypedDataV1(data: data, account: account, response: promiseResolver(resolver)) - } - } - - func signTypedData( - account: EthereumAddress, data: EIP712TypedData) -> Promise { - return Promise { resolver in - signTypedDataV3(account: account, data: data, response: promiseResolver(resolver)) - } - } - - func signTypedDataV4( - account: EthereumAddress, data: EIP712TypedData) -> Promise { - return Promise { resolver in - signTypedDataV4(account: account, data: data, response: promiseResolver(resolver)) - } - } -} - -public extension RPCRequest { - - init(method: String, params: Params) { - self = RPCRequest(id: generateRandomId(), jsonrpc: "2.0", method: method, params: params) - } -} - -/// Represents distinct Ethereum Networks -/// -/// Note: Conforms to Hashable so that we can use these as a Dictionary key -public enum EthNetwork: String { - case mainnet - case goerli -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Number.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Number.swift deleted file mode 100644 index 04cd8dd59..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Number.swift +++ /dev/null @@ -1,12 +0,0 @@ -// -// Number.swift -// Magic -// -// Created by Jerry Liu on 3/11/20. -// - -import Foundation - -public func generateRandomId() -> Int{ - return Int.random(in: 1000..<100000) -} diff --git a/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Query.swift b/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Query.swift deleted file mode 100644 index 09f7aa14c..000000000 --- a/dydx/Pods/MagicSDK/Sources/MagicSDK/Utilities/Query.swift +++ /dev/null @@ -1,25 +0,0 @@ -// -// Query.swift -// Magic -// -// Created by Jerry Liu on 2/5/20. -// - -import Foundation - -enum QueryConstructError: Error { - case generationFailed(code: String) -} - -public func btoa(jsonString: String) -> String { - if let utf8str = jsonString.data(using: String.Encoding.utf8) { - let base64 = utf8str.base64EncodedString(options: Data.Base64EncodingOptions(rawValue: 0)) - return base64 - } - return "" -} - -func atob(encodedString: String) -> String { - let decodedData = Data(base64Encoded: encodedString)! - return String(data: decodedData, encoding: .utf8)! -} diff --git a/dydx/dydxStateManager/dydxStateManager/Protocol Implementations/AbacusRestImp.swift b/dydx/dydxStateManager/dydxStateManager/Protocol Implementations/AbacusRestImp.swift index 85c7f8b4d..00821496b 100644 --- a/dydx/dydxStateManager/dydxStateManager/Protocol Implementations/AbacusRestImp.swift +++ b/dydx/dydxStateManager/dydxStateManager/Protocol Implementations/AbacusRestImp.swift @@ -27,7 +27,7 @@ final public class AbacusRestImp: Abacus.RestProtocol { processRest(url: url, headers: headers, body: nil, verb: "GET", callback: callback) } - public func post(url: String, headers: [String: String]?, body: String?, callback: @escaping (String?, KotlinInt) -> Void) { + public func post(url: String, headers: [String: String]?, body: String?, callback_ callback: @escaping (String?, KotlinInt) -> Void) { processRest(url: url, headers: headers, body: body, verb: "POST", callback: callback) } diff --git a/scripts/install.command b/scripts/install.command index b4ea58173..1a23c49d5 100644 --- a/scripts/install.command +++ b/scripts/install.command @@ -4,7 +4,7 @@ # export DYDX_IOS_ROOT="$HOME/path/to/ios" # If not set, use "~/native-ios" -ios_root_dir=${DYDX_IOS_ROOT:-"$HOME/native-ios"} +ios_root_dir=${DYDX_IOS_ROOT:-"$HOME/v4-native-ios"} echo "Using ios root dir: $ios_root_dir" cd "$ios_root_dir/dydx" || exit 1