-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add Groovy Extensions for Servlet Request and Response
- Loading branch information
Showing
5 changed files
with
309 additions
and
0 deletions.
There are no files selected for viewing
39 changes: 39 additions & 0 deletions
39
src/main/groovy/org/graceframework/plugins/unpoly/HttpServletRequestExtension.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
/* | ||
* Copyright 2024 the original author or authors. | ||
* | ||
* Licensed 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 | ||
* | ||
* https://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.graceframework.plugins.unpoly | ||
|
||
import javax.servlet.http.HttpServletRequest | ||
|
||
import groovy.transform.CompileStatic | ||
|
||
/** | ||
* Extends the {@link HttpServletRequest} object with new methods for handling Unpoly Request | ||
* | ||
* @author Michael Yan | ||
* @since 0.0.1 | ||
*/ | ||
@CompileStatic | ||
class HttpServletRequestExtension { | ||
|
||
static UnpolyRequest getUnpoly(HttpServletRequest request) { | ||
new UnpolyRequest(request) | ||
} | ||
|
||
static boolean isUnpoly(HttpServletRequest request) { | ||
getUnpoly(request) as Boolean | ||
} | ||
|
||
} |
35 changes: 35 additions & 0 deletions
35
src/main/groovy/org/graceframework/plugins/unpoly/HttpServletResponseExtension.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/* | ||
* Copyright 2024 the original author or authors. | ||
* | ||
* Licensed 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 | ||
* | ||
* https://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.graceframework.plugins.unpoly | ||
|
||
import javax.servlet.http.HttpServletResponse | ||
|
||
import groovy.transform.CompileStatic | ||
|
||
/** | ||
* Extends the {@link HttpServletResponse} object with new methods for handling Unpoly Response | ||
* | ||
* @author Michael Yan | ||
* @since 0.0.1 | ||
*/ | ||
@CompileStatic | ||
class HttpServletResponseExtension { | ||
|
||
static UnpolyResponse getUnpoly(HttpServletResponse response) { | ||
new UnpolyResponse(response) | ||
} | ||
|
||
} |
134 changes: 134 additions & 0 deletions
134
src/main/groovy/org/graceframework/plugins/unpoly/UnpolyRequest.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
/* | ||
* Copyright 2024 the original author or authors. | ||
* | ||
* Licensed 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 | ||
* | ||
* https://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.graceframework.plugins.unpoly | ||
|
||
import javax.servlet.http.HttpServletRequest | ||
|
||
import groovy.transform.CompileStatic | ||
|
||
/** | ||
* Unpoly Request {link https://unpoly.com/up.protocol} | ||
* | ||
* @author Michael Yan | ||
* @since 0.0.1 | ||
*/ | ||
@CompileStatic | ||
class UnpolyRequest { | ||
|
||
public static final String UP_ACCEPT_LAYER = 'X-Up-Accept-Layer' | ||
public static final String UP_DISMISS_LAYER = 'X-Up-Dismiss-Layer' | ||
public static final String UP_EVENTS = 'X-Up-Events' | ||
public static final String UP_EVICT_CACHE = 'X-Up-Evict-Cache' | ||
public static final String UP_EXPIRE_CACHE = 'X-Up-Expire-Cache' | ||
public static final String UP_FAIL_MODE = 'X-Up-Fail-Mode' | ||
public static final String UP_FAIL_TARGET = 'X-Up-Fail-Target' | ||
public static final String UP_LOCATION = 'X-Up-Location' | ||
public static final String UP_METHOD = 'X-Up-Method' | ||
public static final String UP_MODE = 'X-Up-Mode' | ||
public static final String UP_TARGET = 'X-Up-Target' | ||
public static final String UP_TITLE = 'X-Up-Title' | ||
public static final String UP_VALIDATE = 'X-Up-Validate' | ||
public static final String UP_VERSION = 'X-Up-Version' | ||
|
||
private final HttpServletRequest request | ||
|
||
UnpolyRequest(HttpServletRequest request) { | ||
this.request = request | ||
} | ||
|
||
/** | ||
* This request header contains the mode of the layer targeted for a failed fragment update. | ||
* A fragment update is considered failed if the server responds with a status code other than 2xx, but still renders HTML. | ||
*/ | ||
String getFailMode() { | ||
getHeaderValue(UP_FAIL_MODE) | ||
} | ||
|
||
/** | ||
* This request header contains the target selector for a failed fragment update. | ||
* A fragment update is considered failed if the server responds with a status code other than 2xx, but still renders HTML. | ||
*/ | ||
String getFailTarget() { | ||
getHeaderValue(UP_FAIL_TARGET) | ||
} | ||
|
||
/** | ||
* The server may set this response header to set a custom browser location after a fragment update. | ||
* Without an X-Up-Location header Unpoly will set the browser location to the requested URL. | ||
*/ | ||
String getLocation() { | ||
getHeaderValue(UP_LOCATION) | ||
} | ||
|
||
/** | ||
* The server may set this optional response header to change the HTTP method after a fragment update. | ||
* Without this header Unpoly will use the requested method. | ||
*/ | ||
String getMethod() { | ||
getHeaderValue(UP_METHOD) | ||
} | ||
|
||
/** | ||
* This request header contains the targeted layer's mode. | ||
* Server-side code is free to render different HTML for different modes. | ||
*/ | ||
String getMode() { | ||
getHeaderValue(UP_MODE) | ||
} | ||
|
||
/** | ||
* This request header contains the target selector for a successful fragment update. | ||
*/ | ||
String getTarget() { | ||
getHeaderValue(UP_TARGET) | ||
} | ||
|
||
/** | ||
* The server may set this optional response header to change the document title after a fragment update. | ||
* The title must be encoded as a JSON string. | ||
*/ | ||
String getTitle() { | ||
getHeaderValue(UP_TITLE) | ||
} | ||
|
||
/** | ||
* This request header contains the names of the form fields being validated. | ||
*/ | ||
String getValidate() { | ||
getHeaderValue(UP_VALIDATE) | ||
} | ||
|
||
/** | ||
* This request header contains the current Unpoly version to mark this request as a fragment update. | ||
*/ | ||
String getVersion() { | ||
getHeaderValue(UP_VERSION) | ||
} | ||
|
||
/** | ||
* Get header value from request | ||
* @param The name of header | ||
* @return value | ||
*/ | ||
String getHeaderValue(String name) { | ||
this.request.getHeader(name) | ||
} | ||
|
||
boolean asBoolean() { | ||
getTarget() || getVersion() | ||
} | ||
|
||
} |
98 changes: 98 additions & 0 deletions
98
src/main/groovy/org/graceframework/plugins/unpoly/UnpolyResponse.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
/* | ||
* Copyright 2024 the original author or authors. | ||
* | ||
* Licensed 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 | ||
* | ||
* https://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.graceframework.plugins.unpoly | ||
|
||
import javax.servlet.http.HttpServletResponse | ||
|
||
import groovy.transform.CompileStatic | ||
|
||
import static org.graceframework.plugins.unpoly.UnpolyRequest.* | ||
|
||
/** | ||
* Unpoly Response {link https://unpoly.com/up.protocol} | ||
* | ||
* @author Michael Yan | ||
* @since 0.0.1 | ||
*/ | ||
@CompileStatic | ||
class UnpolyResponse { | ||
|
||
private final HttpServletResponse response | ||
|
||
UnpolyResponse(HttpServletResponse response) { | ||
this.response = response | ||
} | ||
|
||
/** | ||
* The server may set this response header to accept the targeted overlay in response to a fragment update. | ||
* | ||
* @param acceptLayer | ||
*/ | ||
void setAcceptLayer(String acceptLayer) { | ||
setHeaderValue(UP_ACCEPT_LAYER, acceptLayer) | ||
} | ||
|
||
/** | ||
* The server may set this response header to dismiss the targeted overlay in response to a fragment update. | ||
* | ||
* @param dismissLayer | ||
*/ | ||
void setDismissLayer(String dismissLayer) { | ||
setHeaderValue(UP_DISMISS_LAYER, dismissLayer) | ||
} | ||
|
||
/** | ||
* The server may set this response header to emit events with the requested fragment update. | ||
* | ||
* @param events | ||
*/ | ||
void setEvents(String events) { | ||
setHeaderValue(UP_EVENTS, events) | ||
} | ||
|
||
/** | ||
* The server may send this optional response header to control which previously cached responses should be evicted after this response. | ||
* The value of this header is a URL pattern matching responses that should be evicted. | ||
* | ||
* @param evictCache | ||
*/ | ||
void setEvictCache(String evictCache) { | ||
setHeaderValue(UP_EVICT_CACHE, evictCache) | ||
} | ||
|
||
/** | ||
* The server may send this optional response header to control which previously cached responses should be expired after this response. | ||
* The value of this header is a URL pattern matching responses that should be expired. | ||
* | ||
* @param expireCache | ||
*/ | ||
void setExpireCache(String expireCache) { | ||
setHeaderValue(UP_EXPIRE_CACHE, expireCache) | ||
} | ||
|
||
void setLocation(String location) { | ||
setHeaderValue(UP_LOCATION, location) | ||
} | ||
|
||
void setTarget(String target) { | ||
setHeaderValue(UP_TARGET, target) | ||
} | ||
|
||
void setHeaderValue(String name, Object value) { | ||
this.response.setHeader(name, (value == null) ? "" : value.toString()) | ||
} | ||
|
||
} |
3 changes: 3 additions & 0 deletions
3
src/main/resources/META-INF/services/org.codehaus.groovy.runtime.ExtensionModule
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
moduleName=grace-unpoly-module | ||
moduleVersion=1.0 | ||
extensionClasses=org.graceframework.plugins.unpoly.HttpServletRequestExtension,org.graceframework.plugins.unpoly.HttpServletResponseExtension |