use of io.vertigo.vega.webservice.exception.VSecurityException in project vertigo by KleeGroup.
the class ServerSideStateWebServiceHandlerPlugin method readServerSideUiObject.
private void readServerSideUiObject(final UiObject<DtObject> uiObject, final boolean consumeServerSideToken) {
final String accessToken = uiObject.getServerSideToken();
if (accessToken == null) {
// same message for no ServerSideToken or bad ServerSideToken
throw new VSecurityException(SERVER_SIDE_MANDATORY);
}
final Optional<Serializable> serverSideObjectOpt;
if (consumeServerSideToken) {
// if exception : token is consume. It's for security reason : no replay on bad request (brute force password)
serverSideObjectOpt = tokenManager.getAndRemove(accessToken);
} else {
serverSideObjectOpt = tokenManager.get(accessToken);
}
final Serializable serverSideObject = serverSideObjectOpt.orElseThrow(() -> new VSecurityException(SERVER_SIDE_MANDATORY));
uiObject.setServerSideObject((DtObject) serverSideObject);
}
use of io.vertigo.vega.webservice.exception.VSecurityException in project vertigo by KleeGroup.
the class SessionWebServiceHandlerPlugin method handle.
/**
* {@inheritDoc}
*/
@Override
public Object handle(final Request request, final Response response, final WebServiceCallContext routeContext, final HandlerChain chain) throws SessionException {
// obtain session (create if needed)
final Session session = request.session(true);
final UserSession user = obtainUserSession(session);
try {
// Bind userSession to SecurityManager
securityManager.startCurrentUserSession(user);
return chain.handle(request, response, routeContext);
} catch (final VSecurityException e) {
if (session.isNew()) {
// If a new session is badly use, we invalid it (light protection against DDOS)
session.invalidate();
// If session was just created, we translate securityException as a Session expiration.
throw (SessionException) new SessionException("Session has expired").initCause(e);
}
throw e;
} finally {
// Unbind userSession to SecurityManager
securityManager.stopCurrentUserSession();
}
}
use of io.vertigo.vega.webservice.exception.VSecurityException in project vertigo by KleeGroup.
the class RestfulServiceWebServiceHandlerPlugin method handle.
/**
* {@inheritDoc}
*/
@Override
public Object handle(final Request request, final Response response, final WebServiceCallContext routeContext, final HandlerChain chain) throws SessionException {
final WebServiceDefinition webServiceDefinition = routeContext.getWebServiceDefinition();
final Object[] serviceArgs = makeArgs(routeContext);
final Method method = webServiceDefinition.getMethod();
final WebServices webServices = (WebServices) Home.getApp().getComponentSpace().resolve(method.getDeclaringClass());
if (method.getName().startsWith("create")) {
// by convention, if method starts with 'create', an http 201 status code is returned (if ok)
response.status(HttpServletResponse.SC_CREATED);
}
try {
return ClassUtil.invoke(webServices, method, serviceArgs);
} catch (final RuntimeException e) {
// If throwed exception was ValidationUserException, VUserException, SessionException, VSecurityException, RuntimeException
// we re throw it
final Throwable cause = e.getCause();
if (cause instanceof InvocationTargetException) {
final Throwable targetException = ((InvocationTargetException) cause).getTargetException();
if (targetException instanceof ValidationUserException) {
throw (ValidationUserException) targetException;
} else if (targetException instanceof VUserException) {
throw (VUserException) targetException;
} else if (targetException instanceof SessionException) {
throw (SessionException) targetException;
} else if (targetException instanceof VSecurityException) {
throw (VSecurityException) targetException;
} else if (targetException instanceof RuntimeException) {
throw (RuntimeException) targetException;
}
}
throw e;
}
}
Aggregations