PhonecallController
struct PhonecallController : APIRouteCollection
The collection of /api/v3/phone/*
route endpoints and handler functions related to phone call management..
-
Declaration
Swift
static let logger: Logger
-
Declaration
Swift
var encoder: JSONEncoder { get }
-
Required. Registers routes to the incoming router.
Declaration
Swift
func registerRoutes(_ app: Application) throws
-
initiateCallHandler(_:
Asynchronous) POST /api/v3/phone/initiate/:call_id/to/:user_id
The requester is trying to start a phone call to the given user. Notify the target user of the incoming phone call via their notification socket and provide the IP address(es) of the caller. The callee is then expected to open a socket to the caller for moving audio.
Throws
BadRequest if malformed. notFound if user can’t be notified of call.Declaration
Swift
func initiateCallHandler(_ req: Request) async throws -> HTTPStatus
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
userID
The userID of the user to call.
Return Value
200 OK on success
-
shouldCreatePhoneSocket(_:
Asynchronous) GET /api/v3/phone/socket/initiate/:call_id/to/:user_id
The requester is trying to start a phone call to the given user. Notify the target user of the incoming phone call via their notification socket and save the caller socket. The callee should open a phone socket to the server using
answerPhoneSocket
at which point the server will start forwarding websocket packets between the caller and callee sockets.This is the server-mediated phone call path.
Throws
BadRequest if malformed. notFound if user can’t be notified of call.Declaration
Swift
func shouldCreatePhoneSocket(_ req: Request) async throws -> HTTPHeaders?
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
userID
The userID of the user to call.
Return Value
200 OK on success
-
createPhoneSocket(_:
Asynchronous_: ) WS /api/v3/phone/socket/initiate/:call_id/to/:user_id
The requester is trying to start a phone call to the given user. Notify the target user of the incoming phone call via their notification socket and save the caller socket. The callee should open a phone socket to the server using
answerPhoneSocket
at which point the server will start forwarding websocket packets between the caller and callee sockets.This is the server-mediated phone call path.
Throws
BadRequest if malformed. notFound if user can’t be notified of call.Declaration
Swift
func createPhoneSocket(_ req: Request, _ ws: WebSocket) async
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
userID
The userID of the user to call.
Return Value
200 OK on success
-
shouldAnswerPhoneSocket(_:
Asynchronous) GET /api/v3/phone/socket/answer/:call_id
The requester is trying to answer an incoming phone call. This is the server-mediated phone call path.
Throws
BadRequest if malformed. NotFound if callID doesn’t exist.Declaration
Swift
func shouldAnswerPhoneSocket(_ req: Request) async throws -> HTTPHeaders?
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
Return Value
200 OK on success
-
answerPhoneSocket(_:
Asynchronous_: ) WS /api/v3/phone/socket/answer/:call_id
The requester is trying to answer an incoming phone call. This is the server-mediated phone call path.
Throws
BadRequest if malformed. NotFound if callID doesn’t exist.Declaration
Swift
func answerPhoneSocket(_ req: Request, _ ws: WebSocket) async
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
Return Value
200 OK on success
-
answerPhoneCall(_:
Asynchronous) POST /api/v3/phone/answer/:call_ID
The answering party should call this when they answer the incoming call; this notifies other devices where that user is logged in to stop ringing. Only necessary for the direct-socket path.
Throws
BadRequest if malformed. NotFound if callID doesn’t exist.Declaration
Swift
func answerPhoneCall(_ req: Request) async throws -> HTTPStatus
Parameters
callID
in URL path. UUID for this call.
Return Value
200 OK on success
-
declinePhoneCall(_:
Asynchronous) POST /api/v3/phone/decline/:call_ID
Either party may call this to end a server-mediated phone call. But, if you have an open socket for the call, it’s easier to just close the socket–the server will detect this and close the other socket and clean up. Requester must be a party to the call.
This route is for when a phone call needs to be ended and the client does not have a socket connection. May be used for both direct and server-mediated calls.
Throws
BadRequest if malformed. NotFound if callID doesn’t exist.Declaration
Swift
func declinePhoneCall(_ req: Request) async throws -> HTTPStatus
Parameters
callID
in URL path. Caller-provided UUID for this call. Callee needs to send this to caller to verify the socket is for the correct call.
Return Value
200 OK on success
-
Declaration
Swift
func endPhoneCall(callID: UUID)