Ejemplo n.º 1
0
 def send_receive(self, data):
     """
     Envia os dados contidos em data para a socket da ligação, e retorna a
     resposta recebida pela mesma socket.
     """
     try:
         data_obj = pickle.dumps(data, -1)
         self.socket.sendall(struct.pack("!i", len(data_obj)))
         self.socket.sendall(data_obj)
         ret_size = struct.unpack("!i", receive_all(self.socket, 4, 4))
         return pickle.loads(receive_all(self.socket, ret_size))
     except s.error:
         print "Erro ao enviar/receber dados, o canal ou outra parte morreu"
         self.close()
Ejemplo n.º 2
0
    def send_receive(self, data):
        """
            It sends the data through the connection socket, and returns 
            the answer received by the endpoint.
        """
        mens = p.dumps(data, -1)
        size_mens = struct.pack("!i", len(mens))
        self._sock.sendall(size_mens)
        self._sock.sendall(mens)

        size_bytes = su.receive_all(self._sock, 4)
        size = struct.unpack("!i", size_bytes)[0]

        msg = su.receive_all(self._sock, size)
        obj = p.loads(msg)

        return list(obj)
Ejemplo n.º 3
0
 def send_receive(self, data):
     """
     Envia os dados contidos em data para a socket da ligação, e retorna a
     resposta recebida pela mesma socket.
     """
     self.client_sock.sendall(pickle.dumps(data))
     temp = s.receive_all(self.client_sock, 1024)
     return pickle.loads(temp)
Ejemplo n.º 4
0
def client(host, port):
    cont = True
    while cont:
        sock = sock_utils.create_tcp_client_socket(host, port)
        send_msg = raw_input("Qual a mensagem")
        if send_msg == "EXIT":
            cont = False
        else:
            sock.sendall(send_msg)
        resposta = sock_utils.receive_all(sock, 5000)
        print 'Recebi {}'.format(resposta)
Ejemplo n.º 5
0
def cliente():
	try:
		IP_Server = sys.argv[1]
		PORT = int(sys.argv[2])
		IP_Client = sys.argv[3]
	except:
		raise ValueError("Argumentos inválidos!")

	Cliente = net_client.server(IP_Server, PORT)

	while True:
		msg = raw_input("comando > ")
                if msg == "EXIT":
			exit()
		else:
			msg = msg.split(" ")
			lista = verify(msg, IP_Client)
			if lista != []:
                                
				msg_bytes = pickle.dumps(lista, -2)
				send_bytes =  struct.pack("!i",len(msg_bytes))
				

				Cliente.connect()
				
                                conn_sock.sendall(send_bytes)
                                conn_sock.sendall(msg_bytes)

                                resp_bytes = sock_utils.receive_all(Cliente, 4)
                                resp = sock_utils.receive_all(Cliente, int(struct.unpack("!i",resp_bytes)[0]))
                                resposta_final = pickle.loads(resp)


				Cliente.close()

				print 'Recebi: %s' % resposta:final
			else:
				print "UNKNOWN COMMAND"
Ejemplo n.º 6
0
    def send_receive(self, data):
        """
        Envia os dados contidos em data para a socket da ligação, e retorna a
        resposta recebida pela mesma socket.
        """
        try:

            self.socket.sendall(data)
            msg = receive_all(self.socket, 1024)

            return msg
        except:
            print "erro no send receive"
            self.close()
Ejemplo n.º 7
0
 def handle(self):
     """
     Handling das mensagens.
     """
     global skeleton
     continue_flag = True
     global server_up
     while continue_flag and server_up:
         r, w, x = sel.select([self.request], [], [])
         for sock in r:
             size = sock_utils.receive_all(sock, 4, 4)
             if size:
                 skeleton.clear_expired_locks()
                 skeleton.clear_maxed_locks()
                 rcv_message_size = struct.unpack("!i", size)[0]
                 rcv_message = pickle.loads(
                     sock_utils.receive_all(sock, rcv_message_size))
                 self.client_message_handler(sock, rcv_message)
             else:
                 addr, port = sock.getpeername()
                 print "Cliente com IP {} e porto {} fechou a ligação".format(
                     addr, port)
                 sock.close()
                 continue_flag = False
Ejemplo n.º 8
0
class server:
    """
    Classe para abstrair uma ligação a um servidor TCP. Implementa métodos
    para estabelecer a ligação, para envio de um comando e receção da resposta,
    e para terminar a ligação
    """
    def __init__(self, address, port):
        """
        Inicializa a classe com parâmetros para funcionamento futuro.
        """
        self.sock = 0
        self.adr = address
        self.port = port

    def connect(self):
        """
        Estabelece a ligação ao servidor especificado na inicialização do
        objeto.
        """
        self.sock = util.create_tcp_client_socket(self.adr, self.port)

    def send_receive(self, (data, datasize)):
        # type: (object) -> object
        """
        Envia os dados contidos em data para a socket da ligação, e retorna a
        resposta recebida pela mesma socket.
        :rtype: object
        """
        #Send a request to server
        self.sock.sendall(datasize)
        self.sock.sendall(data)

        #Get answer from server and interpret it
        sizebytes = self.sock.recv(4)
        size = util.size_unpack(sizebytes)
        message_recv = util.receive_all(self.sock, size)
        message = util.deserialize(message_recv)

        return message

        size = struct.unpack('!i', sizebytes)[0]
        recbytes = receive_all38(self.sock, size)
        rec = pickle.loads(recbytes)
        return rec
    def send_receive(self, data):
        """
        Envia os dados contidos em data para a socket da ligação, e retorna a
        resposta recebida pela mesma socket.
        """
        try:
            data_bytes = pickle.dumps(data, -1)
            data_size_bytes = struct.pack('!i', len(data_bytes))
            self.socket.sendall(data_size_bytes)
            self.socket.sendall(data_bytes)

            response = ""
            response_size_bytes = self.socket.recv(4)
            response_bytes = sock_utils.receive_all(
                self.socket,
                struct.unpack('!i', response_size_bytes)[0])
            response = pickle.loads(response_bytes)
        except:
            print("Connection lost, server disconnected")
            self.socket.close()
            exit()
        return response
        for sckt in R:
            if sckt is socket:
                conn_sock, addr = socket.accept()
                addr, port = conn_sock.getpeername()
                print("<" + time.ctime() + "> " + '   Nova Ligação:   %s:%d' %
                      (addr, port))
                SocketList.append(conn_sock)
            else:
                locks.locks.clear_expired_locks()
                for recurso in locks.locks.recursosArray:
                    if locks.locks.recursosArray[recurso].stat() >= int(
                            locks.locks.numMaxBloqueios):
                        locks.locks.recursosArray[recurso].disable()
                size_bytes2 = sckt.recv(4)
                if size_bytes2:
                    mensagem = sock_utils.receive_all(sckt, size_bytes2)
                    if mensagem:
                        print("\n-#-")
                        print("Recebi: ", mensagem)
                        resposta = locks.handleMessage(mensagem)
                        print("Vou Enviar: ", resposta)
                        print("-#-\n")
                        msg_bytes3 = pickle.dumps(resposta, -1)
                        size_bytes3 = struct.pack('!i', len(msg_bytes3))
                        sckt.sendall(size_bytes3)
                        sckt.sendall(msg_bytes3)

                    print("Data Actual: " + time.ctime() + "\n")
                    print(locks.locks)
                    print('----------#########----------\n')
Ejemplo n.º 11
0
    HOST = ''
    PORT = 9999
    resource_number=10
    resource_time=10
    print "A utiizar os parametros padrão"
print "Porta: " + str(PORT)
print "Recursos: " + str(resource_number) + " Tempo: " + str(resource_time)
lp = lock_pool(resource_number)
msgcliente = []
ret = []
sock=sock_utils.create_tcp_server_socket(HOST,PORT,1)
while True:
    (conn_sock, addr) = sock.accept()
    print 'ligado a %s', addr
    try:
        msg = sock_utils.receive_all(conn_sock,1024)
        msg_unp = pickle.loads(msg)
        print 'recebi %s' % msg_unp
        msg_unp[1]=int(msg_unp[1])
        if(len(msg_unp)>2):
            msg_unp[2]=int(msg_unp[2])
            msg_unp[1]=int(msg_unp[1])

        if msg_unp[1] > len(lp.lock_pool_array):
                msg_pronta_enviar = 'UNKNOWN RESOURCE'
        else:
            lp.clear_expired_locks()
            if(msg_unp[0] == 'LOCK'):
                if lp.lock(msg_unp[1], msg_unp[2], t.time() + resource_time):
                    msg_pronta_enviar = 'OK'
                else:
Ejemplo n.º 12
0
    R, W, X = select.select(SocketList, [], [])
    for socket in R:
        if socket is listener_socket:
            (conn_sock, addr) = listener_socket.accept()
            try:
                (addr, port) = conn_sock.getpeername()
                print "New client connected: ", addr[0], ":", addr[1]
                SocketList.append(conn_sock)
            except:
                print "Socket Closed! ------ End Connection"
                SocketList.remove(conn_sock)
                conn_sock.close()
        else:
            try:
                pool.clear_expired_locks()
                message_bytes = util.receive_all(socket, 4)

                if message_bytes != "None":
                    #Get Client request
                    bytesize = util.size_unpack(message_bytes)
                    getmessage = util.receive_all(socket, bytesize)
                    print util.deserialize(getmessage)
                    #Launch server skeleton & process message
                    skeleton = skel.LockSkel()
                    answer = skeleton.ServerHelper(getmessage, pool, args)
                    # Answer must be serialized and sent
                    # answer = util.serialize(answer)
                    # answer_size = util.msg_length(answer)
                    # socket.sendall(answer_size)
                    # socket.sendall(answer)
                    util.serial_send(socket, answer)
Ejemplo n.º 13
0
sock = su.create_tcp_server_socket("", PORT, 1)

SocketList = [sock]

while True:
    try:
        R, W, X = sel.select(SocketList, [], [])
        for sckt in R:
            if sckt is sock:
                (conn_sock, addr) = sock.accept()
                print("### CONNECTED TO: ###")
                print("ADDRESS: ", addr[0])
                print("PORT: ", str(addr[1]))
                SocketList.append(conn_sock)
            else:
                size_bytes = su.receive_all(sckt, 4)

                if size_bytes:
                    skel.pool.clear_expired_locks()
                    skel.pool.disable_expired_resources()

                    size = struct.unpack("!i", size_bytes)[0]

                    #receber mensagem em bytes
                    resp, pool = skel.processMessage(su.receive_all(
                        sckt, size))

                    #enviar resposta

                    size_mens = struct.pack("!i", len(resp))
                    sckt.sendall(size_mens)
Ejemplo n.º 14
0
            try:
                if soquete is sock:
                    (conn_sock, addr) = sock.accept()
                    print "Cliente" + str(conn_sock.getpeername())
                    SocketInput.append(conn_sock)
                else:
                    resp = []
                    recvv = soquete.recv(50)
                    if recvv == '':
                        print 'Client Close' + str(soquete.getpeername())
                        soquete.close()
                        SocketInput.remove(soquete)
                    else:
                        tamanho = int(p.loads(recvv))
                        soquete.sendall(p.dumps("SIZEOK", -1))
                        comando = sock_utils.receive_all(soquete, tamanho)
                        if tamanho == sys.getsizeof(comando):
                            msg_unp = p.loads(comando)
                            print 'Pedido Recebido: ' + str(msg_unp)
                            print ""
                            msg_unp[1] = int(msg_unp[1])
                            if len(msg_unp) > 2:
                                msg_unp[2] = int(msg_unp[2])
                                msg_unp[1] = int(msg_unp[1])

                            resp = lskel.handle(msg_unp)
                            soquete.sendall(resp)
                        else:
                            print 'Erro: Mensagem recebida nao tem o mesmo tamanho da original'
                            soquete.close()
                            SocketInput.remove(soquete)
Ejemplo n.º 15
0
            try:
                if soquete is sock:
                    (conn_sock, addr) = sock.accept()
                    print "Cliente" + str(conn_sock.getpeername())
                    SocketInput.append(conn_sock)
                else:
                    resp = []
                    recvv = soquete.recv(50)
                    if recvv == '':
                        print 'Client Close' + str(soquete.getpeername())
                        soquete.close()
                        SocketInput.remove(soquete)
                    else:
                        tamanho = int(p.loads(recvv))
                        soquete.sendall(p.dumps("SIZEOK", -1))
                        comando = sock_utils.receive_all(soquete, tamanho)
                        if tamanho == sys.getsizeof(comando):
                            msg_unp = p.loads(comando)
                            print 'Pedido Recebido: ' + str(msg_unp)
                            print ""
                            msg_unp[1] = int(msg_unp[1])
                            if len(msg_unp) > 2:
                                msg_unp[2] = int(msg_unp[2])
                                msg_unp[1] = int(msg_unp[1])

                            resp = lskel.handle(msg_unp)
                            soquete.sendall(resp)
                        else:
                            print 'Erro: Mensagem recebida nao tem o mesmo tamanho da original'
                            soquete.close()
                            SocketInput.remove(soquete)
Ejemplo n.º 16
0
def servidor():
    """
    Função usada para iniciar o programa, processando a linha de comandos, aceitando ligações de clientes,
    processando o pedido, gerindo os recursos definidos e enviando a devida resposta ao pedido.
    """
    # python lock_server.py <PORT> <n recursos> <maximo de bloqueios k> <maximo de bloqueios y> <tempo limite de ligacao(segundos)
    try:
        PORT = int(sys.argv[1])
        N = int(sys.argv[2])
        K = int(sys.argv[3])
        Y = int(sys.argv[4])
        T = int(sys.argv[5])
        global pool
        pool = lock_pool(N, K, Y, T)
        global  dicionario
        dicionario = dictionary_create(pool)
    except:
        raise ValueError("Argumentos inválidos!")

    HOST = ''
    Servidor = create_tcp_server_socket(HOST, PORT, 1)  # Criaçao do listening socket do servidor
    semaforo = Semaphore(1)                             # Semaforo usado para garantir exclusao mutua
    keep = True                                         # variavel que mantem o servidor ligado
    while keep:
        try:
            (conn_sock, addr) = Servidor.accept()
        except s.error as err:
    		print "Erro na criacao do socket de conecao: ", err
    		exit()

        resp = ""

        pool.clear_expired_locks()
        pool.check_K()
        
        msg_nbytes = receive_all(Servidor, 4)
        msg_bytes = receive_all(Servidor, int(struct.unpack("!i",msg_nbytes)[0]))
        msg = pickle.loads(resp)
        
        if msg[0] == 10:
            resp = pool.lock(msg[-1], msg[1], T)
        elif msg[0] == 20:
            resp = pool.release(msg[-1],msg[1])
        elif msg[0] == 30:
            resp = pool.test(msg[1])
        elif msg[0] == 40:
            resp = pool.stat(msg[1])
        elif msg[0] == 50:
            resp = pool.stat_y()
        elif msg[0] == 60:
            resp = pool.stat_n()
        else:
            resp = "UNKNOWN COMMAND"

        msg_bytes = pickle.dumps(resp, -2)
        size_bytes = struct.pack("!i",len(msg_bytes))
        conn_sock.sendall(size_bytes)
        conn_sock.sendall(msg_bytes)
        conn_sock.close()

    sock.close()
Ejemplo n.º 17
0
SocketList = [ListenSocket, sys.stdin]

while True:
    R, W, X = select.select(SocketList, [], [])
    for socket in R:
        if socket is ListenSocket:
            conn_sock, addr = ListenSocket.accept()
            addr, port = conn_sock.getpeername()
            print('Novo cliente conectado -> %s:%d' % (addr, port))
            SocketList.append(conn_sock)

        else:
            #limpar recursos
            skel.clear_locks()

            size_bytes = receive_all(socket, 4)
            if not size_bytes:
                socket.close()
                SocketList.remove(socket)
                print('Client closed connection.')

            else:
                size = struct.unpack("!i", size_bytes)[0]
                msg_bytes = receive_all(socket, size)
                if not msg_bytes:
                    socket.close()
                    SocketList.remove(socket)
                    print('Client closed connection.')

                else:
                    msg = pickle.loads(msg_bytes)