-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathCommunicator.podspec
62 lines (47 loc) · 2.71 KB
/
Communicator.podspec
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
Pod::Spec.new do |s|
s.name = 'Communicator'
s.version = '4.1.1'
s.summary = 'Communication between iOS and watchOS apps just got a whole lot better.'
s.description = <<-DESC
Sending messages and data between watchOS and iOS apps
is possible thanks to Apple's work on `WatchConnectivity`,
but there are a lot of delegate callbacks to work with,
some of the API calls are similar, and it's not really
clear which is needed for what purpose.
`Communicator` means you don't have to spend any time writing a cross-platform wrapper around `WatchConnectivity` and is extremely easy to use.
Each app gets its own shared `Communicator` object to use which handles all the underlying session stuff:
```swift
Communicator.shared
```
Usage between the two platforms is identical, so you can
use it in a shared framework with few workarounds.
Here's how you send a simple message with Communicator.
```swift
let message = ImmediateMessage(identifier: "1234", content: ["messageKey" : "This is some message content!"])
try? Communicator.shared.send(immediateMessage: message)
```
This will try to send a message to the counterpart immediately. If the underlying session is not active, the `try` will fail and Communicator will `throw` an error you can catch if you want.
On the other device you register as an observer for new messages:
```swift
Communicator.shared.immediateMessageReceivedObservers.add { message in
if message.identifier == "1234" {
print("Message received: \(message.content)")
}
}
```
The great thing about using this style of observing means that you can observe these messages from anywhere in your app and filter out the ones you don't care about.
`Communicator` can also transfer `Blob`s and sync `Context`s.
`Blob`s are perfect for sending larger amounts of data (`WatchConnectivity` will reject large data in other types of messages), and will continue to transfer even if your app
is terminated during transfer.
You can use a `Context` to keep things in sync between devices, which makes it perfect for preferences. `Context`s are not suitable for messaging or sending large data.
DESC
s.homepage = 'https://github.com/KaneCheshire/Communicator'
s.license = { :type => 'MIT', :file => 'LICENSE' }
s.author = { 'Kane Cheshire' => '@kanecheshire' }
s.source = { :git => 'https://github.com/KaneCheshire/Communicator.git', :tag => s.version.to_s }
s.social_media_url = 'https://twitter.com/kanecheshire'
s.platforms = { :ios => "10.0", :watchos => "3.0" }
s.source_files = 'Sources/**/*'
s.frameworks = 'WatchConnectivity'
s.swift_version = '5.0'
end