Renaming ExtensionRef to ExtensionConfig, fleshing it out bunch more, and using it in Extension instance
This commit is contained in:
parent
3cbcb20257
commit
e919c0dff8
|
@ -0,0 +1,98 @@
|
||||||
|
package org.eclipse.jetty.websocket.api;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.util.QuotedStringTokenizer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Proposed interface for API (not yet settled)
|
||||||
|
*/
|
||||||
|
public class ExtensionConfig
|
||||||
|
{
|
||||||
|
public static ExtensionConfig parse(String parameterizedName)
|
||||||
|
{
|
||||||
|
QuotedStringTokenizer tok = new QuotedStringTokenizer(parameterizedName,";");
|
||||||
|
|
||||||
|
ExtensionConfig ext = new ExtensionConfig(tok.nextToken().trim());
|
||||||
|
|
||||||
|
while (tok.hasMoreTokens())
|
||||||
|
{
|
||||||
|
QuotedStringTokenizer nv = new QuotedStringTokenizer(tok.nextToken().trim(),"=");
|
||||||
|
String key = nv.nextToken().trim();
|
||||||
|
String value = nv.hasMoreTokens()?nv.nextToken().trim():null;
|
||||||
|
ext.setParameter(key,value);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ext;
|
||||||
|
}
|
||||||
|
|
||||||
|
private final String name;
|
||||||
|
private Map<String, String> parameters;
|
||||||
|
|
||||||
|
public ExtensionConfig(String name)
|
||||||
|
{
|
||||||
|
this.name = name;
|
||||||
|
this.parameters = new HashMap<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName()
|
||||||
|
{
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getParameter(String key, int defValue)
|
||||||
|
{
|
||||||
|
String val = parameters.get(key);
|
||||||
|
if(val == null) {
|
||||||
|
return defValue;
|
||||||
|
}
|
||||||
|
return Integer.valueOf(val);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getParameter(String key, String defValue)
|
||||||
|
{
|
||||||
|
String val = parameters.get(key);
|
||||||
|
if(val == null) {
|
||||||
|
return defValue;
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getParameterizedName()
|
||||||
|
{
|
||||||
|
StringBuilder str = new StringBuilder();
|
||||||
|
str.append(name);
|
||||||
|
for (String param : parameters.keySet())
|
||||||
|
{
|
||||||
|
str.append(';').append(param).append('=').append(QuotedStringTokenizer.quoteIfNeeded(parameters.get(param),";="));
|
||||||
|
}
|
||||||
|
return str.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the parameters on this config from the other configuration.
|
||||||
|
* @param other the other configuration.
|
||||||
|
*/
|
||||||
|
public void init(ExtensionConfig other)
|
||||||
|
{
|
||||||
|
this.parameters.clear();
|
||||||
|
this.parameters.putAll(other.parameters);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParameter(String key, int value)
|
||||||
|
{
|
||||||
|
parameters.put(key,Integer.toString(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParameter(String key, String value)
|
||||||
|
{
|
||||||
|
parameters.put(key,value);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString()
|
||||||
|
{
|
||||||
|
return getParameterizedName();
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,13 +0,0 @@
|
||||||
package org.eclipse.jetty.websocket.api;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Proposed interface for API (not yet settled)
|
|
||||||
*/
|
|
||||||
public interface ExtensionRef
|
|
||||||
{
|
|
||||||
String getName();
|
|
||||||
|
|
||||||
Map<String, String> getParameters();
|
|
||||||
}
|
|
|
@ -15,64 +15,40 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
package org.eclipse.jetty.websocket.extensions;
|
package org.eclipse.jetty.websocket.extensions;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import org.eclipse.jetty.websocket.api.ExtensionConfig;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.util.QuotedStringTokenizer;
|
|
||||||
|
|
||||||
public class AbstractExtension implements Extension
|
public class AbstractExtension implements Extension
|
||||||
{
|
{
|
||||||
private final String name;
|
private final ExtensionConfig config;
|
||||||
private final Map<String, String> parameters = new HashMap<String, String>();
|
|
||||||
|
|
||||||
public AbstractExtension(String name)
|
public AbstractExtension(String name)
|
||||||
{
|
{
|
||||||
this.name = name;
|
this.config = new ExtensionConfig(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getInitParameter(String name, int dft)
|
@Override
|
||||||
|
public ExtensionConfig getConfig()
|
||||||
{
|
{
|
||||||
String v = parameters.get(name);
|
// TODO Auto-generated method stub
|
||||||
if (v==null)
|
return null;
|
||||||
{
|
|
||||||
return dft;
|
|
||||||
}
|
|
||||||
return Integer.valueOf(v);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getInitParameter(String name,String dft)
|
|
||||||
{
|
|
||||||
if (!parameters.containsKey(name))
|
|
||||||
{
|
|
||||||
return dft;
|
|
||||||
}
|
|
||||||
return parameters.get(name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName()
|
public String getName()
|
||||||
{
|
{
|
||||||
return name;
|
return config.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getParameterizedName()
|
public String getParameterizedName()
|
||||||
{
|
{
|
||||||
StringBuilder name = new StringBuilder();
|
return config.getParameterizedName();
|
||||||
name.append(name);
|
|
||||||
for (String param : parameters.keySet())
|
|
||||||
{
|
|
||||||
name.append(';').append(param).append('=').append(QuotedStringTokenizer.quoteIfNeeded(parameters.get(param),";="));
|
|
||||||
}
|
|
||||||
return name.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean init(Map<String, String> parameters)
|
public void setConfig(ExtensionConfig config)
|
||||||
{
|
{
|
||||||
parameters.putAll(parameters);
|
this.config.init(config);
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -15,12 +15,12 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
package org.eclipse.jetty.websocket.extensions;
|
package org.eclipse.jetty.websocket.extensions;
|
||||||
|
|
||||||
import java.util.Map;
|
import org.eclipse.jetty.websocket.api.ExtensionConfig;
|
||||||
|
|
||||||
public interface Extension
|
public interface Extension
|
||||||
{
|
{
|
||||||
|
public ExtensionConfig getConfig();
|
||||||
public String getName();
|
public String getName();
|
||||||
public String getParameterizedName();
|
public String getParameterizedName();
|
||||||
|
public void setConfig(ExtensionConfig config);
|
||||||
public boolean init(Map<String,String> parameters);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,12 +15,12 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
package org.eclipse.jetty.websocket.extensions.deflate;
|
package org.eclipse.jetty.websocket.extensions.deflate;
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.zip.Deflater;
|
import java.util.zip.Deflater;
|
||||||
import java.util.zip.Inflater;
|
import java.util.zip.Inflater;
|
||||||
|
|
||||||
import org.eclipse.jetty.util.log.Log;
|
import org.eclipse.jetty.util.log.Log;
|
||||||
import org.eclipse.jetty.util.log.Logger;
|
import org.eclipse.jetty.util.log.Logger;
|
||||||
|
import org.eclipse.jetty.websocket.api.ExtensionConfig;
|
||||||
import org.eclipse.jetty.websocket.extensions.AbstractExtension;
|
import org.eclipse.jetty.websocket.extensions.AbstractExtension;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -40,22 +40,14 @@ public class DeflateFrameExtension extends AbstractExtension
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean init(Map<String, String> parameters)
|
public void setConfig(ExtensionConfig config)
|
||||||
{
|
{
|
||||||
if (!parameters.containsKey("minLength"))
|
super.setConfig(config);
|
||||||
{
|
|
||||||
parameters.put("minLength",Integer.toString(_minLength));
|
_minLength = config.getParameter("minLength",_minLength);
|
||||||
}
|
|
||||||
if(super.init(parameters))
|
|
||||||
{
|
|
||||||
_minLength=getInitParameter("minLength",_minLength);
|
|
||||||
|
|
||||||
_deflater = new Deflater();
|
_deflater = new Deflater();
|
||||||
_inflater = new Inflater();
|
_inflater = new Inflater();
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
|
|
|
@ -15,9 +15,7 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
package org.eclipse.jetty.websocket.extensions.fragment;
|
package org.eclipse.jetty.websocket.extensions.fragment;
|
||||||
|
|
||||||
import java.io.IOException;
|
import org.eclipse.jetty.websocket.api.ExtensionConfig;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.eclipse.jetty.websocket.extensions.AbstractExtension;
|
import org.eclipse.jetty.websocket.extensions.AbstractExtension;
|
||||||
|
|
||||||
public class FragmentExtension extends AbstractExtension
|
public class FragmentExtension extends AbstractExtension
|
||||||
|
@ -31,15 +29,13 @@ public class FragmentExtension extends AbstractExtension
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean init(Map<String, String> parameters)
|
public void setConfig(ExtensionConfig config)
|
||||||
{
|
{
|
||||||
if(super.init(parameters))
|
super.setConfig(config);
|
||||||
{
|
|
||||||
_maxLength=getInitParameter("maxLength",_maxLength);
|
_maxLength = config.getParameter("maxLength",_maxLength);
|
||||||
_minFragments=getInitParameter("minFragments",_minFragments);
|
_minFragments = config.getParameter("minFragments",_minFragments);
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO: Migrate to new Jetty9 IO
|
/* TODO: Migrate to new Jetty9 IO
|
||||||
|
|
Loading…
Reference in New Issue