Skip to content

Commit

Permalink
Make web socket async
Browse files Browse the repository at this point in the history
  • Loading branch information
enums committed Jan 2, 2022
1 parent 1c29ffe commit 5f3a1c7
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 17 deletions.
4 changes: 2 additions & 2 deletions Sources/Heze/Socket/HezeSocketClient.swift
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ open class HezeSocketClient: HezeSocketHandler {
return socket?.isConnected ?? false
}

open override func receiveBytes(_ bytes: [UInt8]) -> HezeResponsable? {
return nil
open override func receiveBytes(_ bytes: [UInt8], completion: @escaping (HezeResponsable?) -> Void) {
completion(nil)
}

open func close() {
Expand Down
52 changes: 39 additions & 13 deletions Sources/Heze/Socket/HezeSocketHandler.swift
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ open class HezeSocketHandler: HezeHandler, WebSocketSessionHandler {
public var socket: WebSocket? = nil
public var remoteHost: String?
public var remotePort: UInt16?
public var queue = DispatchQueue(label: "heze.socket.handler", attributes: .concurrent)
public var buffer = [UInt8]()

open var socketProtocol: String? {
Expand Down Expand Up @@ -68,35 +69,52 @@ open class HezeSocketHandler: HezeHandler, WebSocketSessionHandler {
guard let self = self else {
return
}
guard let bytes = bytes else {

switch opcodeType {
case .binary, .text, .continuation:
guard let bytes = bytes else {
socket.close()
self.closed()
return
}
self.queue.async { [weak self] in
guard let self = self else {
return
}
self.handleBytes(bytes, opcodeType: opcodeType, final: final, socket: socket) { res in
if let bytes = res?.toBytes() {
self.sendBytes(bytes) { }
}
}
}
case .ping:
self.ping()
case .pong:
self.pong()
case .close, .invalid:
socket.close()
self.closed()
return
}
if let bytes = self.handleBytes(bytes, opcodeType: opcodeType, final: final, socket: socket)?.toBytes() {
self.sendBytes(bytes) {
self.handleSession(request: req, socket: socket)
}
} else {
self.handleSession(request: req, socket: socket)
}

self.handleSession(request: req, socket: socket)
}
}

open func handleBytes(_ bytes: [UInt8], opcodeType: WebSocket.OpcodeType, final: Bool, socket: WebSocket) -> HezeResponsable? {
open func handleBytes(_ bytes: [UInt8], opcodeType: WebSocket.OpcodeType, final: Bool, socket: WebSocket, completion: @escaping (HezeResponsable?) -> Void) {
buffer.append(contentsOf: bytes)
if final {
defer {
buffer.removeAll(keepingCapacity: false)
}
return receiveBytes(buffer)
receiveBytes(buffer, completion: completion)
} else {
return nil
completion(nil)
}
}

open func receiveBytes(_ bytes: [UInt8]) -> HezeResponsable? {
return nil
open func receiveBytes(_ bytes: [UInt8], completion: @escaping (HezeResponsable?) -> Void) {
completion(nil)
}

open func sendMessage(_ msg: String, completion: @escaping () -> Void) {
Expand All @@ -114,4 +132,12 @@ open class HezeSocketHandler: HezeHandler, WebSocketSessionHandler {
open func closed() {

}

open func ping() {

}

open func pong() {

}
}
4 changes: 2 additions & 2 deletions Sources/HezeDemo/Socket/RepeatSocketClient.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ var RepeatSocketClientStorage: HezeSocketHandler?

class RepeatSocketClient: HezeSocketClient {

override func receiveBytes(_ bytes: [UInt8]) -> HezeResponsable? {
return bytes
open override func receiveBytes(_ bytes: [UInt8], completion: @escaping (HezeResponsable?) -> Void) {
completion(bytes)
}

override class func create(context: HezeContext) -> HezeSocketHandler? {
Expand Down

0 comments on commit 5f3a1c7

Please sign in to comment.