org.jgroups.auth.FixedMembershipToken Maven / Gradle / Ivy
package org.jgroups.auth;
import org.jgroups.Event;
import org.jgroups.Message;
import org.jgroups.PhysicalAddress;
import org.jgroups.annotations.Property;
import org.jgroups.stack.IpAddress;
import org.jgroups.util.Bits;
import org.jgroups.util.Util;
import java.io.DataInput;
import java.io.DataOutput;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;
/**
*
* The FixedMemberShipToken object predefines a list of IP addresses and ports that can join the group.
*
*
* Configuration parameters for this example are shown below:
*
*
* - fixed_members_value (required) = List of IP addresses & ports (optionally) - ports must be
* seperated by a '/' e.g. 127.0.0.1/1010*127.0.0.1/4567
* - fixed_members_seperator (required) = The seperator used between IP addresses - e.g. *
*
*
* @author Chris Mills ([email protected])
*/
public class FixedMembershipToken extends AuthToken {
private final List memberList = new ArrayList<>();
private String token = "emptyToken";
@Property
private String fixed_members_seperator = ",";
public FixedMembershipToken() {
}
public FixedMembershipToken(String token) {
this.token=token;
}
public String getName() {
return "org.jgroups.auth.FixedMembershipToken";
}
@Property
public void setFixedMembersSeparator(String value) {
fixed_members_seperator = value;
}
/** Check if I'm in memberList, too */
/*public void start() throws Exception {
super.start();
IpAddress self=(IpAddress)auth.getPhysicalAddress();
if(!isInMembersList(self))
throw new IllegalStateException("own physical address " + self + " is not in members (" + memberList + ")");
} */
public boolean authenticate(AuthToken token, Message msg) {
if ((token != null) && (token instanceof FixedMembershipToken) && (this.memberList != null)) {
PhysicalAddress src = (PhysicalAddress) auth.down(new Event(Event.GET_PHYSICAL_ADDRESS, msg.getSrc()));
if (src == null) {
log.error("didn't find physical address for " + msg.getSrc());
return false;
}
return isInMembersList((IpAddress)src);
}
if (log.isWarnEnabled())
log.warn("Invalid AuthToken instance - wrong type or null");
return false;
}
public boolean isInMembersList(IpAddress sender) {
if(memberList == null || sender == null)
return false;
for(InetSocketAddress addr: memberList) {
if(match(sender, addr))
return true;
}
return false;
}
public static boolean match(IpAddress sender, InetSocketAddress addr) {
return !(sender == null || addr == null)
&& addr.getAddress().equals(sender.getIpAddress())
&& (addr.getPort() == 0 || addr.getPort() == sender.getPort());
}
@Property(name = "fixed_members_value")
public void setMemberList(String list) throws UnknownHostException {
memberList.clear();
StringTokenizer memberListTokenizer = new StringTokenizer(list, fixed_members_seperator);
while (memberListTokenizer.hasMoreTokens()) {
String tmp=memberListTokenizer.nextToken().trim();
int index=tmp.lastIndexOf('/');
int port=index != -1? Integer.parseInt(tmp.substring(index+1)) : 0;
String addr_str=index != -1? tmp.substring(0, index) : tmp;
InetAddress addr=InetAddress.getByName(addr_str);
memberList.add(new InetSocketAddress(addr, port));
}
}
public void writeTo(DataOutput out) throws Exception {
Bits.writeString(this.token,out);
}
public void readFrom(DataInput in) throws Exception {
this.token = Bits.readString(in);
}
public int size() {
return Util.size(token);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy