Refactor project, add loading/editing/saving notes, add client/server basic logic
This commit is contained in:
@@ -0,0 +1,37 @@
|
||||
import MultipeerConnectivity
|
||||
import Foundation
|
||||
|
||||
@Observable
|
||||
final class NoteEditingSessionServer: NSObject {
|
||||
private let session: MCSession
|
||||
private let browser: MCNearbyServiceBrowser
|
||||
|
||||
init(username: String) {
|
||||
let peer = MCPeerID(displayName: username)
|
||||
browser = .init(peer: peer, serviceType: "peered")
|
||||
session = .init(peer: peer)
|
||||
super.init()
|
||||
browser.delegate = self
|
||||
}
|
||||
|
||||
func startServer() {
|
||||
browser.startBrowsingForPeers()
|
||||
}
|
||||
|
||||
func stopServer() {
|
||||
browser.stopBrowsingForPeers()
|
||||
}
|
||||
}
|
||||
|
||||
extension NoteEditingSessionServer: MCNearbyServiceBrowserDelegate {
|
||||
func browser(
|
||||
_ browser: MCNearbyServiceBrowser,
|
||||
foundPeer peerID: MCPeerID,
|
||||
withDiscoveryInfo info: [String : String]?
|
||||
) {
|
||||
browser.invitePeer(peerID, to: session, withContext: nil, timeout: 30)
|
||||
print("seeing peer \(peerID.displayName)")
|
||||
}
|
||||
|
||||
func browser(_ browser: MCNearbyServiceBrowser, lostPeer peerID: MCPeerID) {}
|
||||
}
|
||||
Reference in New Issue
Block a user