nex-protocols-common-go/authentication/request_ticket.go

49 lines
1.6 KiB
Go

package authentication
import (
nex "github.com/PretendoNetwork/nex-go"
nexproto "github.com/PretendoNetwork/nex-protocols-go"
)
func requestTicket(err error, client *nex.Client, callID uint32, userPID uint32, targetPID uint32) {
encryptedTicket, errorCode := generateTicket(userPID, targetPID)
rmcResponse := nex.NewRMCResponse(nexproto.AuthenticationProtocolID, callID)
// TODO:
// If the source or target pid is invalid, the %retval% field is set to Core::AccessDenied and the ticket is empty.
if errorCode != 0 {
rmcResponse.SetError(errorCode)
} else {
rmcResponseStream := nex.NewStreamOut(commonAuthenticationProtocol.server)
rmcResponseStream.WriteResult(nex.NewResultSuccess(nex.Errors.Core.Unknown))
rmcResponseStream.WriteBuffer(encryptedTicket)
rmcResponseBody := rmcResponseStream.Bytes()
rmcResponse.SetSuccess(nexproto.AuthenticationMethodRequestTicket, rmcResponseBody)
}
rmcResponseBytes := rmcResponse.Bytes()
var responsePacket nex.PacketInterface
if commonAuthenticationProtocol.server.PrudpVersion() == 0 {
responsePacket, _ = nex.NewPacketV0(client, nil)
responsePacket.SetVersion(0)
} else {
responsePacket, _ = nex.NewPacketV1(client, nil)
responsePacket.SetVersion(1)
}
responsePacket.SetSource(0xA1)
responsePacket.SetDestination(0xAF)
responsePacket.SetType(nex.DataPacket)
responsePacket.SetPayload(rmcResponseBytes)
responsePacket.AddFlag(nex.FlagNeedsAck)
responsePacket.AddFlag(nex.FlagReliable)
commonAuthenticationProtocol.server.Send(responsePacket)
}