mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
GUACAMOLE-524: Add convenience classes for injecting custom parameter tokens through decoration.
This commit is contained in:
@@ -0,0 +1,69 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 org.apache.guacamole.net.auth;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import org.apache.guacamole.GuacamoleException;
|
||||
import org.apache.guacamole.net.GuacamoleTunnel;
|
||||
import org.apache.guacamole.protocol.GuacamoleClientInformation;
|
||||
|
||||
/**
|
||||
* Connection implementation which overrides the connect() function of an
|
||||
* underlying Connection, adding a given set of parameter tokens to the tokens
|
||||
* already supplied.
|
||||
*/
|
||||
public class TokenInjectingConnection extends DelegatingConnection {
|
||||
|
||||
/**
|
||||
* The additional tokens to include with each call to connect().
|
||||
*/
|
||||
private final Map<String, String> tokens;
|
||||
|
||||
/**
|
||||
* Wraps the given Connection, automatically adding the given tokens to
|
||||
* each invocation of connect(). Any additional tokens which have the same
|
||||
* name as existing tokens will override the existing values.
|
||||
*
|
||||
* @param connection
|
||||
* The Connection to wrap.
|
||||
*
|
||||
* @param tokens
|
||||
* The additional tokens to include with each call to connect().
|
||||
*/
|
||||
public TokenInjectingConnection(Connection connection,
|
||||
Map<String, String> tokens) {
|
||||
super(connection);
|
||||
this.tokens = tokens;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GuacamoleTunnel connect(GuacamoleClientInformation info,
|
||||
Map<String, String> tokens) throws GuacamoleException {
|
||||
|
||||
// Apply provided tokens over those given to connect()
|
||||
tokens = new HashMap<>(tokens);
|
||||
tokens.putAll(this.tokens);
|
||||
|
||||
return super.connect(info, tokens);
|
||||
|
||||
}
|
||||
|
||||
}
|
@@ -0,0 +1,69 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 org.apache.guacamole.net.auth;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import org.apache.guacamole.GuacamoleException;
|
||||
import org.apache.guacamole.net.GuacamoleTunnel;
|
||||
import org.apache.guacamole.protocol.GuacamoleClientInformation;
|
||||
|
||||
/**
|
||||
* ConnectionGroup implementation which overrides the connect() function of an
|
||||
* underlying ConnectionGroup, adding a given set of parameter tokens to the
|
||||
* tokens already supplied.
|
||||
*/
|
||||
public class TokenInjectingConnectionGroup extends DelegatingConnectionGroup {
|
||||
|
||||
/**
|
||||
* The additional tokens to include with each call to connect().
|
||||
*/
|
||||
private final Map<String, String> tokens;
|
||||
|
||||
/**
|
||||
* Wraps the given ConnectionGroup, automatically adding the given tokens
|
||||
* to each invocation of connect(). Any additional tokens which have the
|
||||
* same name as existing tokens will override the existing values.
|
||||
*
|
||||
* @param connectionGroup
|
||||
* The ConnectionGroup to wrap.
|
||||
*
|
||||
* @param tokens
|
||||
* The additional tokens to include with each call to connect().
|
||||
*/
|
||||
public TokenInjectingConnectionGroup(ConnectionGroup connectionGroup,
|
||||
Map<String, String> tokens) {
|
||||
super(connectionGroup);
|
||||
this.tokens = tokens;
|
||||
}
|
||||
|
||||
@Override
|
||||
public GuacamoleTunnel connect(GuacamoleClientInformation info,
|
||||
Map<String, String> tokens) throws GuacamoleException {
|
||||
|
||||
// Apply provided tokens over those given to connect()
|
||||
tokens = new HashMap<>(tokens);
|
||||
tokens.putAll(this.tokens);
|
||||
|
||||
return super.connect(info, tokens);
|
||||
|
||||
}
|
||||
|
||||
}
|
@@ -0,0 +1,144 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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 org.apache.guacamole.net.auth;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.Map;
|
||||
import org.apache.guacamole.GuacamoleException;
|
||||
|
||||
/**
|
||||
* UserContext implementation which decorates a given UserContext,
|
||||
* automatically applying additional parameter tokens during the connection
|
||||
* process of any retrieved Connections and ConnectionGroups.
|
||||
*/
|
||||
public class TokenInjectingUserContext extends DelegatingUserContext {
|
||||
|
||||
/**
|
||||
* The additional tokens to include with each call to connect() if
|
||||
* getTokens() is not overridden.
|
||||
*/
|
||||
private final Map<String, String> tokens;
|
||||
|
||||
/**
|
||||
* Wraps the given UserContext, overriding the connect() function of each
|
||||
* retrieved Connection and ConnectionGroup such that the given additional
|
||||
* parameter tokens are included. Any additional tokens which have the same
|
||||
* name as existing tokens will override the existing values. If tokens
|
||||
* specific to a particular connection or connection group need to be
|
||||
* included, getTokens() may be overridden to provide a different set of
|
||||
* tokens.
|
||||
*
|
||||
* @param userContext
|
||||
* The UserContext to wrap.
|
||||
*
|
||||
* @param tokens
|
||||
* The additional tokens to include with each call to connect().
|
||||
*/
|
||||
public TokenInjectingUserContext(UserContext userContext,
|
||||
Map<String, String> tokens) {
|
||||
super(userContext);
|
||||
this.tokens = tokens;
|
||||
}
|
||||
|
||||
/**
|
||||
* Wraps the given UserContext, overriding the connect() function of each
|
||||
* retrieved Connection and ConnectionGroup such that the additional
|
||||
* parameter tokens returned by getTokens() are included. Any additional
|
||||
* tokens which have the same name as existing tokens will override the
|
||||
* existing values.
|
||||
*
|
||||
* @param userContext
|
||||
* The UserContext to wrap.
|
||||
*/
|
||||
public TokenInjectingUserContext(UserContext userContext) {
|
||||
this(userContext, Collections.<String, String>emptyMap());
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the tokens which should be added to an in-progress call to
|
||||
* connect() for the given Connection. If not overridden, this function
|
||||
* will return the tokens provided when this instance of
|
||||
* TokenInjectingUserContext was created.
|
||||
*
|
||||
* @param connection
|
||||
* The Connection on which connect() has been called.
|
||||
*
|
||||
* @return
|
||||
* The tokens which should be added to the in-progress call to
|
||||
* connect().
|
||||
*/
|
||||
protected Map<String, String> getTokens(Connection connection) {
|
||||
return tokens;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the tokens which should be added to an in-progress call to
|
||||
* connect() for the given ConnectionGroup. If not overridden, this
|
||||
* function will return the tokens provided when this instance of
|
||||
* TokenInjectingUserContext was created.
|
||||
*
|
||||
* @param connectionGroup
|
||||
* The ConnectionGroup on which connect() has been called.
|
||||
*
|
||||
* @return
|
||||
* The tokens which should be added to the in-progress call to
|
||||
* connect().
|
||||
*/
|
||||
protected Map<String, String> getTokens(ConnectionGroup connectionGroup) {
|
||||
return tokens;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Directory<ConnectionGroup> getConnectionGroupDirectory()
|
||||
throws GuacamoleException {
|
||||
return new DecoratingDirectory<ConnectionGroup>(super.getConnectionGroupDirectory()) {
|
||||
|
||||
@Override
|
||||
protected ConnectionGroup decorate(ConnectionGroup object) throws GuacamoleException {
|
||||
return new TokenInjectingConnectionGroup(object, getTokens(object));
|
||||
}
|
||||
|
||||
@Override
|
||||
protected ConnectionGroup undecorate(ConnectionGroup object) throws GuacamoleException {
|
||||
return ((TokenInjectingConnectionGroup) object).getDelegateConnectionGroup();
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
@Override
|
||||
public Directory<Connection> getConnectionDirectory()
|
||||
throws GuacamoleException {
|
||||
return new DecoratingDirectory<Connection>(super.getConnectionDirectory()) {
|
||||
|
||||
@Override
|
||||
protected Connection decorate(Connection object) throws GuacamoleException {
|
||||
return new TokenInjectingConnection(object, getTokens(object));
|
||||
}
|
||||
|
||||
@Override
|
||||
protected Connection undecorate(Connection object) throws GuacamoleException {
|
||||
return ((TokenInjectingConnection) object).getDelegateConnection();
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user