All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.client.impl.protocol.codec.MemberCodec Maven / Gradle / Ivy

/*
 * Copyright (c) 2008-2018, Hazelcast, Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.hazelcast.client.impl.protocol.codec;

import com.hazelcast.annotation.Codec;
import com.hazelcast.client.impl.protocol.ClientMessage;
import com.hazelcast.client.impl.protocol.util.ParameterUtil;
import com.hazelcast.core.Member;
import com.hazelcast.nio.Address;
import com.hazelcast.nio.Bits;

import java.util.HashMap;
import java.util.Map;

@Codec(Member.class)
public final class MemberCodec {

    private MemberCodec() {
    }

    public static Member decode(ClientMessage clientMessage) {
        Address address = AddressCodec.decode(clientMessage);
        String uuid = clientMessage.getStringUtf8();
        boolean liteMember = clientMessage.getBoolean();
        int attributeSize = clientMessage.getInt();
        Map attributes = new HashMap();
        for (int i = 0; i < attributeSize; i++) {
            String key = clientMessage.getStringUtf8();
            String value = clientMessage.getStringUtf8();
            attributes.put(key, value);
        }

        return new com.hazelcast.client.impl.MemberImpl(address, uuid, attributes, liteMember);
    }

    public static void encode(Member member, ClientMessage clientMessage) {
        AddressCodec.encode(member.getAddress(), clientMessage);
        clientMessage.set(member.getUuid());
        clientMessage.set(member.isLiteMember());
        Map attributes = new HashMap(member.getAttributes());
        clientMessage.set(attributes.size());
        for (Map.Entry entry : attributes.entrySet()) {
            clientMessage.set(entry.getKey());
            Object value = entry.getValue();
            clientMessage.set(value.toString());

        }
    }

    public static int calculateDataSize(Member member) {
        int dataSize = AddressCodec.calculateDataSize(member.getAddress());
        dataSize += ParameterUtil.calculateDataSize(member.getUuid());
        // isLiteMember field
        dataSize += Bits.BOOLEAN_SIZE_IN_BYTES;
        // number of attributes field
        dataSize += Bits.INT_SIZE_IN_BYTES;
        Map attributes = member.getAttributes();
        for (Map.Entry entry : attributes.entrySet()) {
            dataSize += ParameterUtil.calculateDataSize(entry.getKey());
            Object value = entry.getValue();
            //TODO: this is costly to use toString
            dataSize += ParameterUtil.calculateDataSize(value.toString());
        }
        return dataSize;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy