From 62464408ff3717b47e420e534b87d9be1b3b06e2 Mon Sep 17 00:00:00 2001 From: Lita Date: Mon, 6 Aug 2018 18:34:04 -0500 Subject: [PATCH] Updates to Wisp --- .DS_Store | Bin 6148 -> 6148 bytes Package.resolved | 35 +- Package.swift | 38 +- .../project.pbxproj | 2745 +++++++---------- ...eshifter-Swift-Transports-Package.xcscheme | 98 +- .../FakePacketTunnelProvider.swift | 57 - .../FakeTCPConnection.swift | 173 -- .../ShapeshifterTesting/FakeUDPSession.swift | 42 - Sources/Wisp/WispCoding.swift | 23 +- Sources/Wisp/WispProtocol.swift | 222 +- Sources/Wisp/WispTCPConnection.swift | 192 +- Tests/WispTests/WispTests.swift | 161 +- 12 files changed, 1599 insertions(+), 2187 deletions(-) delete mode 100644 Sources/ShapeshifterTesting/FakePacketTunnelProvider.swift delete mode 100644 Sources/ShapeshifterTesting/FakeTCPConnection.swift delete mode 100644 Sources/ShapeshifterTesting/FakeUDPSession.swift diff --git a/.DS_Store b/.DS_Store index a6f465a78196569a1b6a9b9639c5200806d38f00..4f2ed1704ee0a02e7d5b98b46c599ff633779e4a 100644 GIT binary patch delta 21 ccmZoMXffE3!^$MoI603sfiYn7c~(;)08E(%qyPW_ delta 21 ccmZoMXffE3!^)&JadIAO0%O7E^Q@*q08dc{>;M1& diff --git a/Package.resolved b/Package.resolved index 3d2df63..843acc2 100644 --- a/Package.resolved +++ b/Package.resolved @@ -11,11 +11,11 @@ } }, { - "package": "libsodium", - "repositoryURL": "https://github.com/OperatorFoundation/Clibsodium.git", + "package": "Clibsodium", + "repositoryURL": "https://github.com/tiwoc/Clibsodium.git", "state": { "branch": null, - "revision": "d2e942a7a9e2920fe144fce194381243aa1018a7", + "revision": "2ac72772aae26b2da0b15c253d9bb79ba452f66a", "version": "1.0.0" } }, @@ -33,8 +33,17 @@ "repositoryURL": "https://github.com/krzyzanowskim/CryptoSwift.git", "state": { "branch": null, - "revision": "526d5e91569b30857d8def9ea22ad7265b70d238", - "version": "0.9.0" + "revision": "3f6869c469abf3e2ebefe3b6baef4bfac3aac305", + "version": "0.11.0" + } + }, + { + "package": "Datable", + "repositoryURL": "https://github.com/OperatorFoundation/Datable.git", + "state": { + "branch": null, + "revision": "814c6b1173f74672732d094ad0abe7e5d2eac232", + "version": "0.1.0" } }, { @@ -56,12 +65,12 @@ } }, { - "package": "swift-sodium", - "repositoryURL": "https://github.com/OperatorFoundation/swift-sodium.git", + "package": "Sodium", + "repositoryURL": "https://github.com/consuelita/swift-sodium", "state": { "branch": null, - "revision": "22cdbe7088ac3c009a5aff8abc6d73b0e6b31b02", - "version": "0.5.3" + "revision": "8e60308d8021cece0eb627a1a4cadc3cb78be38b", + "version": "0.6.2" } }, { @@ -69,8 +78,8 @@ "repositoryURL": "https://github.com/OperatorFoundation/SwiftQueue.git", "state": { "branch": null, - "revision": "047666d1e4d804d090ae9588aa5bfc9b77c800c3", - "version": "0.0.1" + "revision": "0e5979acbb104516a427bb2bb09debc50ca100b4", + "version": "0.0.3" } }, { @@ -78,8 +87,8 @@ "repositoryURL": "https://github.com/OperatorFoundation/Transport.git", "state": { "branch": null, - "revision": "1e49592a44568ffb735385575f85058394d24a65", - "version": "0.0.4" + "revision": "538b90bce4153cb79af9b1124fff6723ca76f445", + "version": "0.0.12" } } ] diff --git a/Package.swift b/Package.swift index 9be4c09..156d597 100644 --- a/Package.swift +++ b/Package.swift @@ -7,44 +7,38 @@ let package = Package( name: "Shapeshifter-Swift-Transports", products: [ // Products define the executables and libraries produced by a package, and make them visible to other packages. - .library( - name: "Meek", - targets: ["Meek"]), +// .library( +// name: "Meek", +// targets: ["Meek"]), .library( name: "Wisp", targets: ["Wisp"]), - .library( - name: "ShapeshifterTesting", - targets: ["ShapeshifterTesting"]) ], dependencies: [ // Dependencies declare other packages that this package depends on. - .package(url: "https://github.com/OperatorFoundation/Transport.git", from: "0.0.3"), - .package(url: "https://github.com/IBM-Swift/CommonCrypto.git", from: "0.1.5"), - .package(url: "https://github.com/OperatorFoundation/swift-sodium.git", from: "0.5.3"), - .package(url: "https://github.com/krzyzanowskim/CryptoSwift.git", from: "0.7.2"), + .package(url: "https://github.com/OperatorFoundation/Transport.git", from: "0.0.11"), + //.package(url: "https://github.com/OperatorFoundation/swift-sodium.git", from: "0.5.3"), + .package(url: "https://github.com/consuelita/swift-sodium", from: "0.6.2"), + .package(url: "https://github.com/krzyzanowskim/CryptoSwift.git", from: "0.11.0"), .package(url: "https://github.com/Bouke/HKDF.git", from: "3.0.1"), .package(url: "https://github.com/OperatorFoundation/Elligator.git", from: "0.1.0"), - .package(url: "https://github.com/OperatorFoundation/SwiftQueue.git", from: "0.0.1") + .package(url: "https://github.com/OperatorFoundation/SwiftQueue.git", from: "0.0.3") ], targets: [ // Targets are the basic building blocks of a package. A target can define a module or a test suite. // Targets can depend on other targets in this package, and on products in packages which this package depends on. - .target( - name: "Meek", - dependencies: ["CryptoSwift", "Transport", "SwiftQueue"]), - .testTarget( - name: "MeekTests", - dependencies: ["Meek", "ShapeshifterTesting"]), +// .target( +// name: "Meek", +// dependencies: ["CryptoSwift", "Transport", "SwiftQueue"]), +// .testTarget( +// name: "MeekTests", +// dependencies: ["Meek", "ShapeshifterTesting"]), .target( name: "Wisp", - dependencies: ["CommonCrypto", "Sodium", "CryptoSwift", "HKDF", "Elligator", "Transport", "SwiftQueue"]), + dependencies: ["Sodium", "CryptoSwift", "HKDF", "Elligator", "Transport", "SwiftQueue"]), .testTarget( name: "WispTests", - dependencies: ["Wisp", "ShapeshifterTesting"]), - .target( - name: "ShapeshifterTesting", - dependencies: ["Transport"]), + dependencies: ["Wisp"]), ] ) diff --git a/Shapeshifter-Swift-Transports.xcodeproj/project.pbxproj b/Shapeshifter-Swift-Transports.xcodeproj/project.pbxproj index fb464fb..24b561f 100644 --- a/Shapeshifter-Swift-Transports.xcodeproj/project.pbxproj +++ b/Shapeshifter-Swift-Transports.xcodeproj/project.pbxproj @@ -7,24 +7,13 @@ objects = { /* Begin PBXAggregateTarget section */ - "CommonCrypto::CommonCrypto::ProductTarget" /* CommonCrypto */ = { - isa = PBXAggregateTarget; - buildConfigurationList = OBJ_199 /* Build configuration list for PBXAggregateTarget "CommonCrypto" */; - buildPhases = ( - ); - dependencies = ( - ); - name = CommonCrypto; - productName = CommonCrypto; - }; "Shapeshifter-Swift-Transports::Shapeshifter-Swift-TransportsPackageTests::ProductTarget" /* Shapeshifter-Swift-TransportsPackageTests */ = { isa = PBXAggregateTarget; - buildConfigurationList = OBJ_385 /* Build configuration list for PBXAggregateTarget "Shapeshifter-Swift-TransportsPackageTests" */; + buildConfigurationList = OBJ_363 /* Build configuration list for PBXAggregateTarget "Shapeshifter-Swift-TransportsPackageTests" */; buildPhases = ( ); dependencies = ( - OBJ_388 /* PBXTargetDependency */, - OBJ_389 /* PBXTargetDependency */, + OBJ_366 /* PBXTargetDependency */, ); name = "Shapeshifter-Swift-TransportsPackageTests"; productName = "Shapeshifter-Swift-TransportsPackageTests"; @@ -32,422 +21,347 @@ /* End PBXAggregateTarget section */ /* Begin PBXBuildFile section */ - OBJ_207 /* AEAD.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_89 /* AEAD.swift */; }; - OBJ_208 /* AEADChaCha20Poly1305.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_90 /* AEADChaCha20Poly1305.swift */; }; - OBJ_209 /* AES.Cryptors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_91 /* AES.Cryptors.swift */; }; - OBJ_210 /* AES.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_92 /* AES.swift */; }; - OBJ_211 /* Array+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_93 /* Array+Extension.swift */; }; - OBJ_212 /* Authenticator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_94 /* Authenticator.swift */; }; - OBJ_213 /* BatchedCollection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_95 /* BatchedCollection.swift */; }; - OBJ_214 /* Bit.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_96 /* Bit.swift */; }; - OBJ_215 /* BlockCipher.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_97 /* BlockCipher.swift */; }; - OBJ_216 /* BlockMode.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_99 /* BlockMode.swift */; }; - OBJ_217 /* BlockModeOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_100 /* BlockModeOptions.swift */; }; - OBJ_218 /* BlockModeWorker.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_101 /* BlockModeWorker.swift */; }; - OBJ_219 /* CBC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_102 /* CBC.swift */; }; - OBJ_220 /* CFB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_103 /* CFB.swift */; }; - OBJ_221 /* CTR.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_104 /* CTR.swift */; }; - OBJ_222 /* ECB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_105 /* ECB.swift */; }; - OBJ_223 /* OFB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_106 /* OFB.swift */; }; - OBJ_224 /* PCBC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_107 /* PCBC.swift */; }; - OBJ_225 /* RandomAccessBlockModeWorker.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_108 /* RandomAccessBlockModeWorker.swift */; }; - OBJ_226 /* Blowfish.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_109 /* Blowfish.swift */; }; - OBJ_227 /* CMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_110 /* CMAC.swift */; }; - OBJ_228 /* ChaCha20.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_111 /* ChaCha20.swift */; }; - OBJ_229 /* Checksum.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_112 /* Checksum.swift */; }; - OBJ_230 /* Cipher.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_113 /* Cipher.swift */; }; - OBJ_231 /* Collection+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_114 /* Collection+Extension.swift */; }; - OBJ_232 /* CompactMap.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_115 /* CompactMap.swift */; }; - OBJ_233 /* Cryptors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_116 /* Cryptors.swift */; }; - OBJ_234 /* Digest.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_117 /* Digest.swift */; }; - OBJ_235 /* DigestType.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_118 /* DigestType.swift */; }; - OBJ_236 /* AES+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_120 /* AES+Foundation.swift */; }; - OBJ_237 /* Array+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_121 /* Array+Foundation.swift */; }; - OBJ_238 /* Blowfish+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_122 /* Blowfish+Foundation.swift */; }; - OBJ_239 /* ChaCha20+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_123 /* ChaCha20+Foundation.swift */; }; - OBJ_240 /* Data+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_124 /* Data+Extension.swift */; }; - OBJ_241 /* HMAC+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_125 /* HMAC+Foundation.swift */; }; - OBJ_242 /* Rabbit+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_126 /* Rabbit+Foundation.swift */; }; - OBJ_243 /* String+FoundationExtension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_127 /* String+FoundationExtension.swift */; }; - OBJ_244 /* Utils+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_128 /* Utils+Foundation.swift */; }; - OBJ_245 /* Generics.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_129 /* Generics.swift */; }; - OBJ_246 /* HKDF.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_130 /* HKDF.swift */; }; - OBJ_247 /* HMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_131 /* HMAC.swift */; }; - OBJ_248 /* Int+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_132 /* Int+Extension.swift */; }; - OBJ_249 /* MD5.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_133 /* MD5.swift */; }; - OBJ_250 /* NoPadding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_134 /* NoPadding.swift */; }; - OBJ_251 /* Operators.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_135 /* Operators.swift */; }; - OBJ_252 /* PBKDF1.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_137 /* PBKDF1.swift */; }; - OBJ_253 /* PBKDF2.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_138 /* PBKDF2.swift */; }; - OBJ_254 /* PKCS5.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_139 /* PKCS5.swift */; }; - OBJ_255 /* PKCS7.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_140 /* PKCS7.swift */; }; - OBJ_256 /* PKCS7Padding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_141 /* PKCS7Padding.swift */; }; - OBJ_257 /* Padding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_142 /* Padding.swift */; }; - OBJ_258 /* Poly1305.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_143 /* Poly1305.swift */; }; - OBJ_259 /* Rabbit.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_144 /* Rabbit.swift */; }; - OBJ_260 /* RandomAccessCryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_145 /* RandomAccessCryptor.swift */; }; - OBJ_261 /* RandomBytesSequence.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_146 /* RandomBytesSequence.swift */; }; - OBJ_262 /* SHA1.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_147 /* SHA1.swift */; }; - OBJ_263 /* SHA2.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_148 /* SHA2.swift */; }; - OBJ_264 /* SHA3.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_149 /* SHA3.swift */; }; - OBJ_265 /* SecureBytes.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_150 /* SecureBytes.swift */; }; - OBJ_266 /* String+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_151 /* String+Extension.swift */; }; - OBJ_267 /* UInt16+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_152 /* UInt16+Extension.swift */; }; - OBJ_268 /* UInt32+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_153 /* UInt32+Extension.swift */; }; - OBJ_269 /* UInt64+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_154 /* UInt64+Extension.swift */; }; - OBJ_270 /* UInt8+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_155 /* UInt8+Extension.swift */; }; - OBJ_271 /* Updatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_156 /* Updatable.swift */; }; - OBJ_272 /* Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_157 /* Utils.swift */; }; - OBJ_273 /* ZeroPadding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_158 /* ZeroPadding.swift */; }; - OBJ_280 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_159 /* Package.swift */; }; - OBJ_286 /* Crypto.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_75 /* Crypto.swift */; }; - OBJ_287 /* Cryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_76 /* Cryptor.swift */; }; - OBJ_288 /* Digest.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_77 /* Digest.swift */; }; - OBJ_289 /* HMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_78 /* HMAC.swift */; }; - OBJ_290 /* KeyDerivation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_79 /* KeyDerivation.swift */; }; - OBJ_291 /* Random.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_80 /* Random.swift */; }; - OBJ_292 /* Status.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_81 /* Status.swift */; }; - OBJ_293 /* StreamCryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_82 /* StreamCryptor.swift */; }; - OBJ_294 /* Updatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_83 /* Updatable.swift */; }; - OBJ_295 /* Utilities.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_84 /* Utilities.swift */; }; - OBJ_302 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_85 /* Package.swift */; }; - OBJ_308 /* Elligator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_68 /* Elligator.swift */; }; - OBJ_310 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; - OBJ_311 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; - OBJ_320 /* ElligatorObjC.mm in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_63 /* ElligatorObjC.mm */; }; + OBJ_214 /* AEAD.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_81 /* AEAD.swift */; }; + OBJ_215 /* AEADChaCha20Poly1305.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_82 /* AEADChaCha20Poly1305.swift */; }; + OBJ_216 /* AES.Cryptors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_83 /* AES.Cryptors.swift */; }; + OBJ_217 /* AES.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_84 /* AES.swift */; }; + OBJ_218 /* Array+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_85 /* Array+Extension.swift */; }; + OBJ_219 /* Authenticator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_86 /* Authenticator.swift */; }; + OBJ_220 /* BatchedCollection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_87 /* BatchedCollection.swift */; }; + OBJ_221 /* Bit.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_88 /* Bit.swift */; }; + OBJ_222 /* BlockCipher.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_89 /* BlockCipher.swift */; }; + OBJ_223 /* BlockDecryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_90 /* BlockDecryptor.swift */; }; + OBJ_224 /* BlockEncryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_91 /* BlockEncryptor.swift */; }; + OBJ_225 /* BlockMode.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_93 /* BlockMode.swift */; }; + OBJ_226 /* BlockModeOptions.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_94 /* BlockModeOptions.swift */; }; + OBJ_227 /* CBC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_95 /* CBC.swift */; }; + OBJ_228 /* CFB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_96 /* CFB.swift */; }; + OBJ_229 /* CTR.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_97 /* CTR.swift */; }; + OBJ_230 /* CipherModeWorker.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_98 /* CipherModeWorker.swift */; }; + OBJ_231 /* ECB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_99 /* ECB.swift */; }; + OBJ_232 /* GCM.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_100 /* GCM.swift */; }; + OBJ_233 /* OFB.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_101 /* OFB.swift */; }; + OBJ_234 /* PCBC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_102 /* PCBC.swift */; }; + OBJ_235 /* Blowfish.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_103 /* Blowfish.swift */; }; + OBJ_236 /* CMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_104 /* CMAC.swift */; }; + OBJ_237 /* ChaCha20.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_105 /* ChaCha20.swift */; }; + OBJ_238 /* Checksum.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_106 /* Checksum.swift */; }; + OBJ_239 /* Cipher.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_107 /* Cipher.swift */; }; + OBJ_240 /* Collection+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_108 /* Collection+Extension.swift */; }; + OBJ_241 /* CompactMap.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_109 /* CompactMap.swift */; }; + OBJ_242 /* Cryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_110 /* Cryptor.swift */; }; + OBJ_243 /* Cryptors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_111 /* Cryptors.swift */; }; + OBJ_244 /* Digest.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_112 /* Digest.swift */; }; + OBJ_245 /* DigestType.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_113 /* DigestType.swift */; }; + OBJ_246 /* AES+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_115 /* AES+Foundation.swift */; }; + OBJ_247 /* Array+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_116 /* Array+Foundation.swift */; }; + OBJ_248 /* Blowfish+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_117 /* Blowfish+Foundation.swift */; }; + OBJ_249 /* ChaCha20+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_118 /* ChaCha20+Foundation.swift */; }; + OBJ_250 /* Data+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_119 /* Data+Extension.swift */; }; + OBJ_251 /* HMAC+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_120 /* HMAC+Foundation.swift */; }; + OBJ_252 /* Rabbit+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_121 /* Rabbit+Foundation.swift */; }; + OBJ_253 /* String+FoundationExtension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_122 /* String+FoundationExtension.swift */; }; + OBJ_254 /* Utils+Foundation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_123 /* Utils+Foundation.swift */; }; + OBJ_255 /* Generics.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_124 /* Generics.swift */; }; + OBJ_256 /* HKDF.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_125 /* HKDF.swift */; }; + OBJ_257 /* HMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_126 /* HMAC.swift */; }; + OBJ_258 /* Int+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_127 /* Int+Extension.swift */; }; + OBJ_259 /* MD5.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_128 /* MD5.swift */; }; + OBJ_260 /* NoPadding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_129 /* NoPadding.swift */; }; + OBJ_261 /* Operators.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_130 /* Operators.swift */; }; + OBJ_262 /* PBKDF1.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_132 /* PBKDF1.swift */; }; + OBJ_263 /* PBKDF2.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_133 /* PBKDF2.swift */; }; + OBJ_264 /* PKCS5.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_134 /* PKCS5.swift */; }; + OBJ_265 /* PKCS7.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_135 /* PKCS7.swift */; }; + OBJ_266 /* PKCS7Padding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_136 /* PKCS7Padding.swift */; }; + OBJ_267 /* Padding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_137 /* Padding.swift */; }; + OBJ_268 /* Poly1305.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_138 /* Poly1305.swift */; }; + OBJ_269 /* Rabbit.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_139 /* Rabbit.swift */; }; + OBJ_270 /* RandomBytesSequence.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_140 /* RandomBytesSequence.swift */; }; + OBJ_271 /* SHA1.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_141 /* SHA1.swift */; }; + OBJ_272 /* SHA2.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_142 /* SHA2.swift */; }; + OBJ_273 /* SHA3.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_143 /* SHA3.swift */; }; + OBJ_274 /* SecureBytes.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_144 /* SecureBytes.swift */; }; + OBJ_275 /* StreamEncryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_145 /* StreamEncryptor.swift */; }; + OBJ_276 /* String+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_146 /* String+Extension.swift */; }; + OBJ_277 /* UInt128.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_147 /* UInt128.swift */; }; + OBJ_278 /* UInt16+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_148 /* UInt16+Extension.swift */; }; + OBJ_279 /* UInt32+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_149 /* UInt32+Extension.swift */; }; + OBJ_280 /* UInt64+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_150 /* UInt64+Extension.swift */; }; + OBJ_281 /* UInt8+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_151 /* UInt8+Extension.swift */; }; + OBJ_282 /* Updatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_152 /* Updatable.swift */; }; + OBJ_283 /* Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_153 /* Utils.swift */; }; + OBJ_284 /* ZeroPadding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_154 /* ZeroPadding.swift */; }; + OBJ_291 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_155 /* Package.swift */; }; + OBJ_297 /* Crypto.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_67 /* Crypto.swift */; }; + OBJ_298 /* Cryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_68 /* Cryptor.swift */; }; + OBJ_299 /* Digest.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_69 /* Digest.swift */; }; + OBJ_300 /* HMAC.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_70 /* HMAC.swift */; }; + OBJ_301 /* KeyDerivation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_71 /* KeyDerivation.swift */; }; + OBJ_302 /* Random.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_72 /* Random.swift */; }; + OBJ_303 /* Status.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_73 /* Status.swift */; }; + OBJ_304 /* StreamCryptor.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_74 /* StreamCryptor.swift */; }; + OBJ_305 /* Updatable.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_75 /* Updatable.swift */; }; + OBJ_306 /* Utilities.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_76 /* Utilities.swift */; }; + OBJ_313 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_77 /* Package.swift */; }; + OBJ_319 /* Elligator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_60 /* Elligator.swift */; }; + OBJ_321 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; OBJ_322 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; - OBJ_329 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_69 /* Package.swift */; }; - OBJ_335 /* HKDF.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_72 /* HKDF.swift */; }; - OBJ_337 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; - OBJ_344 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_71 /* Package.swift */; }; - OBJ_350 /* MeekTCPConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_9 /* MeekTCPConnection.swift */; }; - OBJ_352 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; - OBJ_353 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; - OBJ_354 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; - OBJ_365 /* MeekTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_24 /* MeekTests.swift */; }; - OBJ_367 /* ShapeshifterTesting.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Shapeshifter-Swift-Transports::ShapeshifterTesting::Product" /* ShapeshifterTesting.framework */; }; - OBJ_368 /* Meek.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Shapeshifter-Swift-Transports::Meek::Product" /* Meek.framework */; }; - OBJ_369 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; - OBJ_370 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; - OBJ_371 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; - OBJ_383 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_6 /* Package.swift */; }; - OBJ_395 /* FakePacketTunnelProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_11 /* FakePacketTunnelProvider.swift */; }; - OBJ_396 /* FakeTCPConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_12 /* FakeTCPConnection.swift */; }; - OBJ_397 /* FakeUDPSession.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_13 /* FakeUDPSession.swift */; }; - OBJ_399 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; - OBJ_406 /* Auth.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_163 /* Auth.swift */; }; - OBJ_407 /* Box.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_164 /* Box.swift */; }; - OBJ_408 /* GenericHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_165 /* GenericHash.swift */; }; - OBJ_409 /* KeyDerivation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_166 /* KeyDerivation.swift */; }; - OBJ_410 /* KeyExchange.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_167 /* KeyExchange.swift */; }; - OBJ_411 /* PWHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_168 /* PWHash.swift */; }; - OBJ_412 /* RandomBytes.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_169 /* RandomBytes.swift */; }; - OBJ_413 /* SecretBox.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_170 /* SecretBox.swift */; }; - OBJ_414 /* SecretStream.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_171 /* SecretStream.swift */; }; - OBJ_415 /* ShortHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_172 /* ShortHash.swift */; }; - OBJ_416 /* Sign.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_173 /* Sign.swift */; }; - OBJ_417 /* Sodium.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_174 /* Sodium.swift */; }; - OBJ_418 /* Stream.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_175 /* Stream.swift */; }; - OBJ_419 /* Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_176 /* Utils.swift */; }; - OBJ_425 /* LinkedList.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_29 /* LinkedList.swift */; }; - OBJ_426 /* Queue.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_30 /* Queue.swift */; }; - OBJ_433 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_31 /* Package.swift */; }; - OBJ_438 /* PacketTunnelProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_179 /* PacketTunnelProvider.swift */; }; - OBJ_439 /* TCPConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_180 /* TCPConnection.swift */; }; - OBJ_440 /* UDPSession.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_181 /* UDPSession.swift */; }; - OBJ_447 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_182 /* Package.swift */; }; - OBJ_453 /* WispCoding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_15 /* WispCoding.swift */; }; - OBJ_454 /* WispConstants.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_16 /* WispConstants.swift */; }; - OBJ_455 /* WispErrors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_17 /* WispErrors.swift */; }; - OBJ_456 /* WispProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_18 /* WispProtocol.swift */; }; - OBJ_457 /* WispTCPConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_19 /* WispTCPConnection.swift */; }; - OBJ_459 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; - OBJ_460 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; - OBJ_461 /* Elligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::Elligator::Product" /* Elligator.framework */; }; - OBJ_462 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; - OBJ_463 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; - OBJ_464 /* HKDF.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "HKDF::HKDF::Product" /* HKDF.framework */; }; - OBJ_465 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; - OBJ_466 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; - OBJ_467 /* Sodium.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "swift-sodium::Sodium::Product" /* Sodium.framework */; }; - OBJ_481 /* WispTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_22 /* WispTests.swift */; }; - OBJ_483 /* ShapeshifterTesting.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Shapeshifter-Swift-Transports::ShapeshifterTesting::Product" /* ShapeshifterTesting.framework */; }; - OBJ_484 /* Wisp.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */; }; - OBJ_485 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; - OBJ_486 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; - OBJ_487 /* Elligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::Elligator::Product" /* Elligator.framework */; }; - OBJ_488 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; - OBJ_489 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; - OBJ_490 /* HKDF.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "HKDF::HKDF::Product" /* HKDF.framework */; }; - OBJ_491 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; - OBJ_492 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; - OBJ_493 /* Sodium.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "swift-sodium::Sodium::Product" /* Sodium.framework */; }; - OBJ_509 /* crypto_verify_32.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_34 /* crypto_verify_32.cc */; }; - OBJ_510 /* elligator.cpp in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_35 /* elligator.cpp */; }; - OBJ_511 /* fe_add.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_36 /* fe_add.cc */; }; - OBJ_512 /* fe_cmov.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_37 /* fe_cmov.cc */; }; - OBJ_513 /* fe_copy.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_38 /* fe_copy.cc */; }; - OBJ_514 /* fe_frombytes.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_39 /* fe_frombytes.cc */; }; - OBJ_515 /* fe_invert.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_40 /* fe_invert.cc */; }; - OBJ_516 /* fe_isnonzero.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_41 /* fe_isnonzero.cc */; }; - OBJ_517 /* fe_mul.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_42 /* fe_mul.cc */; }; - OBJ_518 /* fe_neg.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_43 /* fe_neg.cc */; }; - OBJ_519 /* fe_sq.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_44 /* fe_sq.cc */; }; - OBJ_520 /* fe_sq2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_45 /* fe_sq2.cc */; }; - OBJ_521 /* fe_sub.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_46 /* fe_sub.cc */; }; - OBJ_522 /* fe_tobytes.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_47 /* fe_tobytes.cc */; }; - OBJ_523 /* ge_madd.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_48 /* ge_madd.cc */; }; - OBJ_524 /* ge_p1p1_to_p2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_49 /* ge_p1p1_to_p2.cc */; }; - OBJ_525 /* ge_p1p1_to_p3.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_50 /* ge_p1p1_to_p3.cc */; }; - OBJ_526 /* ge_p2_dbl.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_51 /* ge_p2_dbl.cc */; }; - OBJ_527 /* ge_p3_0.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_52 /* ge_p3_0.cc */; }; - OBJ_528 /* ge_p3_dbl.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_53 /* ge_p3_dbl.cc */; }; - OBJ_529 /* ge_p3_to_p2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_54 /* ge_p3_to_p2.cc */; }; - OBJ_530 /* ge_precomp_0.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_55 /* ge_precomp_0.cc */; }; - OBJ_531 /* ge_scalarmult_base.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_56 /* ge_scalarmult_base.cc */; }; - OBJ_538 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_161 /* Package.swift */; }; + OBJ_331 /* ElligatorObjC.mm in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_55 /* ElligatorObjC.mm */; }; + OBJ_333 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; + OBJ_340 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_61 /* Package.swift */; }; + OBJ_346 /* HKDF.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_64 /* HKDF.swift */; }; + OBJ_348 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; + OBJ_355 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_63 /* Package.swift */; }; + OBJ_361 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_6 /* Package.swift */; }; + OBJ_373 /* Aead.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_158 /* Aead.swift */; }; + OBJ_374 /* Auth.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_159 /* Auth.swift */; }; + OBJ_375 /* Box.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_160 /* Box.swift */; }; + OBJ_376 /* Bytes.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_161 /* Bytes.swift */; }; + OBJ_377 /* ExitCode.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_162 /* ExitCode.swift */; }; + OBJ_378 /* KeyPairGenerator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_164 /* KeyPairGenerator.swift */; }; + OBJ_379 /* KeyPairProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_165 /* KeyPairProtocol.swift */; }; + OBJ_380 /* NonceGenerator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_166 /* NonceGenerator.swift */; }; + OBJ_381 /* SecretKeyGenerator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_167 /* SecretKeyGenerator.swift */; }; + OBJ_382 /* GenericHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_168 /* GenericHash.swift */; }; + OBJ_383 /* KeyDerivation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_169 /* KeyDerivation.swift */; }; + OBJ_384 /* KeyExchange.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_170 /* KeyExchange.swift */; }; + OBJ_385 /* PWHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_171 /* PWHash.swift */; }; + OBJ_386 /* RandomBytes.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_172 /* RandomBytes.swift */; }; + OBJ_387 /* SecretBox.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_173 /* SecretBox.swift */; }; + OBJ_388 /* SecretStream.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_174 /* SecretStream.swift */; }; + OBJ_389 /* ShortHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_175 /* ShortHash.swift */; }; + OBJ_390 /* Sign.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_176 /* Sign.swift */; }; + OBJ_391 /* Sodium.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_177 /* Sodium.swift */; }; + OBJ_392 /* StateStream.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_178 /* StateStream.swift */; }; + OBJ_393 /* Stream.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_179 /* Stream.swift */; }; + OBJ_394 /* Utils.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_180 /* Utils.swift */; }; + OBJ_401 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_181 /* Package.swift */; }; + OBJ_407 /* LinkedList.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_21 /* LinkedList.swift */; }; + OBJ_408 /* Queue.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_22 /* Queue.swift */; }; + OBJ_415 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_23 /* Package.swift */; }; + OBJ_421 /* Connection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_184 /* Connection.swift */; }; + OBJ_422 /* ConnectionFactory.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_185 /* ConnectionFactory.swift */; }; + OBJ_423 /* IPv4Address.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_186 /* IPv4Address.swift */; }; + OBJ_424 /* NWConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_187 /* NWConnection.swift */; }; + OBJ_425 /* NWEndpoint.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_188 /* NWEndpoint.swift */; }; + OBJ_426 /* NWError.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_189 /* NWError.swift */; }; + OBJ_427 /* NWParameters.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_190 /* NWParameters.swift */; }; + OBJ_428 /* NetworkConnectionFactory.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_191 /* NetworkConnectionFactory.swift */; }; + OBJ_435 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_192 /* Package.swift */; }; + OBJ_441 /* WispCoding.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_9 /* WispCoding.swift */; }; + OBJ_442 /* WispConstants.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_10 /* WispConstants.swift */; }; + OBJ_443 /* WispErrors.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_11 /* WispErrors.swift */; }; + OBJ_444 /* WispProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_12 /* WispProtocol.swift */; }; + OBJ_445 /* WispTCPConnection.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_13 /* WispTCPConnection.swift */; }; + OBJ_447 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; + OBJ_448 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; + OBJ_449 /* Elligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::Elligator::Product" /* Elligator.framework */; }; + OBJ_450 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; + OBJ_451 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; + OBJ_452 /* HKDF.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "HKDF::HKDF::Product" /* HKDF.framework */; }; + OBJ_453 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; + OBJ_454 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; + OBJ_455 /* Sodium.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Sodium::Sodium::Product" /* Sodium.framework */; }; + OBJ_469 /* WispTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_16 /* WispTests.swift */; }; + OBJ_471 /* Wisp.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */; }; + OBJ_472 /* SwiftQueue.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */; }; + OBJ_473 /* Transport.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Transport::Transport::Product" /* Transport.framework */; }; + OBJ_474 /* Elligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::Elligator::Product" /* Elligator.framework */; }; + OBJ_475 /* ElligatorObjC.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */; }; + OBJ_476 /* celligator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Elligator::celligator::Product" /* celligator.framework */; }; + OBJ_477 /* HKDF.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "HKDF::HKDF::Product" /* HKDF.framework */; }; + OBJ_478 /* Cryptor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Cryptor::Cryptor::Product" /* Cryptor.framework */; }; + OBJ_479 /* CryptoSwift.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */; }; + OBJ_480 /* Sodium.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "Sodium::Sodium::Product" /* Sodium.framework */; }; + OBJ_495 /* crypto_verify_32.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_26 /* crypto_verify_32.cc */; }; + OBJ_496 /* elligator.cpp in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_27 /* elligator.cpp */; }; + OBJ_497 /* fe_add.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_28 /* fe_add.cc */; }; + OBJ_498 /* fe_cmov.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_29 /* fe_cmov.cc */; }; + OBJ_499 /* fe_copy.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_30 /* fe_copy.cc */; }; + OBJ_500 /* fe_frombytes.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_31 /* fe_frombytes.cc */; }; + OBJ_501 /* fe_invert.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_32 /* fe_invert.cc */; }; + OBJ_502 /* fe_isnonzero.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_33 /* fe_isnonzero.cc */; }; + OBJ_503 /* fe_mul.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_34 /* fe_mul.cc */; }; + OBJ_504 /* fe_neg.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_35 /* fe_neg.cc */; }; + OBJ_505 /* fe_sq.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_36 /* fe_sq.cc */; }; + OBJ_506 /* fe_sq2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_37 /* fe_sq2.cc */; }; + OBJ_507 /* fe_sub.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_38 /* fe_sub.cc */; }; + OBJ_508 /* fe_tobytes.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_39 /* fe_tobytes.cc */; }; + OBJ_509 /* ge_madd.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_40 /* ge_madd.cc */; }; + OBJ_510 /* ge_p1p1_to_p2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_41 /* ge_p1p1_to_p2.cc */; }; + OBJ_511 /* ge_p1p1_to_p3.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_42 /* ge_p1p1_to_p3.cc */; }; + OBJ_512 /* ge_p2_dbl.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_43 /* ge_p2_dbl.cc */; }; + OBJ_513 /* ge_p3_0.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_44 /* ge_p3_0.cc */; }; + OBJ_514 /* ge_p3_dbl.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_45 /* ge_p3_dbl.cc */; }; + OBJ_515 /* ge_p3_to_p2.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_46 /* ge_p3_to_p2.cc */; }; + OBJ_516 /* ge_precomp_0.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_47 /* ge_precomp_0.cc */; }; + OBJ_517 /* ge_scalarmult_base.cc in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_48 /* ge_scalarmult_base.cc */; }; /* End PBXBuildFile section */ /* Begin PBXContainerItemProxy section */ - 468318A220ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Transport::Transport"; - remoteInfo = Transport; - }; - 468318A320ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "SwiftQueue::SwiftQueue"; - remoteInfo = SwiftQueue; - }; - 468318A420ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D640F21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "Transport::Transport"; - remoteInfo = Transport; - }; - 468318A520ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Elligator::Elligator"; - remoteInfo = Elligator; + remoteGlobalIDString = "Cryptor::Cryptor"; + remoteInfo = Cryptor; }; - 468318A620ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641021190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::ElligatorObjC"; remoteInfo = ElligatorObjC; }; - 468318A720ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641121190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::celligator"; remoteInfo = celligator; }; - 468318A820ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Elligator::celligator"; - remoteInfo = celligator; - }; - 468318A920ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Elligator::ElligatorObjC"; - remoteInfo = ElligatorObjC; - }; - 468318AA20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641221190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::celligator"; remoteInfo = celligator; }; - 468318AB20ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "HKDF::HKDF"; - remoteInfo = HKDF; - }; - 468318AC20ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Cryptor::Cryptor"; - remoteInfo = Cryptor; - }; - 468318AD20ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Cryptor::Cryptor"; - remoteInfo = Cryptor; - }; - 468318AE20ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "CryptoSwift::CryptoSwift"; - remoteInfo = CryptoSwift; - }; - 468318AF20ACD19000CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "swift-sodium::Sodium"; - remoteInfo = Sodium; - }; - 468318B020ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641321190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "SwiftQueue::SwiftQueue"; remoteInfo = SwiftQueue; }; - 468318B120ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641421190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Transport::Transport"; remoteInfo = Transport; }; - 468318B220ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641521190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "CryptoSwift::CryptoSwift"; - remoteInfo = CryptoSwift; + remoteGlobalIDString = "Elligator::Elligator"; + remoteInfo = Elligator; }; - 468318B320ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641621190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "Shapeshifter-Swift-Transports::ShapeshifterTesting"; - remoteInfo = ShapeshifterTesting; + remoteGlobalIDString = "Elligator::ElligatorObjC"; + remoteInfo = ElligatorObjC; }; - 468318B420ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641721190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "Shapeshifter-Swift-Transports::Meek"; - remoteInfo = Meek; + remoteGlobalIDString = "Elligator::celligator"; + remoteInfo = celligator; }; - 468318B520ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641821190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "SwiftQueue::SwiftQueue"; - remoteInfo = SwiftQueue; + remoteGlobalIDString = "HKDF::HKDF"; + remoteInfo = HKDF; }; - 468318B620ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641921190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "Transport::Transport"; - remoteInfo = Transport; + remoteGlobalIDString = "Cryptor::Cryptor"; + remoteInfo = Cryptor; }; - 468318B720ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641A21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "CryptoSwift::CryptoSwift"; remoteInfo = CryptoSwift; }; - 468318B820ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641B21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "Shapeshifter-Swift-Transports::ShapeshifterTesting"; - remoteInfo = ShapeshifterTesting; + remoteGlobalIDString = "Sodium::Sodium"; + remoteInfo = Sodium; }; - 468318B920ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641C21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Shapeshifter-Swift-Transports::Wisp"; remoteInfo = Wisp; }; - 468318BA20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641D21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "SwiftQueue::SwiftQueue"; remoteInfo = SwiftQueue; }; - 468318BB20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641E21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Transport::Transport"; remoteInfo = Transport; }; - 468318BC20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D641F21190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::Elligator"; remoteInfo = Elligator; }; - 468318BD20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642021190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::ElligatorObjC"; remoteInfo = ElligatorObjC; }; - 468318BE20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642121190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Elligator::celligator"; remoteInfo = celligator; }; - 468318BF20ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642221190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "HKDF::HKDF"; remoteInfo = HKDF; }; - 468318C020ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642321190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "Cryptor::Cryptor"; remoteInfo = Cryptor; }; - 468318C120ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642421190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; remoteGlobalIDString = "CryptoSwift::CryptoSwift"; remoteInfo = CryptoSwift; }; - 468318C220ACD19000CFBBBD /* PBXContainerItemProxy */ = { + 467D642521190DC500D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; - remoteGlobalIDString = "swift-sodium::Sodium"; + remoteGlobalIDString = "Sodium::Sodium"; remoteInfo = Sodium; }; - 468318C320ACD19200CFBBBD /* PBXContainerItemProxy */ = { - isa = PBXContainerItemProxy; - containerPortal = OBJ_1 /* Project object */; - proxyType = 1; - remoteGlobalIDString = "Shapeshifter-Swift-Transports::MeekTests"; - remoteInfo = MeekTests; - }; - 468318C420ACD19200CFBBBD /* PBXContainerItemProxy */ = { + 467D642621190DC600D65DDE /* PBXContainerItemProxy */ = { isa = PBXContainerItemProxy; containerPortal = OBJ_1 /* Project object */; proxyType = 1; @@ -463,290 +377,268 @@ "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = ElligatorObjC.framework; sourceTree = BUILT_PRODUCTS_DIR; }; "Elligator::celligator::Product" /* celligator.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = celligator.framework; sourceTree = BUILT_PRODUCTS_DIR; }; "HKDF::HKDF::Product" /* HKDF.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = HKDF.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - OBJ_100 /* BlockModeOptions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockModeOptions.swift; sourceTree = ""; }; - OBJ_101 /* BlockModeWorker.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockModeWorker.swift; sourceTree = ""; }; - OBJ_102 /* CBC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CBC.swift; sourceTree = ""; }; - OBJ_103 /* CFB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CFB.swift; sourceTree = ""; }; - OBJ_104 /* CTR.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CTR.swift; sourceTree = ""; }; - OBJ_105 /* ECB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ECB.swift; sourceTree = ""; }; - OBJ_106 /* OFB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OFB.swift; sourceTree = ""; }; - OBJ_107 /* PCBC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PCBC.swift; sourceTree = ""; }; - OBJ_108 /* RandomAccessBlockModeWorker.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomAccessBlockModeWorker.swift; sourceTree = ""; }; - OBJ_109 /* Blowfish.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Blowfish.swift; sourceTree = ""; }; - OBJ_11 /* FakePacketTunnelProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FakePacketTunnelProvider.swift; sourceTree = ""; }; - OBJ_110 /* CMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CMAC.swift; sourceTree = ""; }; - OBJ_111 /* ChaCha20.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChaCha20.swift; sourceTree = ""; }; - OBJ_112 /* Checksum.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Checksum.swift; sourceTree = ""; }; - OBJ_113 /* Cipher.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cipher.swift; sourceTree = ""; }; - OBJ_114 /* Collection+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Collection+Extension.swift"; sourceTree = ""; }; - OBJ_115 /* CompactMap.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CompactMap.swift; sourceTree = ""; }; - OBJ_116 /* Cryptors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cryptors.swift; sourceTree = ""; }; - OBJ_117 /* Digest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Digest.swift; sourceTree = ""; }; - OBJ_118 /* DigestType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DigestType.swift; sourceTree = ""; }; - OBJ_12 /* FakeTCPConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FakeTCPConnection.swift; sourceTree = ""; }; - OBJ_120 /* AES+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "AES+Foundation.swift"; sourceTree = ""; }; - OBJ_121 /* Array+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+Foundation.swift"; sourceTree = ""; }; - OBJ_122 /* Blowfish+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Blowfish+Foundation.swift"; sourceTree = ""; }; - OBJ_123 /* ChaCha20+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "ChaCha20+Foundation.swift"; sourceTree = ""; }; - OBJ_124 /* Data+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Data+Extension.swift"; sourceTree = ""; }; - OBJ_125 /* HMAC+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "HMAC+Foundation.swift"; sourceTree = ""; }; - OBJ_126 /* Rabbit+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Rabbit+Foundation.swift"; sourceTree = ""; }; - OBJ_127 /* String+FoundationExtension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+FoundationExtension.swift"; sourceTree = ""; }; - OBJ_128 /* Utils+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Utils+Foundation.swift"; sourceTree = ""; }; - OBJ_129 /* Generics.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Generics.swift; sourceTree = ""; }; - OBJ_13 /* FakeUDPSession.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FakeUDPSession.swift; sourceTree = ""; }; - OBJ_130 /* HKDF.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HKDF.swift; sourceTree = ""; }; - OBJ_131 /* HMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HMAC.swift; sourceTree = ""; }; - OBJ_132 /* Int+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Int+Extension.swift"; sourceTree = ""; }; - OBJ_133 /* MD5.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MD5.swift; sourceTree = ""; }; - OBJ_134 /* NoPadding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NoPadding.swift; sourceTree = ""; }; - OBJ_135 /* Operators.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Operators.swift; sourceTree = ""; }; - OBJ_137 /* PBKDF1.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PBKDF1.swift; sourceTree = ""; }; - OBJ_138 /* PBKDF2.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PBKDF2.swift; sourceTree = ""; }; - OBJ_139 /* PKCS5.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS5.swift; sourceTree = ""; }; - OBJ_140 /* PKCS7.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS7.swift; sourceTree = ""; }; - OBJ_141 /* PKCS7Padding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS7Padding.swift; sourceTree = ""; }; - OBJ_142 /* Padding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Padding.swift; sourceTree = ""; }; - OBJ_143 /* Poly1305.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Poly1305.swift; sourceTree = ""; }; - OBJ_144 /* Rabbit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Rabbit.swift; sourceTree = ""; }; - OBJ_145 /* RandomAccessCryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomAccessCryptor.swift; sourceTree = ""; }; - OBJ_146 /* RandomBytesSequence.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomBytesSequence.swift; sourceTree = ""; }; - OBJ_147 /* SHA1.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA1.swift; sourceTree = ""; }; - OBJ_148 /* SHA2.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA2.swift; sourceTree = ""; }; - OBJ_149 /* SHA3.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA3.swift; sourceTree = ""; }; - OBJ_15 /* WispCoding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispCoding.swift; sourceTree = ""; }; - OBJ_150 /* SecureBytes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecureBytes.swift; sourceTree = ""; }; - OBJ_151 /* String+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+Extension.swift"; sourceTree = ""; }; - OBJ_152 /* UInt16+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt16+Extension.swift"; sourceTree = ""; }; - OBJ_153 /* UInt32+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt32+Extension.swift"; sourceTree = ""; }; - OBJ_154 /* UInt64+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt64+Extension.swift"; sourceTree = ""; }; - OBJ_155 /* UInt8+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt8+Extension.swift"; sourceTree = ""; }; - OBJ_156 /* Updatable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Updatable.swift; sourceTree = ""; }; - OBJ_157 /* Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utils.swift; sourceTree = ""; }; - OBJ_158 /* ZeroPadding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ZeroPadding.swift; sourceTree = ""; }; - OBJ_159 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/CryptoSwift.git--6440749087414195235/Package.swift"; sourceTree = ""; }; - OBJ_16 /* WispConstants.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispConstants.swift; sourceTree = ""; }; - OBJ_161 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/swift-sodium.git-4026326239528637742/Package.swift"; sourceTree = ""; }; - OBJ_163 /* Auth.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Auth.swift; sourceTree = ""; }; - OBJ_164 /* Box.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Box.swift; sourceTree = ""; }; - OBJ_165 /* GenericHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GenericHash.swift; sourceTree = ""; }; - OBJ_166 /* KeyDerivation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyDerivation.swift; sourceTree = ""; }; - OBJ_167 /* KeyExchange.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyExchange.swift; sourceTree = ""; }; - OBJ_168 /* PWHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PWHash.swift; sourceTree = ""; }; - OBJ_169 /* RandomBytes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomBytes.swift; sourceTree = ""; }; - OBJ_17 /* WispErrors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispErrors.swift; sourceTree = ""; }; - OBJ_170 /* SecretBox.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecretBox.swift; sourceTree = ""; }; - OBJ_171 /* SecretStream.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecretStream.swift; sourceTree = ""; }; - OBJ_172 /* ShortHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ShortHash.swift; sourceTree = ""; }; - OBJ_173 /* Sign.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sign.swift; sourceTree = ""; }; - OBJ_174 /* Sodium.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sodium.swift; sourceTree = ""; }; - OBJ_175 /* Stream.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Stream.swift; sourceTree = ""; }; - OBJ_176 /* Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utils.swift; sourceTree = ""; }; - OBJ_179 /* PacketTunnelProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PacketTunnelProvider.swift; sourceTree = ""; }; - OBJ_18 /* WispProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispProtocol.swift; sourceTree = ""; }; - OBJ_180 /* TCPConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TCPConnection.swift; sourceTree = ""; }; - OBJ_181 /* UDPSession.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UDPSession.swift; sourceTree = ""; }; - OBJ_182 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/Transport.git-7971019246718298831/Package.swift"; sourceTree = ""; }; - OBJ_19 /* WispTCPConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispTCPConnection.swift; sourceTree = ""; }; - OBJ_22 /* WispTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispTests.swift; sourceTree = ""; }; - OBJ_24 /* MeekTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MeekTests.swift; sourceTree = ""; }; - OBJ_25 /* Examples */ = {isa = PBXFileReference; lastKnownFileType = folder; path = Examples; sourceTree = SOURCE_ROOT; }; - OBJ_29 /* LinkedList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LinkedList.swift; sourceTree = ""; }; - OBJ_30 /* Queue.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Queue.swift; sourceTree = ""; }; - OBJ_31 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/SwiftQueue.git--1803263377898760171/Package.swift"; sourceTree = ""; }; - OBJ_34 /* crypto_verify_32.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = crypto_verify_32.cc; sourceTree = ""; }; - OBJ_35 /* elligator.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = elligator.cpp; sourceTree = ""; }; - OBJ_36 /* fe_add.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_add.cc; sourceTree = ""; }; - OBJ_37 /* fe_cmov.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_cmov.cc; sourceTree = ""; }; - OBJ_38 /* fe_copy.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_copy.cc; sourceTree = ""; }; - OBJ_39 /* fe_frombytes.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_frombytes.cc; sourceTree = ""; }; - OBJ_40 /* fe_invert.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_invert.cc; sourceTree = ""; }; - OBJ_41 /* fe_isnonzero.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_isnonzero.cc; sourceTree = ""; }; - OBJ_42 /* fe_mul.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_mul.cc; sourceTree = ""; }; - OBJ_43 /* fe_neg.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_neg.cc; sourceTree = ""; }; - OBJ_44 /* fe_sq.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sq.cc; sourceTree = ""; }; - OBJ_45 /* fe_sq2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sq2.cc; sourceTree = ""; }; - OBJ_46 /* fe_sub.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sub.cc; sourceTree = ""; }; - OBJ_47 /* fe_tobytes.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_tobytes.cc; sourceTree = ""; }; - OBJ_48 /* ge_madd.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_madd.cc; sourceTree = ""; }; - OBJ_49 /* ge_p1p1_to_p2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p1p1_to_p2.cc; sourceTree = ""; }; - OBJ_50 /* ge_p1p1_to_p3.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p1p1_to_p3.cc; sourceTree = ""; }; - OBJ_51 /* ge_p2_dbl.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p2_dbl.cc; sourceTree = ""; }; - OBJ_52 /* ge_p3_0.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_0.cc; sourceTree = ""; }; - OBJ_53 /* ge_p3_dbl.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_dbl.cc; sourceTree = ""; }; - OBJ_54 /* ge_p3_to_p2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_to_p2.cc; sourceTree = ""; }; - OBJ_55 /* ge_precomp_0.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_precomp_0.cc; sourceTree = ""; }; - OBJ_56 /* ge_scalarmult_base.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_scalarmult_base.cc; sourceTree = ""; }; - OBJ_58 /* fe.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = fe.h; sourceTree = ""; }; - OBJ_59 /* ge.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ge.h; sourceTree = ""; }; + OBJ_10 /* WispConstants.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispConstants.swift; sourceTree = ""; }; + OBJ_100 /* GCM.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GCM.swift; sourceTree = ""; }; + OBJ_101 /* OFB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OFB.swift; sourceTree = ""; }; + OBJ_102 /* PCBC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PCBC.swift; sourceTree = ""; }; + OBJ_103 /* Blowfish.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Blowfish.swift; sourceTree = ""; }; + OBJ_104 /* CMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CMAC.swift; sourceTree = ""; }; + OBJ_105 /* ChaCha20.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChaCha20.swift; sourceTree = ""; }; + OBJ_106 /* Checksum.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Checksum.swift; sourceTree = ""; }; + OBJ_107 /* Cipher.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cipher.swift; sourceTree = ""; }; + OBJ_108 /* Collection+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Collection+Extension.swift"; sourceTree = ""; }; + OBJ_109 /* CompactMap.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CompactMap.swift; sourceTree = ""; }; + OBJ_11 /* WispErrors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispErrors.swift; sourceTree = ""; }; + OBJ_110 /* Cryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cryptor.swift; sourceTree = ""; }; + OBJ_111 /* Cryptors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cryptors.swift; sourceTree = ""; }; + OBJ_112 /* Digest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Digest.swift; sourceTree = ""; }; + OBJ_113 /* DigestType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DigestType.swift; sourceTree = ""; }; + OBJ_115 /* AES+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "AES+Foundation.swift"; sourceTree = ""; }; + OBJ_116 /* Array+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+Foundation.swift"; sourceTree = ""; }; + OBJ_117 /* Blowfish+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Blowfish+Foundation.swift"; sourceTree = ""; }; + OBJ_118 /* ChaCha20+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "ChaCha20+Foundation.swift"; sourceTree = ""; }; + OBJ_119 /* Data+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Data+Extension.swift"; sourceTree = ""; }; + OBJ_12 /* WispProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispProtocol.swift; sourceTree = ""; }; + OBJ_120 /* HMAC+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "HMAC+Foundation.swift"; sourceTree = ""; }; + OBJ_121 /* Rabbit+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Rabbit+Foundation.swift"; sourceTree = ""; }; + OBJ_122 /* String+FoundationExtension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+FoundationExtension.swift"; sourceTree = ""; }; + OBJ_123 /* Utils+Foundation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Utils+Foundation.swift"; sourceTree = ""; }; + OBJ_124 /* Generics.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Generics.swift; sourceTree = ""; }; + OBJ_125 /* HKDF.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HKDF.swift; sourceTree = ""; }; + OBJ_126 /* HMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HMAC.swift; sourceTree = ""; }; + OBJ_127 /* Int+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Int+Extension.swift"; sourceTree = ""; }; + OBJ_128 /* MD5.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MD5.swift; sourceTree = ""; }; + OBJ_129 /* NoPadding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NoPadding.swift; sourceTree = ""; }; + OBJ_13 /* WispTCPConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispTCPConnection.swift; sourceTree = ""; }; + OBJ_130 /* Operators.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Operators.swift; sourceTree = ""; }; + OBJ_132 /* PBKDF1.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PBKDF1.swift; sourceTree = ""; }; + OBJ_133 /* PBKDF2.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PBKDF2.swift; sourceTree = ""; }; + OBJ_134 /* PKCS5.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS5.swift; sourceTree = ""; }; + OBJ_135 /* PKCS7.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS7.swift; sourceTree = ""; }; + OBJ_136 /* PKCS7Padding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PKCS7Padding.swift; sourceTree = ""; }; + OBJ_137 /* Padding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Padding.swift; sourceTree = ""; }; + OBJ_138 /* Poly1305.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Poly1305.swift; sourceTree = ""; }; + OBJ_139 /* Rabbit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Rabbit.swift; sourceTree = ""; }; + OBJ_140 /* RandomBytesSequence.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomBytesSequence.swift; sourceTree = ""; }; + OBJ_141 /* SHA1.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA1.swift; sourceTree = ""; }; + OBJ_142 /* SHA2.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA2.swift; sourceTree = ""; }; + OBJ_143 /* SHA3.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SHA3.swift; sourceTree = ""; }; + OBJ_144 /* SecureBytes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecureBytes.swift; sourceTree = ""; }; + OBJ_145 /* StreamEncryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StreamEncryptor.swift; sourceTree = ""; }; + OBJ_146 /* String+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "String+Extension.swift"; sourceTree = ""; }; + OBJ_147 /* UInt128.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UInt128.swift; sourceTree = ""; }; + OBJ_148 /* UInt16+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt16+Extension.swift"; sourceTree = ""; }; + OBJ_149 /* UInt32+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt32+Extension.swift"; sourceTree = ""; }; + OBJ_150 /* UInt64+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt64+Extension.swift"; sourceTree = ""; }; + OBJ_151 /* UInt8+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UInt8+Extension.swift"; sourceTree = ""; }; + OBJ_152 /* Updatable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Updatable.swift; sourceTree = ""; }; + OBJ_153 /* Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utils.swift; sourceTree = ""; }; + OBJ_154 /* ZeroPadding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ZeroPadding.swift; sourceTree = ""; }; + OBJ_155 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/CryptoSwift.git--6440749087414195235/Package.swift"; sourceTree = ""; }; + OBJ_158 /* Aead.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Aead.swift; sourceTree = ""; }; + OBJ_159 /* Auth.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Auth.swift; sourceTree = ""; }; + OBJ_16 /* WispTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispTests.swift; sourceTree = ""; }; + OBJ_160 /* Box.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Box.swift; sourceTree = ""; }; + OBJ_161 /* Bytes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Bytes.swift; sourceTree = ""; }; + OBJ_162 /* ExitCode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ExitCode.swift; sourceTree = ""; }; + OBJ_164 /* KeyPairGenerator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyPairGenerator.swift; sourceTree = ""; }; + OBJ_165 /* KeyPairProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyPairProtocol.swift; sourceTree = ""; }; + OBJ_166 /* NonceGenerator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NonceGenerator.swift; sourceTree = ""; }; + OBJ_167 /* SecretKeyGenerator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecretKeyGenerator.swift; sourceTree = ""; }; + OBJ_168 /* GenericHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GenericHash.swift; sourceTree = ""; }; + OBJ_169 /* KeyDerivation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyDerivation.swift; sourceTree = ""; }; + OBJ_17 /* Examples */ = {isa = PBXFileReference; lastKnownFileType = folder; path = Examples; sourceTree = SOURCE_ROOT; }; + OBJ_170 /* KeyExchange.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyExchange.swift; sourceTree = ""; }; + OBJ_171 /* PWHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PWHash.swift; sourceTree = ""; }; + OBJ_172 /* RandomBytes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RandomBytes.swift; sourceTree = ""; }; + OBJ_173 /* SecretBox.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecretBox.swift; sourceTree = ""; }; + OBJ_174 /* SecretStream.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SecretStream.swift; sourceTree = ""; }; + OBJ_175 /* ShortHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ShortHash.swift; sourceTree = ""; }; + OBJ_176 /* Sign.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sign.swift; sourceTree = ""; }; + OBJ_177 /* Sodium.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Sodium.swift; sourceTree = ""; }; + OBJ_178 /* StateStream.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StateStream.swift; sourceTree = ""; }; + OBJ_179 /* Stream.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Stream.swift; sourceTree = ""; }; + OBJ_180 /* Utils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utils.swift; sourceTree = ""; }; + OBJ_181 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/swift-sodium-5502668898337213252/Package.swift"; sourceTree = ""; }; + OBJ_184 /* Connection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Connection.swift; sourceTree = ""; }; + OBJ_185 /* ConnectionFactory.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ConnectionFactory.swift; sourceTree = ""; }; + OBJ_186 /* IPv4Address.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = IPv4Address.swift; sourceTree = ""; }; + OBJ_187 /* NWConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NWConnection.swift; sourceTree = ""; }; + OBJ_188 /* NWEndpoint.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NWEndpoint.swift; sourceTree = ""; }; + OBJ_189 /* NWError.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NWError.swift; sourceTree = ""; }; + OBJ_190 /* NWParameters.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NWParameters.swift; sourceTree = ""; }; + OBJ_191 /* NetworkConnectionFactory.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NetworkConnectionFactory.swift; sourceTree = ""; }; + OBJ_192 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/Transport.git-7971019246718298831/Package.swift"; sourceTree = ""; }; + OBJ_21 /* LinkedList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LinkedList.swift; sourceTree = ""; }; + OBJ_22 /* Queue.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Queue.swift; sourceTree = ""; }; + OBJ_23 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/SwiftQueue.git--1803263377898760171/Package.swift"; sourceTree = ""; }; + OBJ_26 /* crypto_verify_32.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = crypto_verify_32.cc; sourceTree = ""; }; + OBJ_27 /* elligator.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = elligator.cpp; sourceTree = ""; }; + OBJ_28 /* fe_add.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_add.cc; sourceTree = ""; }; + OBJ_29 /* fe_cmov.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_cmov.cc; sourceTree = ""; }; + OBJ_30 /* fe_copy.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_copy.cc; sourceTree = ""; }; + OBJ_31 /* fe_frombytes.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_frombytes.cc; sourceTree = ""; }; + OBJ_32 /* fe_invert.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_invert.cc; sourceTree = ""; }; + OBJ_33 /* fe_isnonzero.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_isnonzero.cc; sourceTree = ""; }; + OBJ_34 /* fe_mul.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_mul.cc; sourceTree = ""; }; + OBJ_35 /* fe_neg.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_neg.cc; sourceTree = ""; }; + OBJ_36 /* fe_sq.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sq.cc; sourceTree = ""; }; + OBJ_37 /* fe_sq2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sq2.cc; sourceTree = ""; }; + OBJ_38 /* fe_sub.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_sub.cc; sourceTree = ""; }; + OBJ_39 /* fe_tobytes.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = fe_tobytes.cc; sourceTree = ""; }; + OBJ_40 /* ge_madd.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_madd.cc; sourceTree = ""; }; + OBJ_41 /* ge_p1p1_to_p2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p1p1_to_p2.cc; sourceTree = ""; }; + OBJ_42 /* ge_p1p1_to_p3.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p1p1_to_p3.cc; sourceTree = ""; }; + OBJ_43 /* ge_p2_dbl.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p2_dbl.cc; sourceTree = ""; }; + OBJ_44 /* ge_p3_0.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_0.cc; sourceTree = ""; }; + OBJ_45 /* ge_p3_dbl.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_dbl.cc; sourceTree = ""; }; + OBJ_46 /* ge_p3_to_p2.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_p3_to_p2.cc; sourceTree = ""; }; + OBJ_47 /* ge_precomp_0.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_precomp_0.cc; sourceTree = ""; }; + OBJ_48 /* ge_scalarmult_base.cc */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = ge_scalarmult_base.cc; sourceTree = ""; }; + OBJ_50 /* fe.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = fe.h; sourceTree = ""; }; + OBJ_51 /* ge.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ge.h; sourceTree = ""; }; + OBJ_52 /* base.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = base.h; sourceTree = ""; }; + OBJ_53 /* module.modulemap */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.module-map"; name = module.modulemap; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; sourceTree = ""; }; + OBJ_55 /* ElligatorObjC.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = ElligatorObjC.mm; sourceTree = ""; }; + OBJ_57 /* ElligatorObjC.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ElligatorObjC.h; sourceTree = ""; }; + OBJ_58 /* module.modulemap */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.module-map"; name = module.modulemap; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap"; sourceTree = ""; }; OBJ_6 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; path = Package.swift; sourceTree = ""; }; - OBJ_60 /* base.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = base.h; sourceTree = ""; }; - OBJ_61 /* module.modulemap */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.module-map"; name = module.modulemap; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; sourceTree = ""; }; - OBJ_63 /* ElligatorObjC.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = ElligatorObjC.mm; sourceTree = ""; }; - OBJ_65 /* ElligatorObjC.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ElligatorObjC.h; sourceTree = ""; }; - OBJ_66 /* module.modulemap */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.module-map"; name = module.modulemap; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap"; sourceTree = ""; }; - OBJ_68 /* Elligator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Elligator.swift; sourceTree = ""; }; - OBJ_69 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/Elligator.git-1685432175989269477/Package.swift"; sourceTree = ""; }; - OBJ_71 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/HKDF.git-3816566315579078428/Package.swift"; sourceTree = ""; }; - OBJ_72 /* HKDF.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HKDF.swift; sourceTree = ""; }; - OBJ_75 /* Crypto.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Crypto.swift; sourceTree = ""; }; - OBJ_76 /* Cryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cryptor.swift; sourceTree = ""; }; - OBJ_77 /* Digest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Digest.swift; sourceTree = ""; }; - OBJ_78 /* HMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HMAC.swift; sourceTree = ""; }; - OBJ_79 /* KeyDerivation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyDerivation.swift; sourceTree = ""; }; - OBJ_80 /* Random.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Random.swift; sourceTree = ""; }; - OBJ_81 /* Status.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Status.swift; sourceTree = ""; }; - OBJ_82 /* StreamCryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StreamCryptor.swift; sourceTree = ""; }; - OBJ_83 /* Updatable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Updatable.swift; sourceTree = ""; }; - OBJ_84 /* Utilities.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utilities.swift; sourceTree = ""; }; - OBJ_85 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/BlueCryptor.git-2709167748876642405/Package.swift"; sourceTree = ""; }; - OBJ_89 /* AEAD.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AEAD.swift; sourceTree = ""; }; - OBJ_9 /* MeekTCPConnection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MeekTCPConnection.swift; sourceTree = ""; }; - OBJ_90 /* AEADChaCha20Poly1305.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AEADChaCha20Poly1305.swift; sourceTree = ""; }; - OBJ_91 /* AES.Cryptors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AES.Cryptors.swift; sourceTree = ""; }; - OBJ_92 /* AES.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AES.swift; sourceTree = ""; }; - OBJ_93 /* Array+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+Extension.swift"; sourceTree = ""; }; - OBJ_94 /* Authenticator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Authenticator.swift; sourceTree = ""; }; - OBJ_95 /* BatchedCollection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BatchedCollection.swift; sourceTree = ""; }; - OBJ_96 /* Bit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Bit.swift; sourceTree = ""; }; - OBJ_97 /* BlockCipher.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockCipher.swift; sourceTree = ""; }; - OBJ_99 /* BlockMode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockMode.swift; sourceTree = ""; }; - "Shapeshifter-Swift-Transports::Meek::Product" /* Meek.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Meek.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - "Shapeshifter-Swift-Transports::MeekTests::Product" /* MeekTests.xctest */ = {isa = PBXFileReference; lastKnownFileType = file; path = MeekTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; - "Shapeshifter-Swift-Transports::ShapeshifterTesting::Product" /* ShapeshifterTesting.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = ShapeshifterTesting.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + OBJ_60 /* Elligator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Elligator.swift; sourceTree = ""; }; + OBJ_61 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/Elligator.git-1685432175989269477/Package.swift"; sourceTree = ""; }; + OBJ_63 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/HKDF.git-3816566315579078428/Package.swift"; sourceTree = ""; }; + OBJ_64 /* HKDF.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HKDF.swift; sourceTree = ""; }; + OBJ_67 /* Crypto.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Crypto.swift; sourceTree = ""; }; + OBJ_68 /* Cryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Cryptor.swift; sourceTree = ""; }; + OBJ_69 /* Digest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Digest.swift; sourceTree = ""; }; + OBJ_70 /* HMAC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HMAC.swift; sourceTree = ""; }; + OBJ_71 /* KeyDerivation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = KeyDerivation.swift; sourceTree = ""; }; + OBJ_72 /* Random.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Random.swift; sourceTree = ""; }; + OBJ_73 /* Status.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Status.swift; sourceTree = ""; }; + OBJ_74 /* StreamCryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StreamCryptor.swift; sourceTree = ""; }; + OBJ_75 /* Updatable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Updatable.swift; sourceTree = ""; }; + OBJ_76 /* Utilities.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Utilities.swift; sourceTree = ""; }; + OBJ_77 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; name = Package.swift; path = "/Users/Lita/Documents/Dev/Shapeshifter-Swift-Transports/.build/checkouts/BlueCryptor.git-2709167748876642405/Package.swift"; sourceTree = ""; }; + OBJ_81 /* AEAD.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AEAD.swift; sourceTree = ""; }; + OBJ_82 /* AEADChaCha20Poly1305.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AEADChaCha20Poly1305.swift; sourceTree = ""; }; + OBJ_83 /* AES.Cryptors.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AES.Cryptors.swift; sourceTree = ""; }; + OBJ_84 /* AES.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AES.swift; sourceTree = ""; }; + OBJ_85 /* Array+Extension.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+Extension.swift"; sourceTree = ""; }; + OBJ_86 /* Authenticator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Authenticator.swift; sourceTree = ""; }; + OBJ_87 /* BatchedCollection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BatchedCollection.swift; sourceTree = ""; }; + OBJ_88 /* Bit.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Bit.swift; sourceTree = ""; }; + OBJ_89 /* BlockCipher.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockCipher.swift; sourceTree = ""; }; + OBJ_9 /* WispCoding.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = WispCoding.swift; sourceTree = ""; }; + OBJ_90 /* BlockDecryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockDecryptor.swift; sourceTree = ""; }; + OBJ_91 /* BlockEncryptor.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockEncryptor.swift; sourceTree = ""; }; + OBJ_93 /* BlockMode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockMode.swift; sourceTree = ""; }; + OBJ_94 /* BlockModeOptions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockModeOptions.swift; sourceTree = ""; }; + OBJ_95 /* CBC.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CBC.swift; sourceTree = ""; }; + OBJ_96 /* CFB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CFB.swift; sourceTree = ""; }; + OBJ_97 /* CTR.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CTR.swift; sourceTree = ""; }; + OBJ_98 /* CipherModeWorker.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CipherModeWorker.swift; sourceTree = ""; }; + OBJ_99 /* ECB.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ECB.swift; sourceTree = ""; }; "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Wisp.framework; sourceTree = BUILT_PRODUCTS_DIR; }; "Shapeshifter-Swift-Transports::WispTests::Product" /* WispTests.xctest */ = {isa = PBXFileReference; lastKnownFileType = file; path = WispTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; + "Sodium::Sodium::Product" /* Sodium.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Sodium.framework; sourceTree = BUILT_PRODUCTS_DIR; }; "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = SwiftQueue.framework; sourceTree = BUILT_PRODUCTS_DIR; }; "Transport::Transport::Product" /* Transport.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Transport.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - "swift-sodium::Sodium::Product" /* Sodium.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; path = Sodium.framework; sourceTree = BUILT_PRODUCTS_DIR; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ - OBJ_274 /* Frameworks */ = { + OBJ_285 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_296 /* Frameworks */ = { + OBJ_307 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_309 /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 0; - files = ( - OBJ_310 /* ElligatorObjC.framework in Frameworks */, - OBJ_311 /* celligator.framework in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_321 /* Frameworks */ = { + OBJ_320 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( + OBJ_321 /* ElligatorObjC.framework in Frameworks */, OBJ_322 /* celligator.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_336 /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 0; - files = ( - OBJ_337 /* Cryptor.framework in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_351 /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 0; - files = ( - OBJ_352 /* SwiftQueue.framework in Frameworks */, - OBJ_353 /* Transport.framework in Frameworks */, - OBJ_354 /* CryptoSwift.framework in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_366 /* Frameworks */ = { + OBJ_332 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( - OBJ_367 /* ShapeshifterTesting.framework in Frameworks */, - OBJ_368 /* Meek.framework in Frameworks */, - OBJ_369 /* SwiftQueue.framework in Frameworks */, - OBJ_370 /* Transport.framework in Frameworks */, - OBJ_371 /* CryptoSwift.framework in Frameworks */, + OBJ_333 /* celligator.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_398 /* Frameworks */ = { + OBJ_347 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( - OBJ_399 /* Transport.framework in Frameworks */, + OBJ_348 /* Cryptor.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_420 /* Frameworks */ = { + OBJ_395 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_427 /* Frameworks */ = { + OBJ_409 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_441 /* Frameworks */ = { + OBJ_429 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_458 /* Frameworks */ = { + OBJ_446 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( - OBJ_459 /* SwiftQueue.framework in Frameworks */, - OBJ_460 /* Transport.framework in Frameworks */, - OBJ_461 /* Elligator.framework in Frameworks */, - OBJ_462 /* ElligatorObjC.framework in Frameworks */, - OBJ_463 /* celligator.framework in Frameworks */, - OBJ_464 /* HKDF.framework in Frameworks */, - OBJ_465 /* Cryptor.framework in Frameworks */, - OBJ_466 /* CryptoSwift.framework in Frameworks */, - OBJ_467 /* Sodium.framework in Frameworks */, + OBJ_447 /* SwiftQueue.framework in Frameworks */, + OBJ_448 /* Transport.framework in Frameworks */, + OBJ_449 /* Elligator.framework in Frameworks */, + OBJ_450 /* ElligatorObjC.framework in Frameworks */, + OBJ_451 /* celligator.framework in Frameworks */, + OBJ_452 /* HKDF.framework in Frameworks */, + OBJ_453 /* Cryptor.framework in Frameworks */, + OBJ_454 /* CryptoSwift.framework in Frameworks */, + OBJ_455 /* Sodium.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_482 /* Frameworks */ = { + OBJ_470 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( - OBJ_483 /* ShapeshifterTesting.framework in Frameworks */, - OBJ_484 /* Wisp.framework in Frameworks */, - OBJ_485 /* SwiftQueue.framework in Frameworks */, - OBJ_486 /* Transport.framework in Frameworks */, - OBJ_487 /* Elligator.framework in Frameworks */, - OBJ_488 /* ElligatorObjC.framework in Frameworks */, - OBJ_489 /* celligator.framework in Frameworks */, - OBJ_490 /* HKDF.framework in Frameworks */, - OBJ_491 /* Cryptor.framework in Frameworks */, - OBJ_492 /* CryptoSwift.framework in Frameworks */, - OBJ_493 /* Sodium.framework in Frameworks */, + OBJ_471 /* Wisp.framework in Frameworks */, + OBJ_472 /* SwiftQueue.framework in Frameworks */, + OBJ_473 /* Transport.framework in Frameworks */, + OBJ_474 /* Elligator.framework in Frameworks */, + OBJ_475 /* ElligatorObjC.framework in Frameworks */, + OBJ_476 /* celligator.framework in Frameworks */, + OBJ_477 /* HKDF.framework in Frameworks */, + OBJ_478 /* Cryptor.framework in Frameworks */, + OBJ_479 /* CryptoSwift.framework in Frameworks */, + OBJ_480 /* Sodium.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_532 /* Frameworks */ = { + OBJ_518 /* Frameworks */ = { isa = PBXFrameworksBuildPhase; buildActionMask = 0; files = ( @@ -756,425 +648,414 @@ /* End PBXFrameworksBuildPhase section */ /* Begin PBXGroup section */ - OBJ_10 /* ShapeshifterTesting */ = { + OBJ_114 /* Foundation */ = { isa = PBXGroup; children = ( - OBJ_11 /* FakePacketTunnelProvider.swift */, - OBJ_12 /* FakeTCPConnection.swift */, - OBJ_13 /* FakeUDPSession.swift */, - ); - name = ShapeshifterTesting; - path = Sources/ShapeshifterTesting; - sourceTree = SOURCE_ROOT; - }; - OBJ_119 /* Foundation */ = { - isa = PBXGroup; - children = ( - OBJ_120 /* AES+Foundation.swift */, - OBJ_121 /* Array+Foundation.swift */, - OBJ_122 /* Blowfish+Foundation.swift */, - OBJ_123 /* ChaCha20+Foundation.swift */, - OBJ_124 /* Data+Extension.swift */, - OBJ_125 /* HMAC+Foundation.swift */, - OBJ_126 /* Rabbit+Foundation.swift */, - OBJ_127 /* String+FoundationExtension.swift */, - OBJ_128 /* Utils+Foundation.swift */, + OBJ_115 /* AES+Foundation.swift */, + OBJ_116 /* Array+Foundation.swift */, + OBJ_117 /* Blowfish+Foundation.swift */, + OBJ_118 /* ChaCha20+Foundation.swift */, + OBJ_119 /* Data+Extension.swift */, + OBJ_120 /* HMAC+Foundation.swift */, + OBJ_121 /* Rabbit+Foundation.swift */, + OBJ_122 /* String+FoundationExtension.swift */, + OBJ_123 /* Utils+Foundation.swift */, ); path = Foundation; sourceTree = ""; }; - OBJ_136 /* PKCS */ = { + OBJ_131 /* PKCS */ = { isa = PBXGroup; children = ( - OBJ_137 /* PBKDF1.swift */, - OBJ_138 /* PBKDF2.swift */, - OBJ_139 /* PKCS5.swift */, - OBJ_140 /* PKCS7.swift */, - OBJ_141 /* PKCS7Padding.swift */, + OBJ_132 /* PBKDF1.swift */, + OBJ_133 /* PBKDF2.swift */, + OBJ_134 /* PKCS5.swift */, + OBJ_135 /* PKCS7.swift */, + OBJ_136 /* PKCS7Padding.swift */, ); path = PKCS; sourceTree = ""; }; - OBJ_14 /* Wisp */ = { + OBJ_14 /* Tests */ = { isa = PBXGroup; children = ( - OBJ_15 /* WispCoding.swift */, - OBJ_16 /* WispConstants.swift */, - OBJ_17 /* WispErrors.swift */, - OBJ_18 /* WispProtocol.swift */, - OBJ_19 /* WispTCPConnection.swift */, + OBJ_15 /* WispTests */, ); - name = Wisp; - path = Sources/Wisp; + name = Tests; sourceTree = SOURCE_ROOT; }; - OBJ_160 /* swift-sodium 0.5.3 */ = { + OBJ_15 /* WispTests */ = { isa = PBXGroup; children = ( - OBJ_161 /* Package.swift */, - OBJ_162 /* Sodium */, + OBJ_16 /* WispTests.swift */, ); - name = "swift-sodium 0.5.3"; - path = ".build/checkouts/swift-sodium.git-4026326239528637742"; + name = WispTests; + path = Tests/WispTests; sourceTree = SOURCE_ROOT; }; - OBJ_162 /* Sodium */ = { - isa = PBXGroup; - children = ( - OBJ_163 /* Auth.swift */, - OBJ_164 /* Box.swift */, - OBJ_165 /* GenericHash.swift */, - OBJ_166 /* KeyDerivation.swift */, - OBJ_167 /* KeyExchange.swift */, - OBJ_168 /* PWHash.swift */, - OBJ_169 /* RandomBytes.swift */, - OBJ_170 /* SecretBox.swift */, - OBJ_171 /* SecretStream.swift */, - OBJ_172 /* ShortHash.swift */, - OBJ_173 /* Sign.swift */, - OBJ_174 /* Sodium.swift */, - OBJ_175 /* Stream.swift */, - OBJ_176 /* Utils.swift */, - ); - path = Sodium; - sourceTree = ""; - }; - OBJ_177 /* Transport 0.0.4 */ = { + OBJ_156 /* Sodium 0.6.2 */ = { isa = PBXGroup; children = ( - OBJ_178 /* Transport */, - OBJ_182 /* Package.swift */, + OBJ_157 /* Sodium */, + OBJ_181 /* Package.swift */, ); - name = "Transport 0.0.4"; + name = "Sodium 0.6.2"; sourceTree = SOURCE_ROOT; }; - OBJ_178 /* Transport */ = { + OBJ_157 /* Sodium */ = { isa = PBXGroup; children = ( - OBJ_179 /* PacketTunnelProvider.swift */, - OBJ_180 /* TCPConnection.swift */, - OBJ_181 /* UDPSession.swift */, + OBJ_158 /* Aead.swift */, + OBJ_159 /* Auth.swift */, + OBJ_160 /* Box.swift */, + OBJ_161 /* Bytes.swift */, + OBJ_162 /* ExitCode.swift */, + OBJ_163 /* Generators */, + OBJ_168 /* GenericHash.swift */, + OBJ_169 /* KeyDerivation.swift */, + OBJ_170 /* KeyExchange.swift */, + OBJ_171 /* PWHash.swift */, + OBJ_172 /* RandomBytes.swift */, + OBJ_173 /* SecretBox.swift */, + OBJ_174 /* SecretStream.swift */, + OBJ_175 /* ShortHash.swift */, + OBJ_176 /* Sign.swift */, + OBJ_177 /* Sodium.swift */, + OBJ_178 /* StateStream.swift */, + OBJ_179 /* Stream.swift */, + OBJ_180 /* Utils.swift */, ); - name = Transport; - path = ".build/checkouts/Transport.git-7971019246718298831/Sources/Transport"; + name = Sodium; + path = ".build/checkouts/swift-sodium-5502668898337213252/Sodium"; sourceTree = SOURCE_ROOT; }; - OBJ_183 /* Products */ = { + OBJ_163 /* Generators */ = { isa = PBXGroup; children = ( - "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */, - "Shapeshifter-Swift-Transports::MeekTests::Product" /* MeekTests.xctest */, - "Cryptor::Cryptor::Product" /* Cryptor.framework */, - "Shapeshifter-Swift-Transports::ShapeshifterTesting::Product" /* ShapeshifterTesting.framework */, - "Shapeshifter-Swift-Transports::WispTests::Product" /* WispTests.xctest */, - "Shapeshifter-Swift-Transports::Meek::Product" /* Meek.framework */, - "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */, - "Elligator::celligator::Product" /* celligator.framework */, - "Transport::Transport::Product" /* Transport.framework */, - "Elligator::Elligator::Product" /* Elligator.framework */, - "HKDF::HKDF::Product" /* HKDF.framework */, - "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */, - "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */, - "swift-sodium::Sodium::Product" /* Sodium.framework */, + OBJ_164 /* KeyPairGenerator.swift */, + OBJ_165 /* KeyPairProtocol.swift */, + OBJ_166 /* NonceGenerator.swift */, + OBJ_167 /* SecretKeyGenerator.swift */, ); - name = Products; - sourceTree = BUILT_PRODUCTS_DIR; + path = Generators; + sourceTree = ""; }; - OBJ_20 /* Tests */ = { + OBJ_18 /* Dependencies */ = { isa = PBXGroup; children = ( - OBJ_21 /* WispTests */, - OBJ_23 /* MeekTests */, + OBJ_19 /* SwiftQueue 0.0.3 */, + OBJ_24 /* Elligator 0.1.0 */, + OBJ_62 /* HKDF 3.0.1 */, + OBJ_65 /* Cryptor 0.8.27 */, + OBJ_78 /* CryptoSwift 0.11.0 */, + OBJ_156 /* Sodium 0.6.2 */, + OBJ_182 /* Transport 0.0.12 */, ); - name = Tests; - sourceTree = SOURCE_ROOT; + name = Dependencies; + sourceTree = ""; }; - OBJ_21 /* WispTests */ = { + OBJ_182 /* Transport 0.0.12 */ = { isa = PBXGroup; children = ( - OBJ_22 /* WispTests.swift */, + OBJ_183 /* Transport */, + OBJ_192 /* Package.swift */, ); - name = WispTests; - path = Tests/WispTests; + name = "Transport 0.0.12"; sourceTree = SOURCE_ROOT; }; - OBJ_23 /* MeekTests */ = { + OBJ_183 /* Transport */ = { isa = PBXGroup; children = ( - OBJ_24 /* MeekTests.swift */, + OBJ_184 /* Connection.swift */, + OBJ_185 /* ConnectionFactory.swift */, + OBJ_186 /* IPv4Address.swift */, + OBJ_187 /* NWConnection.swift */, + OBJ_188 /* NWEndpoint.swift */, + OBJ_189 /* NWError.swift */, + OBJ_190 /* NWParameters.swift */, + OBJ_191 /* NetworkConnectionFactory.swift */, ); - name = MeekTests; - path = Tests/MeekTests; + name = Transport; + path = ".build/checkouts/Transport.git-7971019246718298831/Sources/Transport"; sourceTree = SOURCE_ROOT; }; - OBJ_26 /* Dependencies */ = { + OBJ_19 /* SwiftQueue 0.0.3 */ = { isa = PBXGroup; children = ( - OBJ_27 /* SwiftQueue 0.0.1 */, - OBJ_32 /* Elligator 0.1.0 */, - OBJ_70 /* HKDF 3.0.1 */, - OBJ_73 /* Cryptor 0.8.27 */, - OBJ_86 /* CryptoSwift 0.9.0 */, - OBJ_160 /* swift-sodium 0.5.3 */, - OBJ_177 /* Transport 0.0.4 */, + OBJ_20 /* SwiftQueue */, + OBJ_23 /* Package.swift */, ); - name = Dependencies; - sourceTree = ""; + name = "SwiftQueue 0.0.3"; + sourceTree = SOURCE_ROOT; }; - OBJ_27 /* SwiftQueue 0.0.1 */ = { + OBJ_193 /* Products */ = { isa = PBXGroup; children = ( - OBJ_28 /* SwiftQueue */, - OBJ_31 /* Package.swift */, + "Transport::Transport::Product" /* Transport.framework */, + "HKDF::HKDF::Product" /* HKDF.framework */, + "Elligator::Elligator::Product" /* Elligator.framework */, + "CryptoSwift::CryptoSwift::Product" /* CryptoSwift.framework */, + "Sodium::Sodium::Product" /* Sodium.framework */, + "SwiftQueue::SwiftQueue::Product" /* SwiftQueue.framework */, + "Cryptor::Cryptor::Product" /* Cryptor.framework */, + "Elligator::celligator::Product" /* celligator.framework */, + "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */, + "Elligator::ElligatorObjC::Product" /* ElligatorObjC.framework */, + "Shapeshifter-Swift-Transports::WispTests::Product" /* WispTests.xctest */, ); - name = "SwiftQueue 0.0.1"; - sourceTree = SOURCE_ROOT; + name = Products; + sourceTree = BUILT_PRODUCTS_DIR; }; - OBJ_28 /* SwiftQueue */ = { + OBJ_20 /* SwiftQueue */ = { isa = PBXGroup; children = ( - OBJ_29 /* LinkedList.swift */, - OBJ_30 /* Queue.swift */, + OBJ_21 /* LinkedList.swift */, + OBJ_22 /* Queue.swift */, ); name = SwiftQueue; path = ".build/checkouts/SwiftQueue.git--1803263377898760171/Sources/SwiftQueue"; sourceTree = SOURCE_ROOT; }; - OBJ_32 /* Elligator 0.1.0 */ = { + OBJ_24 /* Elligator 0.1.0 */ = { isa = PBXGroup; children = ( - OBJ_33 /* celligator */, - OBJ_62 /* ElligatorObjC */, - OBJ_67 /* Elligator */, - OBJ_69 /* Package.swift */, + OBJ_25 /* celligator */, + OBJ_54 /* ElligatorObjC */, + OBJ_59 /* Elligator */, + OBJ_61 /* Package.swift */, ); name = "Elligator 0.1.0"; sourceTree = SOURCE_ROOT; }; - OBJ_33 /* celligator */ = { + OBJ_25 /* celligator */ = { isa = PBXGroup; children = ( - OBJ_34 /* crypto_verify_32.cc */, - OBJ_35 /* elligator.cpp */, - OBJ_36 /* fe_add.cc */, - OBJ_37 /* fe_cmov.cc */, - OBJ_38 /* fe_copy.cc */, - OBJ_39 /* fe_frombytes.cc */, - OBJ_40 /* fe_invert.cc */, - OBJ_41 /* fe_isnonzero.cc */, - OBJ_42 /* fe_mul.cc */, - OBJ_43 /* fe_neg.cc */, - OBJ_44 /* fe_sq.cc */, - OBJ_45 /* fe_sq2.cc */, - OBJ_46 /* fe_sub.cc */, - OBJ_47 /* fe_tobytes.cc */, - OBJ_48 /* ge_madd.cc */, - OBJ_49 /* ge_p1p1_to_p2.cc */, - OBJ_50 /* ge_p1p1_to_p3.cc */, - OBJ_51 /* ge_p2_dbl.cc */, - OBJ_52 /* ge_p3_0.cc */, - OBJ_53 /* ge_p3_dbl.cc */, - OBJ_54 /* ge_p3_to_p2.cc */, - OBJ_55 /* ge_precomp_0.cc */, - OBJ_56 /* ge_scalarmult_base.cc */, - OBJ_57 /* include */, + OBJ_26 /* crypto_verify_32.cc */, + OBJ_27 /* elligator.cpp */, + OBJ_28 /* fe_add.cc */, + OBJ_29 /* fe_cmov.cc */, + OBJ_30 /* fe_copy.cc */, + OBJ_31 /* fe_frombytes.cc */, + OBJ_32 /* fe_invert.cc */, + OBJ_33 /* fe_isnonzero.cc */, + OBJ_34 /* fe_mul.cc */, + OBJ_35 /* fe_neg.cc */, + OBJ_36 /* fe_sq.cc */, + OBJ_37 /* fe_sq2.cc */, + OBJ_38 /* fe_sub.cc */, + OBJ_39 /* fe_tobytes.cc */, + OBJ_40 /* ge_madd.cc */, + OBJ_41 /* ge_p1p1_to_p2.cc */, + OBJ_42 /* ge_p1p1_to_p3.cc */, + OBJ_43 /* ge_p2_dbl.cc */, + OBJ_44 /* ge_p3_0.cc */, + OBJ_45 /* ge_p3_dbl.cc */, + OBJ_46 /* ge_p3_to_p2.cc */, + OBJ_47 /* ge_precomp_0.cc */, + OBJ_48 /* ge_scalarmult_base.cc */, + OBJ_49 /* include */, ); name = celligator; path = ".build/checkouts/Elligator.git-1685432175989269477/Sources/celligator"; sourceTree = SOURCE_ROOT; }; - OBJ_5 /* */ = { + OBJ_49 /* include */ = { isa = PBXGroup; children = ( - OBJ_6 /* Package.swift */, - OBJ_7 /* Sources */, - OBJ_20 /* Tests */, - OBJ_25 /* Examples */, - OBJ_26 /* Dependencies */, - OBJ_183 /* Products */, + OBJ_50 /* fe.h */, + OBJ_51 /* ge.h */, + OBJ_52 /* base.h */, + OBJ_53 /* module.modulemap */, ); - name = ""; + path = include; sourceTree = ""; }; - OBJ_57 /* include */ = { + OBJ_5 = { isa = PBXGroup; children = ( - OBJ_58 /* fe.h */, - OBJ_59 /* ge.h */, - OBJ_60 /* base.h */, - OBJ_61 /* module.modulemap */, + OBJ_6 /* Package.swift */, + OBJ_7 /* Sources */, + OBJ_14 /* Tests */, + OBJ_17 /* Examples */, + OBJ_18 /* Dependencies */, + OBJ_193 /* Products */, ); - path = include; sourceTree = ""; }; - OBJ_62 /* ElligatorObjC */ = { + OBJ_54 /* ElligatorObjC */ = { isa = PBXGroup; children = ( - OBJ_63 /* ElligatorObjC.mm */, - OBJ_64 /* include */, + OBJ_55 /* ElligatorObjC.mm */, + OBJ_56 /* include */, ); name = ElligatorObjC; path = ".build/checkouts/Elligator.git-1685432175989269477/Sources/ElligatorObjC"; sourceTree = SOURCE_ROOT; }; - OBJ_64 /* include */ = { + OBJ_56 /* include */ = { isa = PBXGroup; children = ( - OBJ_65 /* ElligatorObjC.h */, - OBJ_66 /* module.modulemap */, + OBJ_57 /* ElligatorObjC.h */, + OBJ_58 /* module.modulemap */, ); path = include; sourceTree = ""; }; - OBJ_67 /* Elligator */ = { + OBJ_59 /* Elligator */ = { isa = PBXGroup; children = ( - OBJ_68 /* Elligator.swift */, + OBJ_60 /* Elligator.swift */, ); name = Elligator; path = ".build/checkouts/Elligator.git-1685432175989269477/Sources/Elligator"; sourceTree = SOURCE_ROOT; }; - OBJ_7 /* Sources */ = { - isa = PBXGroup; - children = ( - OBJ_8 /* Meek */, - OBJ_10 /* ShapeshifterTesting */, - OBJ_14 /* Wisp */, - ); - name = Sources; - sourceTree = SOURCE_ROOT; - }; - OBJ_70 /* HKDF 3.0.1 */ = { + OBJ_62 /* HKDF 3.0.1 */ = { isa = PBXGroup; children = ( - OBJ_71 /* Package.swift */, - OBJ_72 /* HKDF.swift */, + OBJ_63 /* Package.swift */, + OBJ_64 /* HKDF.swift */, ); name = "HKDF 3.0.1"; path = ".build/checkouts/HKDF.git-3816566315579078428/Sources"; sourceTree = SOURCE_ROOT; }; - OBJ_73 /* Cryptor 0.8.27 */ = { + OBJ_65 /* Cryptor 0.8.27 */ = { isa = PBXGroup; children = ( - OBJ_74 /* Cryptor */, - OBJ_85 /* Package.swift */, + OBJ_66 /* Cryptor */, + OBJ_77 /* Package.swift */, ); name = "Cryptor 0.8.27"; sourceTree = SOURCE_ROOT; }; - OBJ_74 /* Cryptor */ = { + OBJ_66 /* Cryptor */ = { isa = PBXGroup; children = ( - OBJ_75 /* Crypto.swift */, - OBJ_76 /* Cryptor.swift */, - OBJ_77 /* Digest.swift */, - OBJ_78 /* HMAC.swift */, - OBJ_79 /* KeyDerivation.swift */, - OBJ_80 /* Random.swift */, - OBJ_81 /* Status.swift */, - OBJ_82 /* StreamCryptor.swift */, - OBJ_83 /* Updatable.swift */, - OBJ_84 /* Utilities.swift */, + OBJ_67 /* Crypto.swift */, + OBJ_68 /* Cryptor.swift */, + OBJ_69 /* Digest.swift */, + OBJ_70 /* HMAC.swift */, + OBJ_71 /* KeyDerivation.swift */, + OBJ_72 /* Random.swift */, + OBJ_73 /* Status.swift */, + OBJ_74 /* StreamCryptor.swift */, + OBJ_75 /* Updatable.swift */, + OBJ_76 /* Utilities.swift */, ); name = Cryptor; path = ".build/checkouts/BlueCryptor.git-2709167748876642405/Sources/Cryptor"; sourceTree = SOURCE_ROOT; }; - OBJ_8 /* Meek */ = { + OBJ_7 /* Sources */ = { isa = PBXGroup; children = ( - OBJ_9 /* MeekTCPConnection.swift */, + OBJ_8 /* Wisp */, ); - name = Meek; - path = Sources/Meek; + name = Sources; sourceTree = SOURCE_ROOT; }; - OBJ_86 /* CryptoSwift 0.9.0 */ = { + OBJ_78 /* CryptoSwift 0.11.0 */ = { isa = PBXGroup; children = ( - OBJ_87 /* CryptoSwift */, - OBJ_159 /* Package.swift */, + OBJ_79 /* CryptoSwift */, + OBJ_155 /* Package.swift */, ); - name = "CryptoSwift 0.9.0"; + name = "CryptoSwift 0.11.0"; sourceTree = SOURCE_ROOT; }; - OBJ_87 /* CryptoSwift */ = { + OBJ_79 /* CryptoSwift */ = { isa = PBXGroup; children = ( - OBJ_88 /* AEAD */, - OBJ_91 /* AES.Cryptors.swift */, - OBJ_92 /* AES.swift */, - OBJ_93 /* Array+Extension.swift */, - OBJ_94 /* Authenticator.swift */, - OBJ_95 /* BatchedCollection.swift */, - OBJ_96 /* Bit.swift */, - OBJ_97 /* BlockCipher.swift */, - OBJ_98 /* BlockMode */, - OBJ_109 /* Blowfish.swift */, - OBJ_110 /* CMAC.swift */, - OBJ_111 /* ChaCha20.swift */, - OBJ_112 /* Checksum.swift */, - OBJ_113 /* Cipher.swift */, - OBJ_114 /* Collection+Extension.swift */, - OBJ_115 /* CompactMap.swift */, - OBJ_116 /* Cryptors.swift */, - OBJ_117 /* Digest.swift */, - OBJ_118 /* DigestType.swift */, - OBJ_119 /* Foundation */, - OBJ_129 /* Generics.swift */, - OBJ_130 /* HKDF.swift */, - OBJ_131 /* HMAC.swift */, - OBJ_132 /* Int+Extension.swift */, - OBJ_133 /* MD5.swift */, - OBJ_134 /* NoPadding.swift */, - OBJ_135 /* Operators.swift */, - OBJ_136 /* PKCS */, - OBJ_142 /* Padding.swift */, - OBJ_143 /* Poly1305.swift */, - OBJ_144 /* Rabbit.swift */, - OBJ_145 /* RandomAccessCryptor.swift */, - OBJ_146 /* RandomBytesSequence.swift */, - OBJ_147 /* SHA1.swift */, - OBJ_148 /* SHA2.swift */, - OBJ_149 /* SHA3.swift */, - OBJ_150 /* SecureBytes.swift */, - OBJ_151 /* String+Extension.swift */, - OBJ_152 /* UInt16+Extension.swift */, - OBJ_153 /* UInt32+Extension.swift */, - OBJ_154 /* UInt64+Extension.swift */, - OBJ_155 /* UInt8+Extension.swift */, - OBJ_156 /* Updatable.swift */, - OBJ_157 /* Utils.swift */, - OBJ_158 /* ZeroPadding.swift */, + OBJ_80 /* AEAD */, + OBJ_83 /* AES.Cryptors.swift */, + OBJ_84 /* AES.swift */, + OBJ_85 /* Array+Extension.swift */, + OBJ_86 /* Authenticator.swift */, + OBJ_87 /* BatchedCollection.swift */, + OBJ_88 /* Bit.swift */, + OBJ_89 /* BlockCipher.swift */, + OBJ_90 /* BlockDecryptor.swift */, + OBJ_91 /* BlockEncryptor.swift */, + OBJ_92 /* BlockMode */, + OBJ_103 /* Blowfish.swift */, + OBJ_104 /* CMAC.swift */, + OBJ_105 /* ChaCha20.swift */, + OBJ_106 /* Checksum.swift */, + OBJ_107 /* Cipher.swift */, + OBJ_108 /* Collection+Extension.swift */, + OBJ_109 /* CompactMap.swift */, + OBJ_110 /* Cryptor.swift */, + OBJ_111 /* Cryptors.swift */, + OBJ_112 /* Digest.swift */, + OBJ_113 /* DigestType.swift */, + OBJ_114 /* Foundation */, + OBJ_124 /* Generics.swift */, + OBJ_125 /* HKDF.swift */, + OBJ_126 /* HMAC.swift */, + OBJ_127 /* Int+Extension.swift */, + OBJ_128 /* MD5.swift */, + OBJ_129 /* NoPadding.swift */, + OBJ_130 /* Operators.swift */, + OBJ_131 /* PKCS */, + OBJ_137 /* Padding.swift */, + OBJ_138 /* Poly1305.swift */, + OBJ_139 /* Rabbit.swift */, + OBJ_140 /* RandomBytesSequence.swift */, + OBJ_141 /* SHA1.swift */, + OBJ_142 /* SHA2.swift */, + OBJ_143 /* SHA3.swift */, + OBJ_144 /* SecureBytes.swift */, + OBJ_145 /* StreamEncryptor.swift */, + OBJ_146 /* String+Extension.swift */, + OBJ_147 /* UInt128.swift */, + OBJ_148 /* UInt16+Extension.swift */, + OBJ_149 /* UInt32+Extension.swift */, + OBJ_150 /* UInt64+Extension.swift */, + OBJ_151 /* UInt8+Extension.swift */, + OBJ_152 /* Updatable.swift */, + OBJ_153 /* Utils.swift */, + OBJ_154 /* ZeroPadding.swift */, ); name = CryptoSwift; path = ".build/checkouts/CryptoSwift.git--6440749087414195235/Sources/CryptoSwift"; sourceTree = SOURCE_ROOT; }; - OBJ_88 /* AEAD */ = { + OBJ_8 /* Wisp */ = { + isa = PBXGroup; + children = ( + OBJ_9 /* WispCoding.swift */, + OBJ_10 /* WispConstants.swift */, + OBJ_11 /* WispErrors.swift */, + OBJ_12 /* WispProtocol.swift */, + OBJ_13 /* WispTCPConnection.swift */, + ); + name = Wisp; + path = Sources/Wisp; + sourceTree = SOURCE_ROOT; + }; + OBJ_80 /* AEAD */ = { isa = PBXGroup; children = ( - OBJ_89 /* AEAD.swift */, - OBJ_90 /* AEADChaCha20Poly1305.swift */, + OBJ_81 /* AEAD.swift */, + OBJ_82 /* AEADChaCha20Poly1305.swift */, ); path = AEAD; sourceTree = ""; }; - OBJ_98 /* BlockMode */ = { + OBJ_92 /* BlockMode */ = { isa = PBXGroup; children = ( - OBJ_99 /* BlockMode.swift */, - OBJ_100 /* BlockModeOptions.swift */, - OBJ_101 /* BlockModeWorker.swift */, - OBJ_102 /* CBC.swift */, - OBJ_103 /* CFB.swift */, - OBJ_104 /* CTR.swift */, - OBJ_105 /* ECB.swift */, - OBJ_106 /* OFB.swift */, - OBJ_107 /* PCBC.swift */, - OBJ_108 /* RandomAccessBlockModeWorker.swift */, + OBJ_93 /* BlockMode.swift */, + OBJ_94 /* BlockModeOptions.swift */, + OBJ_95 /* CBC.swift */, + OBJ_96 /* CFB.swift */, + OBJ_97 /* CTR.swift */, + OBJ_98 /* CipherModeWorker.swift */, + OBJ_99 /* ECB.swift */, + OBJ_100 /* GCM.swift */, + OBJ_101 /* OFB.swift */, + OBJ_102 /* PCBC.swift */, ); path = BlockMode; sourceTree = ""; @@ -1184,10 +1065,10 @@ /* Begin PBXNativeTarget section */ "CryptoSwift::CryptoSwift" /* CryptoSwift */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_203 /* Build configuration list for PBXNativeTarget "CryptoSwift" */; + buildConfigurationList = OBJ_210 /* Build configuration list for PBXNativeTarget "CryptoSwift" */; buildPhases = ( - OBJ_206 /* Sources */, - OBJ_274 /* Frameworks */, + OBJ_213 /* Sources */, + OBJ_285 /* Frameworks */, ); buildRules = ( ); @@ -1200,9 +1081,9 @@ }; "CryptoSwift::SwiftPMPackageDescription" /* CryptoSwiftPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_276 /* Build configuration list for PBXNativeTarget "CryptoSwiftPackageDescription" */; + buildConfigurationList = OBJ_287 /* Build configuration list for PBXNativeTarget "CryptoSwiftPackageDescription" */; buildPhases = ( - OBJ_279 /* Sources */, + OBJ_290 /* Sources */, ); buildRules = ( ); @@ -1214,10 +1095,10 @@ }; "Cryptor::Cryptor" /* Cryptor */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_282 /* Build configuration list for PBXNativeTarget "Cryptor" */; + buildConfigurationList = OBJ_293 /* Build configuration list for PBXNativeTarget "Cryptor" */; buildPhases = ( - OBJ_285 /* Sources */, - OBJ_296 /* Frameworks */, + OBJ_296 /* Sources */, + OBJ_307 /* Frameworks */, ); buildRules = ( ); @@ -1230,9 +1111,9 @@ }; "Cryptor::SwiftPMPackageDescription" /* CryptorPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_298 /* Build configuration list for PBXNativeTarget "CryptorPackageDescription" */; + buildConfigurationList = OBJ_309 /* Build configuration list for PBXNativeTarget "CryptorPackageDescription" */; buildPhases = ( - OBJ_301 /* Sources */, + OBJ_312 /* Sources */, ); buildRules = ( ); @@ -1244,16 +1125,16 @@ }; "Elligator::Elligator" /* Elligator */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_304 /* Build configuration list for PBXNativeTarget "Elligator" */; + buildConfigurationList = OBJ_315 /* Build configuration list for PBXNativeTarget "Elligator" */; buildPhases = ( - OBJ_307 /* Sources */, - OBJ_309 /* Frameworks */, + OBJ_318 /* Sources */, + OBJ_320 /* Frameworks */, ); buildRules = ( ); dependencies = ( - OBJ_312 /* PBXTargetDependency */, - OBJ_314 /* PBXTargetDependency */, + OBJ_323 /* PBXTargetDependency */, + OBJ_325 /* PBXTargetDependency */, ); name = Elligator; productName = Elligator; @@ -1262,15 +1143,15 @@ }; "Elligator::ElligatorObjC" /* ElligatorObjC */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_316 /* Build configuration list for PBXNativeTarget "ElligatorObjC" */; + buildConfigurationList = OBJ_327 /* Build configuration list for PBXNativeTarget "ElligatorObjC" */; buildPhases = ( - OBJ_319 /* Sources */, - OBJ_321 /* Frameworks */, + OBJ_330 /* Sources */, + OBJ_332 /* Frameworks */, ); buildRules = ( ); dependencies = ( - OBJ_323 /* PBXTargetDependency */, + OBJ_334 /* PBXTargetDependency */, ); name = ElligatorObjC; productName = ElligatorObjC; @@ -1279,9 +1160,9 @@ }; "Elligator::SwiftPMPackageDescription" /* ElligatorPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_325 /* Build configuration list for PBXNativeTarget "ElligatorPackageDescription" */; + buildConfigurationList = OBJ_336 /* Build configuration list for PBXNativeTarget "ElligatorPackageDescription" */; buildPhases = ( - OBJ_328 /* Sources */, + OBJ_339 /* Sources */, ); buildRules = ( ); @@ -1293,10 +1174,10 @@ }; "Elligator::celligator" /* celligator */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_505 /* Build configuration list for PBXNativeTarget "celligator" */; + buildConfigurationList = OBJ_491 /* Build configuration list for PBXNativeTarget "celligator" */; buildPhases = ( - OBJ_508 /* Sources */, - OBJ_532 /* Frameworks */, + OBJ_494 /* Sources */, + OBJ_518 /* Frameworks */, ); buildRules = ( ); @@ -1309,15 +1190,15 @@ }; "HKDF::HKDF" /* HKDF */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_331 /* Build configuration list for PBXNativeTarget "HKDF" */; + buildConfigurationList = OBJ_342 /* Build configuration list for PBXNativeTarget "HKDF" */; buildPhases = ( - OBJ_334 /* Sources */, - OBJ_336 /* Frameworks */, + OBJ_345 /* Sources */, + OBJ_347 /* Frameworks */, ); buildRules = ( ); dependencies = ( - OBJ_338 /* PBXTargetDependency */, + OBJ_349 /* PBXTargetDependency */, ); name = HKDF; productName = HKDF; @@ -1326,9 +1207,9 @@ }; "HKDF::SwiftPMPackageDescription" /* HKDFPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_340 /* Build configuration list for PBXNativeTarget "HKDFPackageDescription" */; + buildConfigurationList = OBJ_351 /* Build configuration list for PBXNativeTarget "HKDFPackageDescription" */; buildPhases = ( - OBJ_343 /* Sources */, + OBJ_354 /* Sources */, ); buildRules = ( ); @@ -1338,134 +1219,106 @@ productName = HKDFPackageDescription; productType = "com.apple.product-type.framework"; }; - "Shapeshifter-Swift-Transports::Meek" /* Meek */ = { + "Shapeshifter-Swift-Transports::SwiftPMPackageDescription" /* Shapeshifter-Swift-TransportsPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_346 /* Build configuration list for PBXNativeTarget "Meek" */; + buildConfigurationList = OBJ_357 /* Build configuration list for PBXNativeTarget "Shapeshifter-Swift-TransportsPackageDescription" */; buildPhases = ( - OBJ_349 /* Sources */, - OBJ_351 /* Frameworks */, + OBJ_360 /* Sources */, ); buildRules = ( ); dependencies = ( - OBJ_355 /* PBXTargetDependency */, - OBJ_357 /* PBXTargetDependency */, - OBJ_359 /* PBXTargetDependency */, ); - name = Meek; - productName = Meek; - productReference = "Shapeshifter-Swift-Transports::Meek::Product" /* Meek.framework */; + name = "Shapeshifter-Swift-TransportsPackageDescription"; + productName = "Shapeshifter-Swift-TransportsPackageDescription"; productType = "com.apple.product-type.framework"; }; - "Shapeshifter-Swift-Transports::MeekTests" /* MeekTests */ = { - isa = PBXNativeTarget; - buildConfigurationList = OBJ_361 /* Build configuration list for PBXNativeTarget "MeekTests" */; - buildPhases = ( - OBJ_364 /* Sources */, - OBJ_366 /* Frameworks */, - ); - buildRules = ( - ); - dependencies = ( - OBJ_372 /* PBXTargetDependency */, - OBJ_374 /* PBXTargetDependency */, - OBJ_375 /* PBXTargetDependency */, - OBJ_376 /* PBXTargetDependency */, - OBJ_377 /* PBXTargetDependency */, - ); - name = MeekTests; - productName = MeekTests; - productReference = "Shapeshifter-Swift-Transports::MeekTests::Product" /* MeekTests.xctest */; - productType = "com.apple.product-type.bundle.unit-test"; - }; - "Shapeshifter-Swift-Transports::ShapeshifterTesting" /* ShapeshifterTesting */ = { + "Shapeshifter-Swift-Transports::Wisp" /* Wisp */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_391 /* Build configuration list for PBXNativeTarget "ShapeshifterTesting" */; + buildConfigurationList = OBJ_437 /* Build configuration list for PBXNativeTarget "Wisp" */; buildPhases = ( - OBJ_394 /* Sources */, - OBJ_398 /* Frameworks */, + OBJ_440 /* Sources */, + OBJ_446 /* Frameworks */, ); buildRules = ( ); dependencies = ( - OBJ_400 /* PBXTargetDependency */, + OBJ_456 /* PBXTargetDependency */, + OBJ_457 /* PBXTargetDependency */, + OBJ_458 /* PBXTargetDependency */, + OBJ_459 /* PBXTargetDependency */, + OBJ_460 /* PBXTargetDependency */, + OBJ_461 /* PBXTargetDependency */, + OBJ_462 /* PBXTargetDependency */, + OBJ_463 /* PBXTargetDependency */, + OBJ_464 /* PBXTargetDependency */, ); - name = ShapeshifterTesting; - productName = ShapeshifterTesting; - productReference = "Shapeshifter-Swift-Transports::ShapeshifterTesting::Product" /* ShapeshifterTesting.framework */; + name = Wisp; + productName = Wisp; + productReference = "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */; productType = "com.apple.product-type.framework"; }; - "Shapeshifter-Swift-Transports::SwiftPMPackageDescription" /* Shapeshifter-Swift-TransportsPackageDescription */ = { + "Shapeshifter-Swift-Transports::WispTests" /* WispTests */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_379 /* Build configuration list for PBXNativeTarget "Shapeshifter-Swift-TransportsPackageDescription" */; + buildConfigurationList = OBJ_465 /* Build configuration list for PBXNativeTarget "WispTests" */; buildPhases = ( - OBJ_382 /* Sources */, + OBJ_468 /* Sources */, + OBJ_470 /* Frameworks */, ); buildRules = ( ); dependencies = ( + OBJ_481 /* PBXTargetDependency */, + OBJ_482 /* PBXTargetDependency */, + OBJ_483 /* PBXTargetDependency */, + OBJ_484 /* PBXTargetDependency */, + OBJ_485 /* PBXTargetDependency */, + OBJ_486 /* PBXTargetDependency */, + OBJ_487 /* PBXTargetDependency */, + OBJ_488 /* PBXTargetDependency */, + OBJ_489 /* PBXTargetDependency */, + OBJ_490 /* PBXTargetDependency */, ); - name = "Shapeshifter-Swift-TransportsPackageDescription"; - productName = "Shapeshifter-Swift-TransportsPackageDescription"; - productType = "com.apple.product-type.framework"; + name = WispTests; + productName = WispTests; + productReference = "Shapeshifter-Swift-Transports::WispTests::Product" /* WispTests.xctest */; + productType = "com.apple.product-type.bundle.unit-test"; }; - "Shapeshifter-Swift-Transports::Wisp" /* Wisp */ = { + "Sodium::Sodium" /* Sodium */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_449 /* Build configuration list for PBXNativeTarget "Wisp" */; + buildConfigurationList = OBJ_369 /* Build configuration list for PBXNativeTarget "Sodium" */; buildPhases = ( - OBJ_452 /* Sources */, - OBJ_458 /* Frameworks */, + OBJ_372 /* Sources */, + OBJ_395 /* Frameworks */, ); buildRules = ( ); dependencies = ( - OBJ_468 /* PBXTargetDependency */, - OBJ_469 /* PBXTargetDependency */, - OBJ_470 /* PBXTargetDependency */, - OBJ_471 /* PBXTargetDependency */, - OBJ_472 /* PBXTargetDependency */, - OBJ_473 /* PBXTargetDependency */, - OBJ_474 /* PBXTargetDependency */, - OBJ_475 /* PBXTargetDependency */, - OBJ_476 /* PBXTargetDependency */, ); - name = Wisp; - productName = Wisp; - productReference = "Shapeshifter-Swift-Transports::Wisp::Product" /* Wisp.framework */; + name = Sodium; + productName = Sodium; + productReference = "Sodium::Sodium::Product" /* Sodium.framework */; productType = "com.apple.product-type.framework"; }; - "Shapeshifter-Swift-Transports::WispTests" /* WispTests */ = { + "Sodium::SwiftPMPackageDescription" /* SodiumPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_477 /* Build configuration list for PBXNativeTarget "WispTests" */; + buildConfigurationList = OBJ_397 /* Build configuration list for PBXNativeTarget "SodiumPackageDescription" */; buildPhases = ( - OBJ_480 /* Sources */, - OBJ_482 /* Frameworks */, + OBJ_400 /* Sources */, ); buildRules = ( ); dependencies = ( - OBJ_494 /* PBXTargetDependency */, - OBJ_495 /* PBXTargetDependency */, - OBJ_496 /* PBXTargetDependency */, - OBJ_497 /* PBXTargetDependency */, - OBJ_498 /* PBXTargetDependency */, - OBJ_499 /* PBXTargetDependency */, - OBJ_500 /* PBXTargetDependency */, - OBJ_501 /* PBXTargetDependency */, - OBJ_502 /* PBXTargetDependency */, - OBJ_503 /* PBXTargetDependency */, - OBJ_504 /* PBXTargetDependency */, ); - name = WispTests; - productName = WispTests; - productReference = "Shapeshifter-Swift-Transports::WispTests::Product" /* WispTests.xctest */; - productType = "com.apple.product-type.bundle.unit-test"; + name = SodiumPackageDescription; + productName = SodiumPackageDescription; + productType = "com.apple.product-type.framework"; }; "SwiftQueue::SwiftPMPackageDescription" /* SwiftQueuePackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_429 /* Build configuration list for PBXNativeTarget "SwiftQueuePackageDescription" */; + buildConfigurationList = OBJ_411 /* Build configuration list for PBXNativeTarget "SwiftQueuePackageDescription" */; buildPhases = ( - OBJ_432 /* Sources */, + OBJ_414 /* Sources */, ); buildRules = ( ); @@ -1477,10 +1330,10 @@ }; "SwiftQueue::SwiftQueue" /* SwiftQueue */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_421 /* Build configuration list for PBXNativeTarget "SwiftQueue" */; + buildConfigurationList = OBJ_403 /* Build configuration list for PBXNativeTarget "SwiftQueue" */; buildPhases = ( - OBJ_424 /* Sources */, - OBJ_427 /* Frameworks */, + OBJ_406 /* Sources */, + OBJ_409 /* Frameworks */, ); buildRules = ( ); @@ -1493,9 +1346,9 @@ }; "Transport::SwiftPMPackageDescription" /* TransportPackageDescription */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_443 /* Build configuration list for PBXNativeTarget "TransportPackageDescription" */; + buildConfigurationList = OBJ_431 /* Build configuration list for PBXNativeTarget "TransportPackageDescription" */; buildPhases = ( - OBJ_446 /* Sources */, + OBJ_434 /* Sources */, ); buildRules = ( ); @@ -1507,10 +1360,10 @@ }; "Transport::Transport" /* Transport */ = { isa = PBXNativeTarget; - buildConfigurationList = OBJ_434 /* Build configuration list for PBXNativeTarget "Transport" */; + buildConfigurationList = OBJ_417 /* Build configuration list for PBXNativeTarget "Transport" */; buildPhases = ( - OBJ_437 /* Sources */, - OBJ_441 /* Frameworks */, + OBJ_420 /* Sources */, + OBJ_429 /* Frameworks */, ); buildRules = ( ); @@ -1521,36 +1374,6 @@ productReference = "Transport::Transport::Product" /* Transport.framework */; productType = "com.apple.product-type.framework"; }; - "swift-sodium::Sodium" /* Sodium */ = { - isa = PBXNativeTarget; - buildConfigurationList = OBJ_402 /* Build configuration list for PBXNativeTarget "Sodium" */; - buildPhases = ( - OBJ_405 /* Sources */, - OBJ_420 /* Frameworks */, - ); - buildRules = ( - ); - dependencies = ( - ); - name = Sodium; - productName = Sodium; - productReference = "swift-sodium::Sodium::Product" /* Sodium.framework */; - productType = "com.apple.product-type.framework"; - }; - "swift-sodium::SwiftPMPackageDescription" /* swift-sodiumPackageDescription */ = { - isa = PBXNativeTarget; - buildConfigurationList = OBJ_534 /* Build configuration list for PBXNativeTarget "swift-sodiumPackageDescription" */; - buildPhases = ( - OBJ_537 /* Sources */, - ); - buildRules = ( - ); - dependencies = ( - ); - name = "swift-sodiumPackageDescription"; - productName = "swift-sodiumPackageDescription"; - productType = "com.apple.product-type.framework"; - }; /* End PBXNativeTarget section */ /* Begin PBXProject section */ @@ -1566,12 +1389,11 @@ knownRegions = ( en, ); - mainGroup = OBJ_5 /* */; - productRefGroup = OBJ_183 /* Products */; + mainGroup = OBJ_5; + productRefGroup = OBJ_193 /* Products */; projectDirPath = ""; projectRoot = ""; targets = ( - "CommonCrypto::CommonCrypto::ProductTarget" /* CommonCrypto */, "CryptoSwift::CryptoSwift" /* CryptoSwift */, "CryptoSwift::SwiftPMPackageDescription" /* CryptoSwiftPackageDescription */, "Cryptor::Cryptor" /* Cryptor */, @@ -1581,12 +1403,10 @@ "Elligator::SwiftPMPackageDescription" /* ElligatorPackageDescription */, "HKDF::HKDF" /* HKDF */, "HKDF::SwiftPMPackageDescription" /* HKDFPackageDescription */, - "Shapeshifter-Swift-Transports::Meek" /* Meek */, - "Shapeshifter-Swift-Transports::MeekTests" /* MeekTests */, "Shapeshifter-Swift-Transports::SwiftPMPackageDescription" /* Shapeshifter-Swift-TransportsPackageDescription */, "Shapeshifter-Swift-Transports::Shapeshifter-Swift-TransportsPackageTests::ProductTarget" /* Shapeshifter-Swift-TransportsPackageTests */, - "Shapeshifter-Swift-Transports::ShapeshifterTesting" /* ShapeshifterTesting */, - "swift-sodium::Sodium" /* Sodium */, + "Sodium::Sodium" /* Sodium */, + "Sodium::SwiftPMPackageDescription" /* SodiumPackageDescription */, "SwiftQueue::SwiftQueue" /* SwiftQueue */, "SwiftQueue::SwiftPMPackageDescription" /* SwiftQueuePackageDescription */, "Transport::Transport" /* Transport */, @@ -1594,501 +1414,424 @@ "Shapeshifter-Swift-Transports::Wisp" /* Wisp */, "Shapeshifter-Swift-Transports::WispTests" /* WispTests */, "Elligator::celligator" /* celligator */, - "swift-sodium::SwiftPMPackageDescription" /* swift-sodiumPackageDescription */, ); }; /* End PBXProject section */ /* Begin PBXSourcesBuildPhase section */ - OBJ_206 /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 0; - files = ( - OBJ_207 /* AEAD.swift in Sources */, - OBJ_208 /* AEADChaCha20Poly1305.swift in Sources */, - OBJ_209 /* AES.Cryptors.swift in Sources */, - OBJ_210 /* AES.swift in Sources */, - OBJ_211 /* Array+Extension.swift in Sources */, - OBJ_212 /* Authenticator.swift in Sources */, - OBJ_213 /* BatchedCollection.swift in Sources */, - OBJ_214 /* Bit.swift in Sources */, - OBJ_215 /* BlockCipher.swift in Sources */, - OBJ_216 /* BlockMode.swift in Sources */, - OBJ_217 /* BlockModeOptions.swift in Sources */, - OBJ_218 /* BlockModeWorker.swift in Sources */, - OBJ_219 /* CBC.swift in Sources */, - OBJ_220 /* CFB.swift in Sources */, - OBJ_221 /* CTR.swift in Sources */, - OBJ_222 /* ECB.swift in Sources */, - OBJ_223 /* OFB.swift in Sources */, - OBJ_224 /* PCBC.swift in Sources */, - OBJ_225 /* RandomAccessBlockModeWorker.swift in Sources */, - OBJ_226 /* Blowfish.swift in Sources */, - OBJ_227 /* CMAC.swift in Sources */, - OBJ_228 /* ChaCha20.swift in Sources */, - OBJ_229 /* Checksum.swift in Sources */, - OBJ_230 /* Cipher.swift in Sources */, - OBJ_231 /* Collection+Extension.swift in Sources */, - OBJ_232 /* CompactMap.swift in Sources */, - OBJ_233 /* Cryptors.swift in Sources */, - OBJ_234 /* Digest.swift in Sources */, - OBJ_235 /* DigestType.swift in Sources */, - OBJ_236 /* AES+Foundation.swift in Sources */, - OBJ_237 /* Array+Foundation.swift in Sources */, - OBJ_238 /* Blowfish+Foundation.swift in Sources */, - OBJ_239 /* ChaCha20+Foundation.swift in Sources */, - OBJ_240 /* Data+Extension.swift in Sources */, - OBJ_241 /* HMAC+Foundation.swift in Sources */, - OBJ_242 /* Rabbit+Foundation.swift in Sources */, - OBJ_243 /* String+FoundationExtension.swift in Sources */, - OBJ_244 /* Utils+Foundation.swift in Sources */, - OBJ_245 /* Generics.swift in Sources */, - OBJ_246 /* HKDF.swift in Sources */, - OBJ_247 /* HMAC.swift in Sources */, - OBJ_248 /* Int+Extension.swift in Sources */, - OBJ_249 /* MD5.swift in Sources */, - OBJ_250 /* NoPadding.swift in Sources */, - OBJ_251 /* Operators.swift in Sources */, - OBJ_252 /* PBKDF1.swift in Sources */, - OBJ_253 /* PBKDF2.swift in Sources */, - OBJ_254 /* PKCS5.swift in Sources */, - OBJ_255 /* PKCS7.swift in Sources */, - OBJ_256 /* PKCS7Padding.swift in Sources */, - OBJ_257 /* Padding.swift in Sources */, - OBJ_258 /* Poly1305.swift in Sources */, - OBJ_259 /* Rabbit.swift in Sources */, - OBJ_260 /* RandomAccessCryptor.swift in Sources */, - OBJ_261 /* RandomBytesSequence.swift in Sources */, - OBJ_262 /* SHA1.swift in Sources */, - OBJ_263 /* SHA2.swift in Sources */, - OBJ_264 /* SHA3.swift in Sources */, - OBJ_265 /* SecureBytes.swift in Sources */, - OBJ_266 /* String+Extension.swift in Sources */, - OBJ_267 /* UInt16+Extension.swift in Sources */, - OBJ_268 /* UInt32+Extension.swift in Sources */, - OBJ_269 /* UInt64+Extension.swift in Sources */, - OBJ_270 /* UInt8+Extension.swift in Sources */, - OBJ_271 /* Updatable.swift in Sources */, - OBJ_272 /* Utils.swift in Sources */, - OBJ_273 /* ZeroPadding.swift in Sources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_279 /* Sources */ = { + OBJ_213 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_280 /* Package.swift in Sources */, + OBJ_214 /* AEAD.swift in Sources */, + OBJ_215 /* AEADChaCha20Poly1305.swift in Sources */, + OBJ_216 /* AES.Cryptors.swift in Sources */, + OBJ_217 /* AES.swift in Sources */, + OBJ_218 /* Array+Extension.swift in Sources */, + OBJ_219 /* Authenticator.swift in Sources */, + OBJ_220 /* BatchedCollection.swift in Sources */, + OBJ_221 /* Bit.swift in Sources */, + OBJ_222 /* BlockCipher.swift in Sources */, + OBJ_223 /* BlockDecryptor.swift in Sources */, + OBJ_224 /* BlockEncryptor.swift in Sources */, + OBJ_225 /* BlockMode.swift in Sources */, + OBJ_226 /* BlockModeOptions.swift in Sources */, + OBJ_227 /* CBC.swift in Sources */, + OBJ_228 /* CFB.swift in Sources */, + OBJ_229 /* CTR.swift in Sources */, + OBJ_230 /* CipherModeWorker.swift in Sources */, + OBJ_231 /* ECB.swift in Sources */, + OBJ_232 /* GCM.swift in Sources */, + OBJ_233 /* OFB.swift in Sources */, + OBJ_234 /* PCBC.swift in Sources */, + OBJ_235 /* Blowfish.swift in Sources */, + OBJ_236 /* CMAC.swift in Sources */, + OBJ_237 /* ChaCha20.swift in Sources */, + OBJ_238 /* Checksum.swift in Sources */, + OBJ_239 /* Cipher.swift in Sources */, + OBJ_240 /* Collection+Extension.swift in Sources */, + OBJ_241 /* CompactMap.swift in Sources */, + OBJ_242 /* Cryptor.swift in Sources */, + OBJ_243 /* Cryptors.swift in Sources */, + OBJ_244 /* Digest.swift in Sources */, + OBJ_245 /* DigestType.swift in Sources */, + OBJ_246 /* AES+Foundation.swift in Sources */, + OBJ_247 /* Array+Foundation.swift in Sources */, + OBJ_248 /* Blowfish+Foundation.swift in Sources */, + OBJ_249 /* ChaCha20+Foundation.swift in Sources */, + OBJ_250 /* Data+Extension.swift in Sources */, + OBJ_251 /* HMAC+Foundation.swift in Sources */, + OBJ_252 /* Rabbit+Foundation.swift in Sources */, + OBJ_253 /* String+FoundationExtension.swift in Sources */, + OBJ_254 /* Utils+Foundation.swift in Sources */, + OBJ_255 /* Generics.swift in Sources */, + OBJ_256 /* HKDF.swift in Sources */, + OBJ_257 /* HMAC.swift in Sources */, + OBJ_258 /* Int+Extension.swift in Sources */, + OBJ_259 /* MD5.swift in Sources */, + OBJ_260 /* NoPadding.swift in Sources */, + OBJ_261 /* Operators.swift in Sources */, + OBJ_262 /* PBKDF1.swift in Sources */, + OBJ_263 /* PBKDF2.swift in Sources */, + OBJ_264 /* PKCS5.swift in Sources */, + OBJ_265 /* PKCS7.swift in Sources */, + OBJ_266 /* PKCS7Padding.swift in Sources */, + OBJ_267 /* Padding.swift in Sources */, + OBJ_268 /* Poly1305.swift in Sources */, + OBJ_269 /* Rabbit.swift in Sources */, + OBJ_270 /* RandomBytesSequence.swift in Sources */, + OBJ_271 /* SHA1.swift in Sources */, + OBJ_272 /* SHA2.swift in Sources */, + OBJ_273 /* SHA3.swift in Sources */, + OBJ_274 /* SecureBytes.swift in Sources */, + OBJ_275 /* StreamEncryptor.swift in Sources */, + OBJ_276 /* String+Extension.swift in Sources */, + OBJ_277 /* UInt128.swift in Sources */, + OBJ_278 /* UInt16+Extension.swift in Sources */, + OBJ_279 /* UInt32+Extension.swift in Sources */, + OBJ_280 /* UInt64+Extension.swift in Sources */, + OBJ_281 /* UInt8+Extension.swift in Sources */, + OBJ_282 /* Updatable.swift in Sources */, + OBJ_283 /* Utils.swift in Sources */, + OBJ_284 /* ZeroPadding.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_285 /* Sources */ = { + OBJ_290 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_286 /* Crypto.swift in Sources */, - OBJ_287 /* Cryptor.swift in Sources */, - OBJ_288 /* Digest.swift in Sources */, - OBJ_289 /* HMAC.swift in Sources */, - OBJ_290 /* KeyDerivation.swift in Sources */, - OBJ_291 /* Random.swift in Sources */, - OBJ_292 /* Status.swift in Sources */, - OBJ_293 /* StreamCryptor.swift in Sources */, - OBJ_294 /* Updatable.swift in Sources */, - OBJ_295 /* Utilities.swift in Sources */, + OBJ_291 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_301 /* Sources */ = { + OBJ_296 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_302 /* Package.swift in Sources */, + OBJ_297 /* Crypto.swift in Sources */, + OBJ_298 /* Cryptor.swift in Sources */, + OBJ_299 /* Digest.swift in Sources */, + OBJ_300 /* HMAC.swift in Sources */, + OBJ_301 /* KeyDerivation.swift in Sources */, + OBJ_302 /* Random.swift in Sources */, + OBJ_303 /* Status.swift in Sources */, + OBJ_304 /* StreamCryptor.swift in Sources */, + OBJ_305 /* Updatable.swift in Sources */, + OBJ_306 /* Utilities.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_307 /* Sources */ = { + OBJ_312 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_308 /* Elligator.swift in Sources */, + OBJ_313 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_319 /* Sources */ = { + OBJ_318 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_320 /* ElligatorObjC.mm in Sources */, + OBJ_319 /* Elligator.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_328 /* Sources */ = { + OBJ_330 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_329 /* Package.swift in Sources */, + OBJ_331 /* ElligatorObjC.mm in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_334 /* Sources */ = { + OBJ_339 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_335 /* HKDF.swift in Sources */, + OBJ_340 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_343 /* Sources */ = { + OBJ_345 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_344 /* Package.swift in Sources */, + OBJ_346 /* HKDF.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_349 /* Sources */ = { + OBJ_354 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_350 /* MeekTCPConnection.swift in Sources */, + OBJ_355 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_364 /* Sources */ = { + OBJ_360 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_365 /* MeekTests.swift in Sources */, + OBJ_361 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_382 /* Sources */ = { + OBJ_372 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_383 /* Package.swift in Sources */, + OBJ_373 /* Aead.swift in Sources */, + OBJ_374 /* Auth.swift in Sources */, + OBJ_375 /* Box.swift in Sources */, + OBJ_376 /* Bytes.swift in Sources */, + OBJ_377 /* ExitCode.swift in Sources */, + OBJ_378 /* KeyPairGenerator.swift in Sources */, + OBJ_379 /* KeyPairProtocol.swift in Sources */, + OBJ_380 /* NonceGenerator.swift in Sources */, + OBJ_381 /* SecretKeyGenerator.swift in Sources */, + OBJ_382 /* GenericHash.swift in Sources */, + OBJ_383 /* KeyDerivation.swift in Sources */, + OBJ_384 /* KeyExchange.swift in Sources */, + OBJ_385 /* PWHash.swift in Sources */, + OBJ_386 /* RandomBytes.swift in Sources */, + OBJ_387 /* SecretBox.swift in Sources */, + OBJ_388 /* SecretStream.swift in Sources */, + OBJ_389 /* ShortHash.swift in Sources */, + OBJ_390 /* Sign.swift in Sources */, + OBJ_391 /* Sodium.swift in Sources */, + OBJ_392 /* StateStream.swift in Sources */, + OBJ_393 /* Stream.swift in Sources */, + OBJ_394 /* Utils.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_394 /* Sources */ = { + OBJ_400 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_395 /* FakePacketTunnelProvider.swift in Sources */, - OBJ_396 /* FakeTCPConnection.swift in Sources */, - OBJ_397 /* FakeUDPSession.swift in Sources */, + OBJ_401 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_405 /* Sources */ = { + OBJ_406 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_406 /* Auth.swift in Sources */, - OBJ_407 /* Box.swift in Sources */, - OBJ_408 /* GenericHash.swift in Sources */, - OBJ_409 /* KeyDerivation.swift in Sources */, - OBJ_410 /* KeyExchange.swift in Sources */, - OBJ_411 /* PWHash.swift in Sources */, - OBJ_412 /* RandomBytes.swift in Sources */, - OBJ_413 /* SecretBox.swift in Sources */, - OBJ_414 /* SecretStream.swift in Sources */, - OBJ_415 /* ShortHash.swift in Sources */, - OBJ_416 /* Sign.swift in Sources */, - OBJ_417 /* Sodium.swift in Sources */, - OBJ_418 /* Stream.swift in Sources */, - OBJ_419 /* Utils.swift in Sources */, + OBJ_407 /* LinkedList.swift in Sources */, + OBJ_408 /* Queue.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_424 /* Sources */ = { + OBJ_414 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_425 /* LinkedList.swift in Sources */, - OBJ_426 /* Queue.swift in Sources */, + OBJ_415 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_432 /* Sources */ = { + OBJ_420 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_433 /* Package.swift in Sources */, + OBJ_421 /* Connection.swift in Sources */, + OBJ_422 /* ConnectionFactory.swift in Sources */, + OBJ_423 /* IPv4Address.swift in Sources */, + OBJ_424 /* NWConnection.swift in Sources */, + OBJ_425 /* NWEndpoint.swift in Sources */, + OBJ_426 /* NWError.swift in Sources */, + OBJ_427 /* NWParameters.swift in Sources */, + OBJ_428 /* NetworkConnectionFactory.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_437 /* Sources */ = { + OBJ_434 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_438 /* PacketTunnelProvider.swift in Sources */, - OBJ_439 /* TCPConnection.swift in Sources */, - OBJ_440 /* UDPSession.swift in Sources */, + OBJ_435 /* Package.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_446 /* Sources */ = { + OBJ_440 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_447 /* Package.swift in Sources */, + OBJ_441 /* WispCoding.swift in Sources */, + OBJ_442 /* WispConstants.swift in Sources */, + OBJ_443 /* WispErrors.swift in Sources */, + OBJ_444 /* WispProtocol.swift in Sources */, + OBJ_445 /* WispTCPConnection.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_452 /* Sources */ = { + OBJ_468 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_453 /* WispCoding.swift in Sources */, - OBJ_454 /* WispConstants.swift in Sources */, - OBJ_455 /* WispErrors.swift in Sources */, - OBJ_456 /* WispProtocol.swift in Sources */, - OBJ_457 /* WispTCPConnection.swift in Sources */, + OBJ_469 /* WispTests.swift in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; - OBJ_480 /* Sources */ = { + OBJ_494 /* Sources */ = { isa = PBXSourcesBuildPhase; buildActionMask = 0; files = ( - OBJ_481 /* WispTests.swift in Sources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_508 /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 0; - files = ( - OBJ_509 /* crypto_verify_32.cc in Sources */, - OBJ_510 /* elligator.cpp in Sources */, - OBJ_511 /* fe_add.cc in Sources */, - OBJ_512 /* fe_cmov.cc in Sources */, - OBJ_513 /* fe_copy.cc in Sources */, - OBJ_514 /* fe_frombytes.cc in Sources */, - OBJ_515 /* fe_invert.cc in Sources */, - OBJ_516 /* fe_isnonzero.cc in Sources */, - OBJ_517 /* fe_mul.cc in Sources */, - OBJ_518 /* fe_neg.cc in Sources */, - OBJ_519 /* fe_sq.cc in Sources */, - OBJ_520 /* fe_sq2.cc in Sources */, - OBJ_521 /* fe_sub.cc in Sources */, - OBJ_522 /* fe_tobytes.cc in Sources */, - OBJ_523 /* ge_madd.cc in Sources */, - OBJ_524 /* ge_p1p1_to_p2.cc in Sources */, - OBJ_525 /* ge_p1p1_to_p3.cc in Sources */, - OBJ_526 /* ge_p2_dbl.cc in Sources */, - OBJ_527 /* ge_p3_0.cc in Sources */, - OBJ_528 /* ge_p3_dbl.cc in Sources */, - OBJ_529 /* ge_p3_to_p2.cc in Sources */, - OBJ_530 /* ge_precomp_0.cc in Sources */, - OBJ_531 /* ge_scalarmult_base.cc in Sources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; - OBJ_537 /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 0; - files = ( - OBJ_538 /* Package.swift in Sources */, + OBJ_495 /* crypto_verify_32.cc in Sources */, + OBJ_496 /* elligator.cpp in Sources */, + OBJ_497 /* fe_add.cc in Sources */, + OBJ_498 /* fe_cmov.cc in Sources */, + OBJ_499 /* fe_copy.cc in Sources */, + OBJ_500 /* fe_frombytes.cc in Sources */, + OBJ_501 /* fe_invert.cc in Sources */, + OBJ_502 /* fe_isnonzero.cc in Sources */, + OBJ_503 /* fe_mul.cc in Sources */, + OBJ_504 /* fe_neg.cc in Sources */, + OBJ_505 /* fe_sq.cc in Sources */, + OBJ_506 /* fe_sq2.cc in Sources */, + OBJ_507 /* fe_sub.cc in Sources */, + OBJ_508 /* fe_tobytes.cc in Sources */, + OBJ_509 /* ge_madd.cc in Sources */, + OBJ_510 /* ge_p1p1_to_p2.cc in Sources */, + OBJ_511 /* ge_p1p1_to_p3.cc in Sources */, + OBJ_512 /* ge_p2_dbl.cc in Sources */, + OBJ_513 /* ge_p3_0.cc in Sources */, + OBJ_514 /* ge_p3_dbl.cc in Sources */, + OBJ_515 /* ge_p3_to_p2.cc in Sources */, + OBJ_516 /* ge_precomp_0.cc in Sources */, + OBJ_517 /* ge_scalarmult_base.cc in Sources */, ); runOnlyForDeploymentPostprocessing = 0; }; /* End PBXSourcesBuildPhase section */ /* Begin PBXTargetDependency section */ - OBJ_312 /* PBXTargetDependency */ = { + OBJ_323 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::ElligatorObjC" /* ElligatorObjC */; - targetProxy = 468318A620ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641021190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_314 /* PBXTargetDependency */ = { + OBJ_325 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::celligator" /* celligator */; - targetProxy = 468318A820ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_323 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Elligator::celligator" /* celligator */; - targetProxy = 468318A720ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_338 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Cryptor::Cryptor" /* Cryptor */; - targetProxy = 468318AC20ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_355 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "SwiftQueue::SwiftQueue" /* SwiftQueue */; - targetProxy = 468318B020ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_357 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Transport::Transport" /* Transport */; - targetProxy = 468318B120ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_359 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "CryptoSwift::CryptoSwift" /* CryptoSwift */; - targetProxy = 468318B220ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_372 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Shapeshifter-Swift-Transports::ShapeshifterTesting" /* ShapeshifterTesting */; - targetProxy = 468318B320ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_374 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Shapeshifter-Swift-Transports::Meek" /* Meek */; - targetProxy = 468318B420ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_375 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "SwiftQueue::SwiftQueue" /* SwiftQueue */; - targetProxy = 468318B520ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_376 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Transport::Transport" /* Transport */; - targetProxy = 468318B620ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641221190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_377 /* PBXTargetDependency */ = { + OBJ_334 /* PBXTargetDependency */ = { isa = PBXTargetDependency; - target = "CryptoSwift::CryptoSwift" /* CryptoSwift */; - targetProxy = 468318B720ACD19000CFBBBD /* PBXContainerItemProxy */; + target = "Elligator::celligator" /* celligator */; + targetProxy = 467D641121190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_388 /* PBXTargetDependency */ = { + OBJ_349 /* PBXTargetDependency */ = { isa = PBXTargetDependency; - target = "Shapeshifter-Swift-Transports::MeekTests" /* MeekTests */; - targetProxy = 468318C320ACD19200CFBBBD /* PBXContainerItemProxy */; + target = "Cryptor::Cryptor" /* Cryptor */; + targetProxy = 467D640F21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_389 /* PBXTargetDependency */ = { + OBJ_366 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Shapeshifter-Swift-Transports::WispTests" /* WispTests */; - targetProxy = 468318C420ACD19200CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_400 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "Transport::Transport" /* Transport */; - targetProxy = 468318A220ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642621190DC600D65DDE /* PBXContainerItemProxy */; }; - OBJ_468 /* PBXTargetDependency */ = { + OBJ_456 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "SwiftQueue::SwiftQueue" /* SwiftQueue */; - targetProxy = 468318A320ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641321190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_469 /* PBXTargetDependency */ = { + OBJ_457 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Transport::Transport" /* Transport */; - targetProxy = 468318A420ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641421190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_470 /* PBXTargetDependency */ = { + OBJ_458 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::Elligator" /* Elligator */; - targetProxy = 468318A520ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641521190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_471 /* PBXTargetDependency */ = { + OBJ_459 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::ElligatorObjC" /* ElligatorObjC */; - targetProxy = 468318A920ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641621190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_472 /* PBXTargetDependency */ = { + OBJ_460 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::celligator" /* celligator */; - targetProxy = 468318AA20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641721190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_473 /* PBXTargetDependency */ = { + OBJ_461 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "HKDF::HKDF" /* HKDF */; - targetProxy = 468318AB20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641821190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_474 /* PBXTargetDependency */ = { + OBJ_462 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Cryptor::Cryptor" /* Cryptor */; - targetProxy = 468318AD20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641921190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_475 /* PBXTargetDependency */ = { + OBJ_463 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "CryptoSwift::CryptoSwift" /* CryptoSwift */; - targetProxy = 468318AE20ACD19000CFBBBD /* PBXContainerItemProxy */; - }; - OBJ_476 /* PBXTargetDependency */ = { - isa = PBXTargetDependency; - target = "swift-sodium::Sodium" /* Sodium */; - targetProxy = 468318AF20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641A21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_494 /* PBXTargetDependency */ = { + OBJ_464 /* PBXTargetDependency */ = { isa = PBXTargetDependency; - target = "Shapeshifter-Swift-Transports::ShapeshifterTesting" /* ShapeshifterTesting */; - targetProxy = 468318B820ACD19000CFBBBD /* PBXContainerItemProxy */; + target = "Sodium::Sodium" /* Sodium */; + targetProxy = 467D641B21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_495 /* PBXTargetDependency */ = { + OBJ_481 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Shapeshifter-Swift-Transports::Wisp" /* Wisp */; - targetProxy = 468318B920ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641C21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_496 /* PBXTargetDependency */ = { + OBJ_482 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "SwiftQueue::SwiftQueue" /* SwiftQueue */; - targetProxy = 468318BA20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641D21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_497 /* PBXTargetDependency */ = { + OBJ_483 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Transport::Transport" /* Transport */; - targetProxy = 468318BB20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641E21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_498 /* PBXTargetDependency */ = { + OBJ_484 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::Elligator" /* Elligator */; - targetProxy = 468318BC20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D641F21190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_499 /* PBXTargetDependency */ = { + OBJ_485 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::ElligatorObjC" /* ElligatorObjC */; - targetProxy = 468318BD20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642021190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_500 /* PBXTargetDependency */ = { + OBJ_486 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Elligator::celligator" /* celligator */; - targetProxy = 468318BE20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642121190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_501 /* PBXTargetDependency */ = { + OBJ_487 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "HKDF::HKDF" /* HKDF */; - targetProxy = 468318BF20ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642221190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_502 /* PBXTargetDependency */ = { + OBJ_488 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "Cryptor::Cryptor" /* Cryptor */; - targetProxy = 468318C020ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642321190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_503 /* PBXTargetDependency */ = { + OBJ_489 /* PBXTargetDependency */ = { isa = PBXTargetDependency; target = "CryptoSwift::CryptoSwift" /* CryptoSwift */; - targetProxy = 468318C120ACD19000CFBBBD /* PBXContainerItemProxy */; + targetProxy = 467D642421190DC500D65DDE /* PBXContainerItemProxy */; }; - OBJ_504 /* PBXTargetDependency */ = { + OBJ_490 /* PBXTargetDependency */ = { isa = PBXTargetDependency; - target = "swift-sodium::Sodium" /* Sodium */; - targetProxy = 468318C220ACD19000CFBBBD /* PBXContainerItemProxy */; + target = "Sodium::Sodium" /* Sodium */; + targetProxy = 467D642521190DC500D65DDE /* PBXContainerItemProxy */; }; /* End PBXTargetDependency section */ /* Begin XCBuildConfiguration section */ - OBJ_200 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - }; - name = Debug; - }; - OBJ_201 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - }; - name = Release; - }; - OBJ_204 /* Debug */ = { + OBJ_211 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2111,7 +1854,7 @@ }; name = Debug; }; - OBJ_205 /* Release */ = { + OBJ_212 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2134,7 +1877,7 @@ }; name = Release; }; - OBJ_277 /* Debug */ = { + OBJ_288 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2143,7 +1886,7 @@ }; name = Debug; }; - OBJ_278 /* Release */ = { + OBJ_289 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2152,7 +1895,7 @@ }; name = Release; }; - OBJ_283 /* Debug */ = { + OBJ_294 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2178,7 +1921,7 @@ }; name = Debug; }; - OBJ_284 /* Release */ = { + OBJ_295 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2204,15 +1947,6 @@ }; name = Release; }; - OBJ_299 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - LD = /usr/bin/true; - OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; - SWIFT_VERSION = 4.0; - }; - name = Debug; - }; OBJ_3 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { @@ -2235,7 +1969,16 @@ }; name = Debug; }; - OBJ_300 /* Release */ = { + OBJ_310 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + LD = /usr/bin/true; + OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; + SWIFT_VERSION = 4.0; + }; + name = Debug; + }; + OBJ_311 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2244,7 +1987,7 @@ }; name = Release; }; - OBJ_305 /* Debug */ = { + OBJ_316 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2273,7 +2016,7 @@ }; name = Debug; }; - OBJ_306 /* Release */ = { + OBJ_317 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2302,7 +2045,7 @@ }; name = Release; }; - OBJ_317 /* Debug */ = { + OBJ_328 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { DEFINES_MODULE = NO; @@ -2329,7 +2072,7 @@ }; name = Debug; }; - OBJ_318 /* Release */ = { + OBJ_329 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { DEFINES_MODULE = NO; @@ -2356,7 +2099,7 @@ }; name = Release; }; - OBJ_326 /* Debug */ = { + OBJ_337 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2365,7 +2108,7 @@ }; name = Debug; }; - OBJ_327 /* Release */ = { + OBJ_338 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2374,7 +2117,7 @@ }; name = Release; }; - OBJ_332 /* Debug */ = { + OBJ_343 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2400,7 +2143,7 @@ }; name = Debug; }; - OBJ_333 /* Release */ = { + OBJ_344 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2426,7 +2169,7 @@ }; name = Release; }; - OBJ_341 /* Debug */ = { + OBJ_352 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2435,7 +2178,7 @@ }; name = Debug; }; - OBJ_342 /* Release */ = { + OBJ_353 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2444,103 +2187,7 @@ }; name = Release; }; - OBJ_347 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - ENABLE_TESTABILITY = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/Meek_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - PRODUCT_BUNDLE_IDENTIFIER = Meek; - PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; - PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; - SKIP_INSTALL = YES; - SWIFT_VERSION = 4.0; - TARGET_NAME = Meek; - }; - name = Debug; - }; - OBJ_348 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ENABLE_TESTABILITY = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/Meek_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - PRODUCT_BUNDLE_IDENTIFIER = Meek; - PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; - PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; - SKIP_INSTALL = YES; - SWIFT_VERSION = 4.0; - TARGET_NAME = Meek; - }; - name = Release; - }; - OBJ_362 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - EMBEDDED_CONTENT_CONTAINS_SWIFT = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/MeekTests_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) @loader_path/../Frameworks @loader_path/Frameworks"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - SWIFT_VERSION = 4.0; - TARGET_NAME = MeekTests; - }; - name = Debug; - }; - OBJ_363 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - EMBEDDED_CONTENT_CONTAINS_SWIFT = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/MeekTests_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) @loader_path/../Frameworks @loader_path/Frameworks"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - SWIFT_VERSION = 4.0; - TARGET_NAME = MeekTests; - }; - name = Release; - }; - OBJ_380 /* Debug */ = { + OBJ_358 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2549,7 +2196,7 @@ }; name = Debug; }; - OBJ_381 /* Release */ = { + OBJ_359 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2558,91 +2205,19 @@ }; name = Release; }; - OBJ_386 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - }; - name = Debug; - }; - OBJ_387 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - }; - name = Release; - }; - OBJ_392 /* Debug */ = { + OBJ_364 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { - ENABLE_TESTABILITY = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/ShapeshifterTesting_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - PRODUCT_BUNDLE_IDENTIFIER = ShapeshifterTesting; - PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; - PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; - SKIP_INSTALL = YES; - SWIFT_VERSION = 4.0; - TARGET_NAME = ShapeshifterTesting; }; name = Debug; }; - OBJ_393 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ENABLE_TESTABILITY = YES; - FRAMEWORK_SEARCH_PATHS = ( - "$(inherited)", - "$(PLATFORM_DIR)/Developer/Library/Frameworks", - ); - HEADER_SEARCH_PATHS = ( - "$(inherited)", - "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", - ); - INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/ShapeshifterTesting_Info.plist"; - LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; - OTHER_CFLAGS = "$(inherited)"; - OTHER_LDFLAGS = "$(inherited)"; - OTHER_SWIFT_FLAGS = "$(inherited)"; - PRODUCT_BUNDLE_IDENTIFIER = ShapeshifterTesting; - PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; - PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; - SKIP_INSTALL = YES; - SWIFT_VERSION = 4.0; - TARGET_NAME = ShapeshifterTesting; - }; - name = Release; - }; - OBJ_4 /* Release */ = { + OBJ_365 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { - CLANG_ENABLE_OBJC_ARC = YES; - COMBINE_HIDPI_IMAGES = YES; - COPY_PHASE_STRIP = YES; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - DYLIB_INSTALL_NAME_BASE = "@rpath"; - GCC_OPTIMIZATION_LEVEL = s; - MACOSX_DEPLOYMENT_TARGET = 10.13; - OTHER_SWIFT_FLAGS = "-DXcode"; - PRODUCT_NAME = "$(TARGET_NAME)"; - SDKROOT = macosx; - SUPPORTED_PLATFORMS = "macosx iphoneos iphonesimulator appletvos appletvsimulator watchos watchsimulator"; - SWIFT_ACTIVE_COMPILATION_CONDITIONS = SWIFT_PACKAGE; - SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule"; - USE_HEADERMAP = NO; }; name = Release; }; - OBJ_403 /* Debug */ = { + OBJ_370 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2652,20 +2227,20 @@ ); HEADER_SEARCH_PATHS = ( "$(inherited)", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", ); INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/Sodium_Info.plist"; LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include"; PRODUCT_BUNDLE_IDENTIFIER = Sodium; PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; @@ -2675,7 +2250,7 @@ }; name = Debug; }; - OBJ_404 /* Release */ = { + OBJ_371 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2685,20 +2260,20 @@ ); HEADER_SEARCH_PATHS = ( "$(inherited)", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", ); INFOPLIST_FILE = "Shapeshifter-Swift-Transports.xcodeproj/Sodium_Info.plist"; LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include"; PRODUCT_BUNDLE_IDENTIFIER = Sodium; PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; @@ -2708,7 +2283,45 @@ }; name = Release; }; - OBJ_422 /* Debug */ = { + OBJ_398 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + LD = /usr/bin/true; + OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; + SWIFT_VERSION = 4.0; + }; + name = Debug; + }; + OBJ_399 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + LD = /usr/bin/true; + OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; + SWIFT_VERSION = 4.0; + }; + name = Release; + }; + OBJ_4 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_ENABLE_OBJC_ARC = YES; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + GCC_OPTIMIZATION_LEVEL = s; + MACOSX_DEPLOYMENT_TARGET = 10.13; + OTHER_SWIFT_FLAGS = "-DXcode"; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SUPPORTED_PLATFORMS = "macosx iphoneos iphonesimulator appletvos appletvsimulator watchos watchsimulator"; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = SWIFT_PACKAGE; + SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule"; + USE_HEADERMAP = NO; + }; + name = Release; + }; + OBJ_404 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2731,7 +2344,7 @@ }; name = Debug; }; - OBJ_423 /* Release */ = { + OBJ_405 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2754,7 +2367,7 @@ }; name = Release; }; - OBJ_430 /* Debug */ = { + OBJ_412 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2763,7 +2376,7 @@ }; name = Debug; }; - OBJ_431 /* Release */ = { + OBJ_413 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2772,7 +2385,7 @@ }; name = Release; }; - OBJ_435 /* Debug */ = { + OBJ_418 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2795,7 +2408,7 @@ }; name = Debug; }; - OBJ_436 /* Release */ = { + OBJ_419 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2818,7 +2431,7 @@ }; name = Release; }; - OBJ_444 /* Debug */ = { + OBJ_432 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2827,7 +2440,7 @@ }; name = Debug; }; - OBJ_445 /* Release */ = { + OBJ_433 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { LD = /usr/bin/true; @@ -2836,7 +2449,7 @@ }; name = Release; }; - OBJ_450 /* Debug */ = { + OBJ_438 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2848,8 +2461,8 @@ "$(inherited)", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/ElligatorObjC/include", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/celligator/include", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator", ); @@ -2857,14 +2470,14 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; PRODUCT_BUNDLE_IDENTIFIER = Wisp; PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; @@ -2874,7 +2487,7 @@ }; name = Debug; }; - OBJ_451 /* Release */ = { + OBJ_439 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { ENABLE_TESTABILITY = YES; @@ -2886,8 +2499,8 @@ "$(inherited)", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/ElligatorObjC/include", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/celligator/include", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator", ); @@ -2895,14 +2508,14 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; PRODUCT_BUNDLE_IDENTIFIER = Wisp; PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)"; PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)"; @@ -2912,7 +2525,7 @@ }; name = Release; }; - OBJ_478 /* Debug */ = { + OBJ_466 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { EMBEDDED_CONTENT_CONTAINS_SWIFT = YES; @@ -2924,8 +2537,8 @@ "$(inherited)", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/ElligatorObjC/include", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/celligator/include", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator", ); @@ -2933,20 +2546,20 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @loader_path/../Frameworks @loader_path/Frameworks"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; SWIFT_VERSION = 4.0; TARGET_NAME = WispTests; }; name = Debug; }; - OBJ_479 /* Release */ = { + OBJ_467 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { EMBEDDED_CONTENT_CONTAINS_SWIFT = YES; @@ -2958,8 +2571,8 @@ "$(inherited)", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/ElligatorObjC/include", "$(SRCROOT)/.build/checkouts/Elligator.git-1685432175989269477/Sources/celligator/include", - "$(SRCROOT)/.build/checkouts/Clibsodium.git-7179824380838366220", "$(SRCROOT)/.build/checkouts/CommonCrypto.git-1219305460334093717", + "$(SRCROOT)/.build/checkouts/Clibsodium.git--6266754812837251518", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC", "$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator", ); @@ -2967,20 +2580,20 @@ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @loader_path/../Frameworks @loader_path/Frameworks"; OTHER_CFLAGS = ( "$(inherited)", - "-I/usr/local/Cellar/libsodium/1.0.15/include", + "-I/usr/local/Cellar/libsodium/1.0.16/include", ); OTHER_LDFLAGS = ( "$(inherited)", - "-L/usr/local/Cellar/libsodium/1.0.15/lib", + "-L/usr/local/Cellar/libsodium/1.0.16/lib", "-lsodium", ); - OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.15/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; + OTHER_SWIFT_FLAGS = "$(inherited) -I/usr/local/Cellar/libsodium/1.0.16/include -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/ElligatorObjC/module.modulemap -Xcc -fmodule-map-file=$(SRCROOT)/Shapeshifter-Swift-Transports.xcodeproj/GeneratedModuleMap/celligator/module.modulemap"; SWIFT_VERSION = 4.0; TARGET_NAME = WispTests; }; name = Release; }; - OBJ_506 /* Debug */ = { + OBJ_492 /* Debug */ = { isa = XCBuildConfiguration; buildSettings = { DEFINES_MODULE = NO; @@ -3006,7 +2619,7 @@ }; name = Debug; }; - OBJ_507 /* Release */ = { + OBJ_493 /* Release */ = { isa = XCBuildConfiguration; buildSettings = { DEFINES_MODULE = NO; @@ -3032,36 +2645,9 @@ }; name = Release; }; - OBJ_535 /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - LD = /usr/bin/true; - OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; - SWIFT_VERSION = 4.0; - }; - name = Debug; - }; - OBJ_536 /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - LD = /usr/bin/true; - OTHER_SWIFT_FLAGS = "-swift-version 4 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk"; - SWIFT_VERSION = 4.0; - }; - name = Release; - }; /* End XCBuildConfiguration section */ /* Begin XCConfigurationList section */ - OBJ_199 /* Build configuration list for PBXAggregateTarget "CommonCrypto" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - OBJ_200 /* Debug */, - OBJ_201 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; OBJ_2 /* Build configuration list for PBXProject "Shapeshifter-Swift-Transports" */ = { isa = XCConfigurationList; buildConfigurations = ( @@ -3071,209 +2657,182 @@ defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_203 /* Build configuration list for PBXNativeTarget "CryptoSwift" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - OBJ_204 /* Debug */, - OBJ_205 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - OBJ_276 /* Build configuration list for PBXNativeTarget "CryptoSwiftPackageDescription" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - OBJ_277 /* Debug */, - OBJ_278 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - OBJ_282 /* Build configuration list for PBXNativeTarget "Cryptor" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - OBJ_283 /* Debug */, - OBJ_284 /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - OBJ_298 /* Build configuration list for PBXNativeTarget "CryptorPackageDescription" */ = { + OBJ_210 /* Build configuration list for PBXNativeTarget "CryptoSwift" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_299 /* Debug */, - OBJ_300 /* Release */, + OBJ_211 /* Debug */, + OBJ_212 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_304 /* Build configuration list for PBXNativeTarget "Elligator" */ = { + OBJ_287 /* Build configuration list for PBXNativeTarget "CryptoSwiftPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_305 /* Debug */, - OBJ_306 /* Release */, + OBJ_288 /* Debug */, + OBJ_289 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_316 /* Build configuration list for PBXNativeTarget "ElligatorObjC" */ = { + OBJ_293 /* Build configuration list for PBXNativeTarget "Cryptor" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_317 /* Debug */, - OBJ_318 /* Release */, + OBJ_294 /* Debug */, + OBJ_295 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_325 /* Build configuration list for PBXNativeTarget "ElligatorPackageDescription" */ = { + OBJ_309 /* Build configuration list for PBXNativeTarget "CryptorPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_326 /* Debug */, - OBJ_327 /* Release */, + OBJ_310 /* Debug */, + OBJ_311 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_331 /* Build configuration list for PBXNativeTarget "HKDF" */ = { + OBJ_315 /* Build configuration list for PBXNativeTarget "Elligator" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_332 /* Debug */, - OBJ_333 /* Release */, + OBJ_316 /* Debug */, + OBJ_317 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_340 /* Build configuration list for PBXNativeTarget "HKDFPackageDescription" */ = { + OBJ_327 /* Build configuration list for PBXNativeTarget "ElligatorObjC" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_341 /* Debug */, - OBJ_342 /* Release */, + OBJ_328 /* Debug */, + OBJ_329 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_346 /* Build configuration list for PBXNativeTarget "Meek" */ = { + OBJ_336 /* Build configuration list for PBXNativeTarget "ElligatorPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_347 /* Debug */, - OBJ_348 /* Release */, + OBJ_337 /* Debug */, + OBJ_338 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_361 /* Build configuration list for PBXNativeTarget "MeekTests" */ = { + OBJ_342 /* Build configuration list for PBXNativeTarget "HKDF" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_362 /* Debug */, - OBJ_363 /* Release */, + OBJ_343 /* Debug */, + OBJ_344 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_379 /* Build configuration list for PBXNativeTarget "Shapeshifter-Swift-TransportsPackageDescription" */ = { + OBJ_351 /* Build configuration list for PBXNativeTarget "HKDFPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_380 /* Debug */, - OBJ_381 /* Release */, + OBJ_352 /* Debug */, + OBJ_353 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_385 /* Build configuration list for PBXAggregateTarget "Shapeshifter-Swift-TransportsPackageTests" */ = { + OBJ_357 /* Build configuration list for PBXNativeTarget "Shapeshifter-Swift-TransportsPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_386 /* Debug */, - OBJ_387 /* Release */, + OBJ_358 /* Debug */, + OBJ_359 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_391 /* Build configuration list for PBXNativeTarget "ShapeshifterTesting" */ = { + OBJ_363 /* Build configuration list for PBXAggregateTarget "Shapeshifter-Swift-TransportsPackageTests" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_392 /* Debug */, - OBJ_393 /* Release */, + OBJ_364 /* Debug */, + OBJ_365 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_402 /* Build configuration list for PBXNativeTarget "Sodium" */ = { + OBJ_369 /* Build configuration list for PBXNativeTarget "Sodium" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_403 /* Debug */, - OBJ_404 /* Release */, + OBJ_370 /* Debug */, + OBJ_371 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_421 /* Build configuration list for PBXNativeTarget "SwiftQueue" */ = { + OBJ_397 /* Build configuration list for PBXNativeTarget "SodiumPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_422 /* Debug */, - OBJ_423 /* Release */, + OBJ_398 /* Debug */, + OBJ_399 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_429 /* Build configuration list for PBXNativeTarget "SwiftQueuePackageDescription" */ = { + OBJ_403 /* Build configuration list for PBXNativeTarget "SwiftQueue" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_430 /* Debug */, - OBJ_431 /* Release */, + OBJ_404 /* Debug */, + OBJ_405 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_434 /* Build configuration list for PBXNativeTarget "Transport" */ = { + OBJ_411 /* Build configuration list for PBXNativeTarget "SwiftQueuePackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_435 /* Debug */, - OBJ_436 /* Release */, + OBJ_412 /* Debug */, + OBJ_413 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_443 /* Build configuration list for PBXNativeTarget "TransportPackageDescription" */ = { + OBJ_417 /* Build configuration list for PBXNativeTarget "Transport" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_444 /* Debug */, - OBJ_445 /* Release */, + OBJ_418 /* Debug */, + OBJ_419 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_449 /* Build configuration list for PBXNativeTarget "Wisp" */ = { + OBJ_431 /* Build configuration list for PBXNativeTarget "TransportPackageDescription" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_450 /* Debug */, - OBJ_451 /* Release */, + OBJ_432 /* Debug */, + OBJ_433 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_477 /* Build configuration list for PBXNativeTarget "WispTests" */ = { + OBJ_437 /* Build configuration list for PBXNativeTarget "Wisp" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_478 /* Debug */, - OBJ_479 /* Release */, + OBJ_438 /* Debug */, + OBJ_439 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_505 /* Build configuration list for PBXNativeTarget "celligator" */ = { + OBJ_465 /* Build configuration list for PBXNativeTarget "WispTests" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_506 /* Debug */, - OBJ_507 /* Release */, + OBJ_466 /* Debug */, + OBJ_467 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; }; - OBJ_534 /* Build configuration list for PBXNativeTarget "swift-sodiumPackageDescription" */ = { + OBJ_491 /* Build configuration list for PBXNativeTarget "celligator" */ = { isa = XCConfigurationList; buildConfigurations = ( - OBJ_535 /* Debug */, - OBJ_536 /* Release */, + OBJ_492 /* Debug */, + OBJ_493 /* Release */, ); defaultConfigurationIsVisible = 0; defaultConfigurationName = Release; diff --git a/Shapeshifter-Swift-Transports.xcodeproj/xcshareddata/xcschemes/Shapeshifter-Swift-Transports-Package.xcscheme b/Shapeshifter-Swift-Transports.xcodeproj/xcshareddata/xcschemes/Shapeshifter-Swift-Transports-Package.xcscheme index a147b7d..e4b4006 100644 --- a/Shapeshifter-Swift-Transports.xcodeproj/xcshareddata/xcschemes/Shapeshifter-Swift-Transports-Package.xcscheme +++ b/Shapeshifter-Swift-Transports.xcodeproj/xcshareddata/xcschemes/Shapeshifter-Swift-Transports-Package.xcscheme @@ -14,23 +14,9 @@ buildForAnalyzing = "YES"> - - - - @@ -42,9 +28,9 @@ buildForAnalyzing = "YES"> @@ -56,9 +42,9 @@ buildForAnalyzing = "YES"> @@ -70,9 +56,9 @@ buildForAnalyzing = "YES"> @@ -84,9 +70,9 @@ buildForAnalyzing = "YES"> @@ -98,9 +84,9 @@ buildForAnalyzing = "YES"> @@ -112,9 +98,9 @@ buildForAnalyzing = "YES"> @@ -126,9 +112,9 @@ buildForAnalyzing = "YES"> @@ -140,9 +126,9 @@ buildForAnalyzing = "YES"> @@ -160,20 +146,6 @@ ReferencedContainer = "container:Shapeshifter-Swift-Transports.xcodeproj"> - - - - - - - - diff --git a/Sources/ShapeshifterTesting/FakePacketTunnelProvider.swift b/Sources/ShapeshifterTesting/FakePacketTunnelProvider.swift deleted file mode 100644 index d8ce73a..0000000 --- a/Sources/ShapeshifterTesting/FakePacketTunnelProvider.swift +++ /dev/null @@ -1,57 +0,0 @@ -// -// FakePacketTunnelProvider.swift -// Shapeshifter-Swift-Transports -// -// Created by Brandon Wiley on 10/30/17. -// Copyright Ā© 2017 Operator Foundation. All rights reserved. -// - -import Foundation -import NetworkExtension -import Transport - -open class FakePacketTunnelProvider: PacketTunnelProvider -{ - public init() { - // super.init() - } - - open func startTunnel(options: [String : NSObject]? = nil, completionHandler: @escaping (Error?) -> Void) { - completionHandler(nil) - } - - open func stopTunnel(with reason: NEProviderStopReason, completionHandler: @escaping () -> Void) { - completionHandler() - } - - public func cancelTunnelWithError(_ error: Error?) { - // Do nothing - } - - public func createTCPConnectionThroughTunnel(to remoteEndpoint: NWEndpoint, enableTLS: Bool, tlsParameters TLSParameters: NWTLSParameters?, delegate: Any?) -> TCPConnection? - { - return FakeTCPConnection(to: remoteEndpoint) - } - - public func createUDPSessionThroughTunnel(to remoteEndpoint: NWEndpoint, - from localEndpoint: NWHostEndpoint?) -> NWUDPSession { - return FakeUDPSession(to: remoteEndpoint, from: localEndpoint) - } - - public func setTunnelNetworkSettings(_ tunnelNetworkSettings: NETunnelNetworkSettings?, - completionHandler: ((Error?) -> Void)? = nil) { - if let completion = completionHandler - { - completion(nil) - } - } - - open func handleAppMessage(_ messageData: Data, completionHandler: ((Data?) -> Void)? = nil) - { - if let completion = completionHandler - { - completion(nil) - } - } -} - diff --git a/Sources/ShapeshifterTesting/FakeTCPConnection.swift b/Sources/ShapeshifterTesting/FakeTCPConnection.swift deleted file mode 100644 index 3c418ce..0000000 --- a/Sources/ShapeshifterTesting/FakeTCPConnection.swift +++ /dev/null @@ -1,173 +0,0 @@ -// -// FakeTCPConnection.swift -// Shapeshifter-Swift-Transports -// -// Created by Brandon Wiley on 10/24/17. -// Copyright Ā© 2017 Operator Foundation. All rights reserved. -// - -import Foundation -import NetworkExtension -import Transport - -public func createFakeTCPConnection(to:NWEndpoint) -> FakeTCPConnection? -{ - return FakeTCPConnection(to: to) -} - -public class FakeTCPConnection: TCPConnection -{ - var network: URLSessionStreamTask - var stateCallback: ((NWTCPConnectionState, Error?) -> Void)? - - private var _endpoint: NWEndpoint - private var _isViable: Bool - private var _state: NWTCPConnectionState { - didSet { - guard let callback = stateCallback else { - return - } - - callback(_state, nil) - } - } - - public var state: NWTCPConnectionState { - get { - return _state - } - } - - public var isViable: Bool { - get { - return _isViable - } - } - - public var error: Error? { - get { - return nil - } - } - - public var endpoint: NWEndpoint { - get { - return _endpoint - } - } - - public var remoteAddress: NWEndpoint? { - get { - return _endpoint - } - } - - public var localAddress: NWEndpoint? { - get { - return NWHostEndpoint(hostname: "127.0.0.1", port: "1234") - } - } - - public var connectedPath: NWPath? { - get { - return nil - } - } - - public var txtRecord: Data? { - get { - return nil - } - } - - public var hasBetterPath: Bool { - get { - return false - } - } - - init?(to: NWEndpoint) - { - if let hostendpoint = to as? NWHostEndpoint - { - _endpoint = to - let session = URLSession(configuration: .default, delegate: nil, delegateQueue: nil) - network = session.streamTask(withHostName: "\(hostendpoint.hostname)", port: Int(hostendpoint.port)!) - network.resume() - - _isViable = true - _state = .connected - } - else - { - return nil - } - } - - public func observeState(_ callback: @escaping (NWTCPConnectionState, Error?) -> Void) { - self.stateCallback=callback - - callback(_state, nil) - } - - public func readMinimumLength(_ minimum: Int, maximumLength maximum: Int, completionHandler completion: @escaping (Data?, Error?) -> Void) - { - network.readData(ofMinLength: 0, maxLength: 100000, timeout: 60) - { - (data, bool, error) in - - guard error == nil else { - completion(nil, error) - return - } - - guard data != nil else { - completion(nil, nil) - return - } - - completion(data, nil) - } - } - - public func readLength(_ length: Int, completionHandler completion: @escaping (Data?, Error?) -> Void) { - readMinimumLength(length, maximumLength: length) - { - (data, error) in - - guard error == nil else { - completion(nil, error) - return - } - - guard data != nil else { - completion(nil, nil) - return - } - - completion(data, nil) - } - } - - public func write(_ data: Data, completionHandler completion: @escaping (Error?) -> Void) - { - network.write(data, timeout: 0) - { - (error) in - - completion(error) - } - } - - public func writeClose() - { - network.closeWrite() - } - - public func cancel() { - writeClose() - network.closeRead() - _state = .cancelled - } -} - diff --git a/Sources/ShapeshifterTesting/FakeUDPSession.swift b/Sources/ShapeshifterTesting/FakeUDPSession.swift deleted file mode 100644 index 0e58975..0000000 --- a/Sources/ShapeshifterTesting/FakeUDPSession.swift +++ /dev/null @@ -1,42 +0,0 @@ -// -// FakeUDPSession.swift -// Shapeshifter-Swift-Transports -// -// Created by Brandon Wiley on 10/30/17. -// Copyright Ā© 2017 Operator Foundation. All rights reserved. -// - -import Foundation -import NetworkExtension - -public class FakeUDPSession: NWUDPSession { - var privEndpoint: NWEndpoint - var privIsViable: Bool - var privState: NWUDPSessionState - - override public var state: NWUDPSessionState { - get { - return privState - } - } - - override public var isViable: Bool { - get { - return privIsViable - } - } - - override public var endpoint: NWEndpoint { - get { - return privEndpoint - } - } - - init(to remoteEndpoint: NWEndpoint, from localEndpoint: NWHostEndpoint?) { - self.privEndpoint = remoteEndpoint - self.privState = .ready - self.privIsViable = true - - super.init() - } -} diff --git a/Sources/Wisp/WispCoding.swift b/Sources/Wisp/WispCoding.swift index d50a138..b3a1d53 100644 --- a/Sources/Wisp/WispCoding.swift +++ b/Sources/Wisp/WispCoding.swift @@ -83,7 +83,14 @@ struct HashDrbg mutating func nextBlock() -> Data { let sodium = Sodium() - self.ofb = sodium.shortHash.hash(message: self.ofb, key: self.sip)! + guard let ofbBytes = sodium.shortHash.hash(message: self.ofb.bytes, key: self.sip.bytes), ofbBytes.count == siphashSize + else + { + print("Error getting next block, sodium hash failed or was the wrong size.") + return Data() + } + + self.ofb = Data(ofbBytes) return self.ofb[0 ..< 8] } } @@ -134,19 +141,21 @@ struct WispEncoder print("encoder nonce counter: \(self.nonce.counter)") print("encoder nonce key: \(nonce.prefix.count)") - guard let encodedData: Data = sodium.secretBox.seal(message: payload, secretKey: secretBoxKey, nonce: self.nonce.data) +// guard let encodedBytes = sodium.secretBox.seal(message: payload, secretKey: secretBoxKey, nonce: self.nonce.data) + guard let encodedBytes = sodium.secretBox.seal(message: payload.bytes, secretKey: secretBoxKey.bytes, nonce: self.nonce.data.bytes) else { return nil } - print("encoded data: \(encodedData.bytes)") - print("encoded data length: \(encodedData.count)") + print("encoded data: \(encodedBytes)") + print("encoded data length: \(encodedBytes.count)") // Obfuscate the length. - let length = UInt16(encodedData.count) + let length = UInt16(encodedBytes.count) let obfuscatedLength = obfuscate(length: length) + let encodedData = Data(bytes: encodedBytes) var frame = Data() frame.append(obfuscatedLength) @@ -270,7 +279,7 @@ struct WispDecoder print("nonce counter: \(nonce.counter)") print("nonce secret key: \(nonce.prefix.bytes)") - guard let decodedData = sodium.secretBox.open(authenticatedCipherText: box, secretKey: secretBoxKey, nonce: nonce.data) + guard let decodedData = sodium.secretBox.open(authenticatedCipherText: box.bytes, secretKey: secretBoxKey.bytes, nonce: nonce.data.bytes) else { nextLength = nil @@ -287,7 +296,7 @@ struct WispDecoder // Clean up and prepare for the next frame. nextLength = nil - return .success(decodedData: decodedData, leftovers: leftovers) + return .success(decodedData: Data(bytes: decodedData), leftovers: leftovers) } mutating func unobfuscate(obfuscatedLength: Data) -> UInt16 diff --git a/Sources/Wisp/WispProtocol.swift b/Sources/Wisp/WispProtocol.swift index f00a581..11a2a6a 100644 --- a/Sources/Wisp/WispProtocol.swift +++ b/Sources/Wisp/WispProtocol.swift @@ -12,7 +12,6 @@ // implementation to other obfs4 implementations except when required for over-the-wire compatibility. import Foundation -import NetworkExtension import Sodium import CryptoSwift import Elligator @@ -122,7 +121,8 @@ struct ClientHandshake handshakeBuffer.append(contentsOf: mark[0 ..< markLength]) // Calculate and write the MAC. - guard let macOfBuffer = try? self.mac.authenticate(handshakeBuffer.bytes + self.epochHour.bytes) + + guard let macOfBuffer: Bytes = try? self.mac.authenticate(handshakeBuffer.bytes + self.epochHour.utf8) else { print("Unable to create hmac for handshake buffer.") @@ -202,13 +202,13 @@ class WispProtocol let sessionKey: Keypair let iatMode: Bool - var network: TCPConnection + var network: Connection var encoder: WispEncoder? var decoder: WispDecoder? var receivedBuffer = Data() var receivedDecodedBuffer = Data() - init?(connection: TCPConnection, cert: String, iatMode enableIAT: Bool) + init?(connection: Connection, cert: String, iatMode enableIAT: Bool) { network = connection iatMode = enableIAT @@ -249,7 +249,8 @@ class WispProtocol return } - network.write(clientHandshakeBytes) + let context = NWConnection.ContentContext() + let sendCompletion = NWConnection.SendCompletion(completion: { (maybeWriteError) in @@ -262,30 +263,71 @@ class WispProtocol } // Consume the server handshake. - self.network.readMinimumLength(serverMinHandshakeLength, maximumLength: maxHandshakeLength, completionHandler: - { - (maybeReadData, maybeReadError) in - - if let readError = maybeReadError + self.network.receive(minimumIncompleteLength: serverMinHandshakeLength, maximumLength: maxHandshakeLength, completion: { - print("Error reading from network:") - print(readError.localizedDescription) + (maybeReadData, maybeContentContext, readComplete, maybeReadError) in + //FIXME: Bool in this completion has unknown meaning - completion(readError) - return - } - - guard let readData = maybeReadData - else - { - completion(WispError.invalidResponse) - print("No data received when attempting to read server handshake šŸ¤”") - return - } - - self.readServerHandshake(clientHandshake: newHandshake, buffer: readData, completion: completion) + if let readError = maybeReadError + { + print("Error reading from network:") + print(readError.localizedDescription) + + completion(readError) + return + } + + guard let readData = maybeReadData + else + { + completion(WispError.invalidResponse) + print("No data received when attempting to read server handshake šŸ¤”") + return + } + + self.readServerHandshake(clientHandshake: newHandshake, buffer: readData, completion: completion) }) - } + }) + + network.send(content: clientHandshakeBytes, contentContext: context, isComplete: true, completion: sendCompletion) + +// network.write(clientHandshakeBytes) +// { +// (maybeWriteError) in +// +// if let writeError = maybeWriteError +// { +// print("Received an error when writing client handshake to the network:") +// print(writeError.localizedDescription) +// completion(writeError) +// return +// } +// +// // Consume the server handshake. +// self.network.readMinimumLength(serverMinHandshakeLength, maximumLength: maxHandshakeLength, completionHandler: +// { +// (maybeReadData, maybeReadError) in +// +// if let readError = maybeReadError +// { +// print("Error reading from network:") +// print(readError.localizedDescription) +// +// completion(readError) +// return +// } +// +// guard let readData = maybeReadData +// else +// { +// completion(WispError.invalidResponse) +// print("No data received when attempting to read server handshake šŸ¤”") +// return +// } +// +// self.readServerHandshake(clientHandshake: newHandshake, buffer: readData, completion: completion) +// }) +// } } func readServerHandshake(clientHandshake: ClientHandshake, buffer: Data, completion: @escaping (Error?) -> Void) @@ -298,9 +340,10 @@ class WispProtocol completion(WispError.invalidServerHandshake) return case .retry: - self.network.readMinimumLength(1, maximumLength: maxHandshakeLength - buffer.count) + self.network.receive(minimumIncompleteLength: 1, maximumLength: maxHandshakeLength - buffer.count) { - (maybeReadData, maybeReadError) in + (maybeReadData, maybeReadContext, readComplete, maybeReadError) in + //FIXME: Bool in this completion has unknown meaning if let readError = maybeReadError { @@ -322,6 +365,30 @@ class WispProtocol self.readServerHandshake(clientHandshake: clientHandshake, buffer: newBuffer, completion: completion) return } +// self.network.readMinimumLength(1, maximumLength: maxHandshakeLength - buffer.count) +// { +// (maybeReadData, maybeReadError) in +// +// if let readError = maybeReadError +// { +// print("Error reading from network:") +// print(readError.localizedDescription) +// +// completion(readError) +// return +// } +// +// guard let readData = maybeReadData +// else +// { +// completion(WispError.invalidResponse) +// return +// } +// +// let newBuffer = buffer + readData +// self.readServerHandshake(clientHandshake: clientHandshake, buffer: newBuffer, completion: completion) +// return +// } case let .success(seed): /// TODO: Test, We are assuming that count refers to desired output size in bytes not bits. <------ // HKDF @@ -399,7 +466,7 @@ class WispProtocol let prefixIncludingMark = response[0 ..< serverMarkRange.upperBound] let epochHour = clientHandshake.epochHour let providedMac = response[serverMarkRange.upperBound ..< serverMarkRange.upperBound + macLength] - let thingToMac = prefixIncludingMark.bytes + epochHour.bytes + let thingToMac = prefixIncludingMark.bytes + epochHour.utf8 @@ -422,7 +489,7 @@ class WispProtocol print("\nThing to mac is \(thingToMac.count) long.") print("prefix length is \(prefixIncludingMark.count)") print("\nprefix including mark: \(prefixIncludingMark.bytes)") - print("epoch hour: \(epochHour.bytes)") + print("epoch hour: \(epochHour.utf8)") return .failed } @@ -463,9 +530,9 @@ class WispProtocol func readPackets(minRead: Int, maxRead: Int, completion: @escaping (Data?, Error?) -> Void) { // Attempt to read off the network. - network.readMinimumLength(1, maximumLength: maxFrameLength) + network.receive(minimumIncompleteLength: 1, maximumLength: maxFrameLength) { - (maybeData, maybeError) in + (maybeData, maybeContext, receiveComplete, maybeError) in if let error = maybeError { @@ -474,7 +541,7 @@ class WispProtocol } guard let receivedData = maybeData - else + else { completion(nil, WispError.connectionClosed) return @@ -483,7 +550,7 @@ class WispProtocol self.receivedBuffer.append(receivedData) guard self.decoder != nil - else + else { completion(nil, WispError.decoderNotFound) return @@ -529,10 +596,77 @@ class WispProtocol self.readPackets(minRead: minRead, maxRead: maxRead, completion: completion) } return - - } } + +// network.readMinimumLength(1, maximumLength: maxFrameLength) +// { +// (maybeData, maybeError) in +// +// if let error = maybeError +// { +// completion(nil, error) +// return +// } +// +// guard let receivedData = maybeData +// else +// { +// completion(nil, WispError.connectionClosed) +// return +// } +// +// self.receivedBuffer.append(receivedData) +// +// guard self.decoder != nil +// else +// { +// completion(nil, WispError.decoderNotFound) +// return +// } +// +// let result = self.decoder!.decode(framesBuffer: self.receivedBuffer) +// +// switch result +// { +// case .failed: +// completion(nil, WispError.decoderFailure) +// return +// case .retry: +// self.readPackets(minRead: minRead, maxRead: maxRead, completion: completion) +// return +// case let .success(decodedData, leftovers): +// if leftovers != nil +// { +// self.receivedBuffer = leftovers! +// } +// else +// { +// self.receivedBuffer = Data() +// } +// +// //Handle packet data writes to the decoded buffer +// self.handlePacketData(data: decodedData) +// if self.receivedDecodedBuffer.count >= minRead +// { +// if self.receivedDecodedBuffer.count > maxRead +// { +// /// Slice +// completion(self.receivedDecodedBuffer[0 ..< maxRead], nil) +// } +// else +// { +// /// No Slice +// completion(self.receivedDecodedBuffer, nil) +// } +// } +// else +// { +// self.readPackets(minRead: minRead, maxRead: maxRead, completion: completion) +// } +// return +// } +// } } func handlePacketData(data: Data) @@ -572,36 +706,36 @@ class WispProtocol let sodium = Sodium() let zeroData = Data(repeating: 0x00, count: sharedSecretLength) - guard let ephemeralSharedSecret = sodium.keyExchange.sessionKeyPair(publicKey: clientKeypair.publicKey, secretKey: clientKeypair.privateKey, otherPublicKey: serverPublicKey, side: .CLIENT) + guard let ephemeralSharedSecret = sodium.keyExchange.sessionKeyPair(publicKey: clientKeypair.publicKey.bytes, secretKey: clientKeypair.privateKey.bytes, otherPublicKey: serverPublicKey.bytes, side: .CLIENT) else { print("ntorClientHandshake: Unable to derive ephermeral shared secret.") return nil } - guard let staticSharedSecret = sodium.keyExchange.sessionKeyPair(publicKey: clientKeypair.publicKey, secretKey: clientKeypair.privateKey, otherPublicKey: idPublicKey, side: .CLIENT) + guard let staticSharedSecret = sodium.keyExchange.sessionKeyPair(publicKey: clientKeypair.publicKey.bytes, secretKey: clientKeypair.privateKey.bytes, otherPublicKey: idPublicKey.bytes, side: .CLIENT) else { print("ntorClientHandshake: Unable to derive static shared secret.") return nil } - guard !sodium.utils.equals(staticSharedSecret.tx, zeroData) + guard !sodium.utils.equals(staticSharedSecret.tx, zeroData.bytes) else { print("ntorClientHandshake: static shared secret is zero.") return nil } - guard !sodium.utils.equals(ephemeralSharedSecret.tx, zeroData) + guard !sodium.utils.equals(ephemeralSharedSecret.tx, zeroData.bytes) else { print("ntorClientHandshake: ephemeral shared secret is zero.") return nil } - secretInput.append(ephemeralSharedSecret.tx) - secretInput.append(staticSharedSecret.tx) + secretInput.append(Data(bytes: ephemeralSharedSecret.tx)) + secretInput.append(Data(bytes: staticSharedSecret.tx)) guard let (keySeed, auth) = ntorCommon(secretInput: secretInput, nodeID: nodeID, bPublicKey: idPublicKey, xPublicKey: clientKeypair.publicKey, yPublicKey: serverPublicKey) else @@ -763,7 +897,7 @@ func newKeypair() -> Keypair? return nil } - if let result = representative(privateKey: sodiumKeypair.secretKey) + if let result = representative(privateKey: Data(bytes: sodiumKeypair.secretKey)) { maybeKeypair = sodiumKeypair elligatorRepresentative = result.representative @@ -780,7 +914,7 @@ func newKeypair() -> Keypair? if let actualRepresentative = elligatorRepresentative?.bytes, let newKeypair = maybeKeypair { - let wispKeypair = Keypair(publicKey: newKeypair.publicKey, privateKey: newKeypair.secretKey, representative: Data(actualRepresentative)) + let wispKeypair = Keypair(publicKey: Data(bytes: newKeypair.publicKey) , privateKey: Data(bytes: newKeypair.secretKey), representative: Data(actualRepresentative)) return wispKeypair } else diff --git a/Sources/Wisp/WispTCPConnection.swift b/Sources/Wisp/WispTCPConnection.swift index 3773900..0ce331c 100644 --- a/Sources/Wisp/WispTCPConnection.swift +++ b/Sources/Wisp/WispTCPConnection.swift @@ -12,125 +12,65 @@ // implementation to other obfs4 implementations except when required for over-the-wire compatibility. import Foundation -import NetworkExtension import Transport let certKey = "cert" let iatKey = "iatMode" -public func createWispTCPConnection(provider: PacketTunnelProvider, to: NWEndpoint, cert: String, iatMode: Bool) -> WispTCPConnection? -{ - return WispTCPConnection(provider: provider, to: to, cert: cert, iatMode: iatMode) -} -public func createWispTCPConnection(connection: TCPConnection, cert: String, iatMode: Bool) -> WispTCPConnection? +public func createWispTCPConnection(connection: Connection, + host: NWEndpoint.Host, + port: NWEndpoint.Port, + using parameters: NWParameters, + cert: String, + iatMode: Bool) -> WispTCPConnection? { - return WispTCPConnection(connection: connection, cert: cert, iatMode: iatMode) + return WispTCPConnection(connection: connection, host: host, port: port, using: parameters, cert: cert, iatMode: iatMode) } -public class WispTCPConnection: TCPConnection +public class WispTCPConnection: NWConnection { - var network: TCPConnection + /// Use this to create connections + var connectionFactory: NetworkConnectionFactory? + var wispConnection: Connection + + //var network: Connection var writeClosed = false var wisp: WispProtocol var handshakeDone = false - var stateCallback: ((NWTCPConnectionState, Error?) -> Void)? - - private var _isViable: Bool - private var _error: Error? - private var _state: NWTCPConnectionState - { - didSet - { - NotificationCenter.default.post(name: .wispConnectionState, object: _state) - guard let callback = stateCallback - else { return } - - callback(_state, nil) - } - } - - public var state: NWTCPConnectionState - { - get { - return _state - } - } + //public var state: NWConnectionState public var isViable: Bool + public var error: Error? + + public var endpoint: NWEndpoint? + public var remoteAddress: NWEndpoint? + public var localAddress: NWEndpoint? + //public var connectedPath: NWPath? + public var txtRecord: Data? + public var hasBetterPath = false + + public init?(connection: Connection, + host: NWEndpoint.Host, + port: NWEndpoint.Port, + using parameters: NWParameters, + cert: String, + iatMode: Bool) { - get { - return _isViable - } - } - - public var error: Error? { - get { - return _error - } - } - - public var endpoint: NWEndpoint { - get { - return network.endpoint - } - } - - public var remoteAddress: NWEndpoint? { - get { - return network.remoteAddress - } - } - - public var localAddress: NWEndpoint? { - get { - return network.localAddress - } - } - - public var connectedPath: NWPath? { - get { - return network.connectedPath - } - } - - public var txtRecord: Data? { - get { - return network.txtRecord - } - } - - public var hasBetterPath: Bool { - get { - return network.hasBetterPath - } - } - - public convenience init?(provider: PacketTunnelProvider, to: NWEndpoint, cert: String, iatMode: Bool) - { - guard let connection = provider.createTCPConnectionThroughTunnel(to: to, enableTLS: true, tlsParameters: nil, delegate: nil) - else - { - return nil - } - - self.init(connection: connection, cert: cert, iatMode: iatMode) - } - - public init?(connection: TCPConnection, cert: String, iatMode: Bool) - { - network = connection - _isViable = false - _state = .connecting +// network = connection + wispConnection = connection + isViable = false +// _state = .connecting + - guard let newWisp = WispProtocol(connection: network, cert: cert, iatMode: iatMode) + guard let newWisp = WispProtocol(connection: connection, cert: cert, iatMode: iatMode) else { return nil } wisp = newWisp - + super.init(host: host, port: port, using: parameters) wisp.connectWithHandshake(certString: cert, sessionKey: wisp.sessionKey) { (maybeError) in @@ -139,22 +79,22 @@ public class WispTCPConnection: TCPConnection { print("Error connecting with handshake: \(error)") self.handshakeDone = false - self._error = error - self._isViable = false - self._state = .invalid + self.error = error + self.isViable = false +// self._state = .invalid } else { self.handshakeDone = true - self._isViable = true - self._state = .connected + self.isViable = true +// self._state = .connected } } } - - public func observeState(_ callback: @escaping (NWTCPConnectionState, Error?) -> Void) { - self.stateCallback=callback - } +// +// public func observeState(_ callback: @escaping (NWTCPConnectionState, Error?) -> Void) { +// self.stateCallback=callback +// } public func readMinimumLength(_ minimum: Int, maximumLength maximum: Int, completionHandler completion: @escaping (Data?, Error?) -> Void) { @@ -194,28 +134,38 @@ public class WispTCPConnection: TCPConnection completion(nil) return } - - network.write(frame) + let context = NWConnection.ContentContext() + let sendCompletion = NWConnection.SendCompletion(completion: { (error) in completion(error) - } - } - - public func writeClose() - { - _state = .disconnected - _isViable = false - network.writeClose() + }) + + wispConnection.send(content: frame, contentContext: context, isComplete: true, completion: sendCompletion) +// +// network.write(frame, timeout: 0) +// { +// (error) in +// +// completion(error) +// } } - public func cancel() - { - _state = .cancelled - _isViable = false - network.cancel() - } +// public func writeClose() +// { +// _state = .disconnected +// _isViable = false +// network.writeClose() +// } +// +// public func cancel() +// { +// _state = .cancelled +// _isViable = false +// network.cancel() +// } + } public extension Notification.Name diff --git a/Tests/WispTests/WispTests.swift b/Tests/WispTests/WispTests.swift index 1a72fb1..ce5ebde 100644 --- a/Tests/WispTests/WispTests.swift +++ b/Tests/WispTests/WispTests.swift @@ -11,7 +11,6 @@ import XCTest import Sodium import Elligator import NetworkExtension -import ShapeshifterTesting import Transport @testable import Wisp @@ -19,7 +18,11 @@ import Transport class Shapeshifter_WispTests: XCTestCase { let certString = "60RNHBMRrf+aOSPzSj8bD4ASGyyPl0mkaOUAQsAYljSkFB0G8B8m9fGvGJCpOxwoXS1baA" + let ipAddressString = "166.78.129.122" + let portString = "1234" let endpoint = NWHostEndpoint(hostname: "198.211.106.85", port: "1234") + + //static let fakeTCPConnection: FakeTCPConnection = createFakeTCPConnection(to: endpoint) let secretKeyMaterial = Data(repeating: 0x0A, count: keyMaterialLength) static let publicKey = Data(bytes: [139, 210, 37, 89, 10, 47, 113, 85, 13, 53, 118, 181, 28, 8, 202, 146, 220, 206, 224, 143, 24, 159, 235, 136, 173, 194, 120, 171, 201, 54, 238, 76]) @@ -153,50 +156,114 @@ class Shapeshifter_WispTests: XCTestCase func testFakeTCPConnection() { - let maybeFakeTCPConnection: TCPConnection? = createFakeTCPConnection(to: endpoint) - XCTAssertNotNil(maybeFakeTCPConnection) - guard let fakeTCPConnection = maybeFakeTCPConnection else { + guard let portUInt = UInt16(portString), let port = NWEndpoint.Port(rawValue: portUInt) + else + { + print("Unable to resolve port for test") + XCTFail() + return + } + guard let ipv4Address = IPv4Address(ipAddressString) + else + { + print("Unable to resolve ipv4 address for test") + XCTFail() return } + let host = NWEndpoint.Host.ipv4(ipv4Address) + let parameters = NWParameters() + let connectionFactory = NetworkConnectionFactory(host: host, port: port) + var maybeConnection = connectionFactory.connect(parameters) + + XCTAssertNotNil(maybeConnection) + let connected = expectation(description: "Connected to server.") - let wrote = expectation(description: "Wrote data to server.") + //let wrote = expectation(description: "Wrote data to server.") - fakeTCPConnection.observeState { - (state, maybeConnectError) in + maybeConnection?.stateUpdateHandler = + { + (newState) in + + + connected.fulfill() + print("CURRENT STATE = \(newState))") - XCTAssertNil(maybeConnectError) - guard maybeConnectError == nil else { - return - } - switch state { - case .connected: - connected.fulfill() + // guard let startCompletion = pendingStartCompletion + // else + // { + // print("pendingStartCompletion is nil?") + // return + // } + + switch newState + { + case .ready: + // Start reading messages from the tunnel connection. + //self.tunnelConnection?.startHandlingPackets() - fakeTCPConnection.write(Data(repeating: 0x0A, count: 1)) - { - (maybeWriteError) in - - XCTAssertNil(maybeWriteError) - - guard maybeWriteError == nil else - { - print("\nTest - FakeTCPConnection write failure:") - if let error = maybeWriteError { - print(error.localizedDescription) - } - - return - } - - wrote.fulfill() - } - default: - return + // Open the logical flow of packets through the tunnel. + //let newConnection = ClientTunnelConnection(clientPacketFlow: self.packetFlow) + print("\nšŸš€ open() called on tunnel connection šŸš€\n") + connected.fulfill() + //self.tunnelConnection = newConnection + //startCompletion(nil) + + case .cancelled: + connected.fulfill() + print("\nšŸ™…ā€ā™€ļø Connection Canceled šŸ™…ā€ā™€ļø\n") + // self.connection = nil + // self.tunnelDidClose() + // startCompletion(SimpleTunnelError.cancelled) + + case .failed(let error): + print("\nšŸ’šŸ’Ø Connection Failed šŸ’šŸ’Ø\n") + connected.fulfill() + // self.closeTunnelWithError(error) + // startCompletion(error) + + default: + connected.fulfill() + print("\nšŸ¤·ā€ā™€ļø Unexpected State: \(newState)) šŸ¤·ā€ā™€ļø\n") } } +// fakeTCPConnection.observeState { +// (state, maybeConnectError) in +// +// XCTAssertNil(maybeConnectError) +// guard maybeConnectError == nil else { +// return +// } +// +// switch state { +// case .connected: +// connected.fulfill() +// +// fakeTCPConnection.write(Data(repeating: 0x0A, count: 1)) +// { +// (maybeWriteError) in +// +// XCTAssertNil(maybeWriteError) +// +// guard maybeWriteError == nil else +// { +// print("\nTest - FakeTCPConnection write failure:") +// if let error = maybeWriteError { +// print(error.localizedDescription) +// } +// +// return +// } +// +// wrote.fulfill() +// } +// default: +// return +// } +// } +// waitForExpectations(timeout: maxWaitSeconds) { (maybeError) in if let error = maybeError @@ -208,19 +275,19 @@ class Shapeshifter_WispTests: XCTestCase func testWispTCPConnection() { - let promise = expectation(description: "Connection state changed.") - let maybeConnection = createFakeTCPConnection(to: endpoint) - XCTAssertNotNil(maybeConnection) - guard let connection = maybeConnection else { - return - } - connection.observeState - { - (connectionState, maybeError) in - - let maybeWtcpConnection = createWispTCPConnection(connection: connection, cert: self.certString, iatMode: false) - XCTAssertNotNil(maybeWtcpConnection) - } +// let promise = expectation(description: "Connection state changed.") +// let maybeConnection = createFakeTCPConnection(to: endpoint) +// XCTAssertNotNil(maybeConnection) +// guard let connection = maybeConnection else { +// return +// } +// connection.observeState +// { +// (connectionState, maybeError) in +// +// let maybeWtcpConnection = createWispTCPConnection(connection: connection, cert: self.certString, iatMode: false) +// XCTAssertNotNil(maybeWtcpConnection) +// } } // func testConnectWithHandshake()