| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | 
							- package command
 
- import (
 
- 	"io"
 
- 	"time"
 
- 	v2net "github.com/v2ray/v2ray-core/common/net"
 
- 	"github.com/v2ray/v2ray-core/common/serial"
 
- 	"github.com/v2ray/v2ray-core/common/uuid"
 
- 	"github.com/v2ray/v2ray-core/transport"
 
- )
 
- func init() {
 
- 	RegisterResponseCommand(1, func() Command { return new(SwitchAccount) })
 
- }
 
- // Structure
 
- // 1 byte: host len N
 
- // N bytes: host
 
- // 2 bytes: port
 
- // 16 bytes: uuid
 
- // 2 bytes: alterid
 
- // 8 bytes: time
 
- type SwitchAccount struct {
 
- 	Host       v2net.Address
 
- 	Port       v2net.Port
 
- 	ID         *uuid.UUID
 
- 	AlterIds   serial.Uint16Literal
 
- 	ValidUntil time.Time
 
- }
 
- func (this *SwitchAccount) Marshal(writer io.Writer) (int, error) {
 
- 	outBytes := 0
 
- 	hostStr := ""
 
- 	if this.Host != nil {
 
- 		hostStr = this.Host.String()
 
- 	}
 
- 	writer.Write([]byte{byte(len(hostStr))})
 
- 	outBytes++
 
- 	if len(hostStr) > 0 {
 
- 		writer.Write([]byte(hostStr))
 
- 		outBytes += len(hostStr)
 
- 	}
 
- 	writer.Write(this.Port.Bytes())
 
- 	outBytes += 2
 
- 	idBytes := this.ID.Bytes()
 
- 	writer.Write(idBytes)
 
- 	outBytes += len(idBytes)
 
- 	writer.Write(this.AlterIds.Bytes())
 
- 	outBytes += 2
 
- 	timestamp := this.ValidUntil.Unix()
 
- 	timeBytes := serial.Int64Literal(timestamp).Bytes()
 
- 	writer.Write(timeBytes)
 
- 	outBytes += len(timeBytes)
 
- 	return outBytes, nil
 
- }
 
- func (this *SwitchAccount) Unmarshal(data []byte) error {
 
- 	lenHost := int(data[0])
 
- 	if len(data) < lenHost+1 {
 
- 		return transport.CorruptedPacket
 
- 	}
 
- 	this.Host = v2net.ParseAddress(string(data[1 : 1+lenHost]))
 
- 	portStart := 1 + lenHost
 
- 	if len(data) < portStart+2 {
 
- 		return transport.CorruptedPacket
 
- 	}
 
- 	this.Port = v2net.PortFromBytes(data[portStart : portStart+2])
 
- 	idStart := portStart + 2
 
- 	if len(data) < idStart+16 {
 
- 		return transport.CorruptedPacket
 
- 	}
 
- 	this.ID, _ = uuid.ParseBytes(data[idStart : idStart+16])
 
- 	alterIdStart := idStart + 16
 
- 	if len(data) < alterIdStart+2 {
 
- 		return transport.CorruptedPacket
 
- 	}
 
- 	this.AlterIds = serial.ParseUint16(data[alterIdStart : alterIdStart+2])
 
- 	timeStart := alterIdStart + 2
 
- 	if len(data) < timeStart+8 {
 
- 		return transport.CorruptedPacket
 
- 	}
 
- 	this.ValidUntil = time.Unix(serial.BytesLiteral(data[timeStart:timeStart+8]).Int64Value(), 0)
 
- 	return nil
 
- }
 
 
  |