LogoutServlet.java
2.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* javax.jcr.Session
* javax.servlet.ServletException
* javax.servlet.http.HttpServletRequest
* javax.servlet.http.HttpServletResponse
* javax.servlet.http.HttpServletResponseWrapper
* org.apache.sling.api.auth.Authenticator
* org.apache.sling.commons.json.JSONException
* org.apache.sling.commons.json.io.JSONWriter
* org.osgi.framework.BundleContext
* org.osgi.framework.ServiceReference
* org.slf4j.Logger
*/
package com.day.crx.delite.impl.servlets;
import com.day.crx.delite.impl.AbstractServlet;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.Writer;
import javax.jcr.Session;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import org.apache.sling.api.auth.Authenticator;
import org.apache.sling.commons.json.JSONException;
import org.apache.sling.commons.json.io.JSONWriter;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceReference;
import org.slf4j.Logger;
public class LogoutServlet
extends AbstractServlet {
public LogoutServlet(BundleContext bc) {
super(bc);
}
protected void doService(HttpServletRequest req, HttpServletResponse res, Session session) throws ServletException, IOException {
this.logout(req, res);
res.setStatus(200);
res.setContentType("application/json");
res.setCharacterEncoding("UTF-8");
PrintWriter pw = res.getWriter();
try {
JSONWriter writer = new JSONWriter((Writer)pw);
writer.object();
writer.endObject();
}
catch (JSONException e) {
this.logger.error("Error while retrieving infos: {}", (Object)e.toString());
res.sendError(500);
}
}
/*
* WARNING - Removed try catching itself - possible behaviour change.
*/
private void logout(HttpServletRequest request, HttpServletResponse response) {
Authenticator auth;
ServiceReference ref = this.bundleContext.getServiceReference(Authenticator.SERVICE_NAME);
if (ref != null && (auth = (Authenticator)this.bundleContext.getService(ref)) != null) {
try {
auth.logout(request, (HttpServletResponse)new HttpServletResponseWrapper(response){
public void sendRedirect(String location) {
}
public void sendError(int sc) {
}
public void sendError(int sc, String msg) {
}
});
response.resetBuffer();
}
finally {
this.bundleContext.ungetService(ref);
}
}
}
}