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

org.wildfly.clustering.server.infinispan.affinity.NaryGroupMemberAffinity Maven / Gradle / Ivy

/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package org.wildfly.clustering.server.infinispan.affinity;

import java.util.LinkedList;
import java.util.List;
import java.util.function.Function;
import java.util.function.Supplier;

import org.infinispan.Cache;
import org.infinispan.remoting.transport.Address;
import org.wildfly.clustering.cache.Key;
import org.wildfly.clustering.cache.infinispan.CacheKey;
import org.wildfly.clustering.cache.infinispan.embedded.distribution.KeyDistribution;
import org.wildfly.clustering.server.infinispan.CacheContainerGroup;
import org.wildfly.clustering.server.infinispan.CacheContainerGroupMember;
import org.wildfly.clustering.server.infinispan.CacheContainerGroupMemberFactory;

/**
 * Returns a list of group members that own cache keys for a given identifier.
 * @param  the identifier type of a cache key
 * @author Paul Ferraro
 */
public class NaryGroupMemberAffinity implements Function> {

	private final Supplier distribution;
	private final CacheContainerGroupMemberFactory factory;
	private final CacheContainerGroupMember localMember;

	public NaryGroupMemberAffinity(GroupMemberAffinityConfiguration configuration) {
		this(configuration.getCache(), configuration.getGroup());
	}

	public NaryGroupMemberAffinity(Cache, ?> cache, CacheContainerGroup group) {
		this(new Supplier<>() {
			@Override
			public KeyDistribution get() {
				return KeyDistribution.forCache(cache);
			}
		}, group.getGroupMemberFactory(), group.getLocalMember());
	}

	NaryGroupMemberAffinity(Supplier distribution, CacheContainerGroupMemberFactory factory, CacheContainerGroupMember localMember) {
		this.distribution = distribution;
		this.factory = factory;
		this.localMember = localMember;
	}

	@Override
	public List apply(I id) {
		List members = new LinkedList<>();
		boolean locallyOwned = false;
		for (Address address : this.distribution.get().getOwners(new CacheKey<>(id))) {
			locallyOwned |= this.localMember.getAddress().equals(address);
			members.add(this.factory.createGroupMember(address));
		}
		if (!locallyOwned) {
			members.add(this.localMember);
		}
		return members;
	}
}