net.spy.memcached.protocol.binary.SASLBaseOperationImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spymemcached Show documentation
Show all versions of spymemcached Show documentation
A client library for memcached.
/**
* Copyright (C) 2006-2009 Dustin Sallings
* Copyright (C) 2009-2011 Couchbase, Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALING
* IN THE SOFTWARE.
*/
package net.spy.memcached.protocol.binary;
import java.io.IOException;
import java.util.Map;
import javax.security.auth.callback.CallbackHandler;
import javax.security.sasl.Sasl;
import javax.security.sasl.SaslClient;
import javax.security.sasl.SaslException;
import net.spy.memcached.ops.OperationCallback;
import net.spy.memcached.ops.OperationState;
import net.spy.memcached.ops.OperationStatus;
/**
* SASL authenticator.
*/
public abstract class SASLBaseOperationImpl extends OperationImpl {
private static final byte SASL_CONTINUE = 0x21;
protected final String[] mech;
protected final byte[] challenge;
protected final String serverName;
protected final Map props;
protected final CallbackHandler cbh;
public SASLBaseOperationImpl(byte c, String[] m, byte[] ch, String s,
Map p, CallbackHandler h, OperationCallback cb) {
super(c, generateOpaque(), cb);
mech = m;
challenge = ch;
serverName = s;
props = p;
cbh = h;
}
@Override
public void initialize() {
try {
SaslClient sc = Sasl.createSaslClient(mech, null, "memcached",
serverName, props, cbh);
byte[] response = buildResponse(sc);
String mechanism = sc.getMechanismName();
getLogger().debug("Using SASL auth mechanism: " + mechanism);
prepareBuffer(mechanism, 0, response);
} catch (SaslException e) {
// XXX: Probably something saner can be done here.
throw new RuntimeException("Can't make SASL go.", e);
}
}
protected abstract byte[] buildResponse(SaslClient sc) throws SaslException;
@Override
protected void decodePayload(byte[] pl) {
getLogger().debug("Auth response: %s", new String(pl));
}
@Override
protected void finishedPayload(byte[] pl) throws IOException {
if (errorCode == SASL_CONTINUE) {
getCallback().receivedStatus(new OperationStatus(true, new String(pl)));
transitionState(OperationState.COMPLETE);
} else if (errorCode == 0) {
getCallback().receivedStatus(new OperationStatus(true, ""));
transitionState(OperationState.COMPLETE);
} else {
super.finishedPayload(pl);
}
}
@Override
public String toString() {
return "SASL base operation";
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy