Beispiel #1
0
func handleRegist(client *NetCore.Client, msg *NetCore.NetMsg) {
	stype := binary.LittleEndian.Uint32(msg.Buf)
	NetCore.MarkServer(client, stype)
	addServerToMap(client)
	client.AddCloseCB("removeServer", removeServerFromMap)

	Logger.Info(LogConf.CourierServerJob, LogConf.SERVER, "Server Regist client idx: %d buf len: %d %d", client.GetIdx(), len(msg.Buf), stype)

	binary.LittleEndian.PutUint32(msg.Buf[0:4], NetConf.Courier)
	client.SendMsg(msg)
}
Beispiel #2
0
//要把房间user列表回复给它
func handleClientEnterRoom(client *NetCore.Client, msg *NetCore.NetMsg) bool {
	var (
		req  EnterRoomReq
		rsp  = &EnterRoomRsp{Ret: 0}
		room *Room
		ok   bool
	)
	Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 000")

	enterRoomRsp := func() {
		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom aaa %d", rsp.Ret)
		if rsp.Ret == 0 {
			rsp.Guests = make([]NetCore.ClientIDType, len(room.Guests)+1)
			rsp.Guests[0] = NetCore.ClientIDType(client.Id)
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom bbb")

			n := 1
			for id, _ := range room.Guests {
				Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ccc %d %d", id, n)
				rsp.Guests[n] = NetCore.ClientIDType(id)
				n = n + 1
				Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ddd %d %d", id, len(rsp.Guests))
			}
		}
		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom ddd")
		if buf, err := json.Marshal(rsp); err == nil {
			rspMsg := &NetCore.NetMsg{
				Cmd: msg.Cmd,
				Buf: buf,
			}
			client.SendMsg(rspMsg)

			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom client Idx: %d id: %d RoomId: %d", client.Idx, client.Id, req.RoomId)
		} else {
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom xxxx")
		}
	}

	if err := json.Unmarshal([]byte(msg.Buf), &req); err != nil {
		rsp.Ret = ErrConf.INVALID_JSON
		enterRoomRsp()
		return false
	}

	if room, ok = rooms[req.RoomId]; ok {
		if _, ok2 := room.Guests[client.Id]; ok2 {
			rsp.Ret = ErrConf.ID_HAS_BEEN_IN_ROOM
			enterRoomRsp()
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 111")
			return true
		}

		if req.Passwd != room.Passwd {
			rsp.Ret = ErrConf.ERROR_PASSWD_FOR_ROOM
			enterRoomRsp()
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 111")
			return true
		}

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 222")
		notify := &EnterRoomNotify{
			Id: NetCore.ClientIDType(client.Id),
		}
		notifyMsg := &NetCore.NetMsg{
			Cmd: MsgConf.ClientEnterRoomNotify,
		}
		if buf, err := json.Marshal(notify); err == nil {
			notifyMsg.Buf = buf
		} else {
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 333")
			return false
		}

		for _, v := range room.Guests {
			v.SendMsg(notifyMsg)
		}

		enterRoomRsp()

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 444")
		room.Guests[client.Id] = client
		idRoomMap[client.Id] = room

	} else {
		room = &Room{
			Id:     req.RoomId,
			Passwd: req.Passwd,
			Guests: make(map[NetCore.ClientIDType]*NetCore.Client),
		}

		enterRoomRsp()

		room.Guests[client.Id] = client
		idRoomMap[client.Id] = room

		rooms[req.RoomId] = room

		Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 555")
	}

	client.AddCloseCB("leaveRoom", func(c *NetCore.Client) {
		//Logger.Info(LogConf.WorkerClientJob, client.Idx, "handleClientEnterRoom 666")
		var tmproom *Room
		if tmproom, ok = idRoomMap[c.Id]; ok {
			delete(tmproom.Guests, c.Id)

			leaveMsg := &NetCore.NetMsg{
				Cmd: MsgConf.ClientLeaveRoomNotify,
			}
			notify := &LeaveRoomNotify{
				Id: NetCore.ClientIDType(c.Id),
			}

			if buf, err := json.Marshal(notify); err == nil {
				leaveMsg.Buf = buf
			} else {
				return
			}

			if len(tmproom.Guests) > 0 {
				for _, v := range tmproom.Guests {
					v.SendMsg(leaveMsg)
				}
			} else {
				delete(rooms, tmproom.Id)
			}
			Logger.Info(LogConf.WorkerClientJob, client.Idx, "client leave room %d", client.Id)
		}
	})

	return true
}