Warning! This documentation is a work in progress. Expect things to be out of date and not actually work according to instructions.
Defining RESTful HTTP Endpoints
View an HTML endpoint:
var endpoints: {
viewChapter: {
route: '/book/:bookId/:chapterId', // Use ":name" to indicate dynamic route parameters
params: [stallion.pathParam('bookId'), stallion.pathParam('chapterId')],
handler: function(bookId, chapterId) {
var ctx = {bookId: bookId, chapterId: chapterId};
return myContext.renderTemplate("book-chapter.jinja", ctx);
}
}
};
stallion.registerEndpoints(endpoints);
import static io.stallion.Literals.*;
public class BooksEndpoints {
@GET // HTTP methods, alternatives are @GET, @PUT, @DELETE
@Path("/book/:bookId/:chapterId") // A colon indicates named dynamics parameters
public String viewChapter(@PathParam Long bookId, @PathParam Long chapterId) {
Map ctx = map(val("bookId", bookId), val("chapterId", chapterId));
return TemplateRenderer.instance().renderTemplate("book-chapter.jinja", ctx);
}
}
/// Register the endpoints in the boot function of your plugin
public void boot() {
EndpointsRegistry.instance().addResource("/api/books", new BooksEndpoints());
}
Simple endpoint to retrieve an object:
var endpoints: {
getBook: {
route: '/book/:bookId/*', // Use ":name" to indicate dynamic route parameters
produces: 'application/json', // By default, "text/html",
params: [stallion.pathParam('bookId')],
handler: function(bookId) {
var book = myContext.dal.books.forId(bookId);
if (!book) {
stallion.raiseNotFound("Could not find book for id " + bookId);
}
return book;
}
}
};
@POST // HTTP methods, alternatives are @GET, @PUT, @DELETE
@Path("/book/:bookId") // A colon indicates named dynamics parameters
@Produces("application/json")
public Book getBook(@PathParam Long bookId) {
Book book = BooksController.instance().forId(bookId);
if (book == null) {
throw new NotFoundException("Book not found for id " + bookid);
}
return book;
}
Here is an endpoint with all possible options defined:
var endpoints: {
completeRoute: {
route: '/book/:bookId/*', // Use ":name" to indicate dynamic route parameters
produces: 'application/json', // By default, "text/html",
method: "POST", // The HTTP method for this route, default is GET
role: 'staff', // 'anon' is the default, and means any non-logged in user can access the page.
/* "params" represents parameters extracted from the request and
passed to the handler function. The order of arguments in the handler
function will be the order defined in this array.
*/
params: [
stallion.longParam("bookId"), // Take the parameter from the route named bookId
stallion.queryParam("previewMode")], // a query string value
stallion.bodyParam("newTitle"), // a key/value param from the JSON POST body
stallion.mapParam() // The entire POST body as a Map.
],
handler: function(bookId, preview, title, extra) {
return {
bookId: bookId,
newTitle: title,
extra: extra,
previewMode: preview
}
}
}
}
@POST // HTTP methods, alternatives are @GET, @PUT, @DELETE
@Path("/book/:bookId/*slug") // A colon indicates named dynamics parameters
@Produces("application/json") // The content-type of the response, return "text/html" for web pages
@JsonView(RestrictedViews.Owner.class) // Restricts which fields get serialized to JSON
@MinRole(Roles.STAFF) // The minimum role required to view this endpoint, use Roles.ANON for a public endpoint
public Object bookRoute(@PathParam Long bookId, @QueryParam Boolean previewMode, @BodyParam("newTitle") String newTitle) {
Map data = new HashMap<>();
data.put("bookId", bookId);
data.put("newTitle", title);
data.put("extra", extra);
data.put("previewMode", preview);
return data;
}
© 2025 Stallion Software LLC