TemplateContext.java
/**************************************************************************
*
* Copyright (c) 2016-2020 Yawg project contributors.
*
**************************************************************************/
package com.varmateo.yawg.spi;
/**
* Data available to a template during processing.
*/
public interface TemplateContext {
/**
* The authors of the document. It may be an empty list.
*/
Iterable<Author> authors();
/**
* The raw HTML contents of the baked document. This is actually
* an HTML snippet appropriate for inclusion under a
* <code><body></code> tag, or any other block level
* element.
*/
String body();
/**
* The URL of the page being baked relative to the root directory
* of the site.
*/
String pageUrl();
/**
* Set of variables available to the page template. These
* variables are immutable.
*/
PageVars pageVars();
/**
* The URL of the root directory of the site being baked relative
* to the document about to be baked.
*/
String rootRelativeUrl();
/**
* The title of the document, as extracted from its source.
*/
String title();
/**
* Randomly generated unique bake identifier. Each bake will have
* a different identifier.
*/
String bakeId();
/**
* Document author data.
*/
final class Author {
private final String _name;
private final String _email;
/**
*
*/
private Author(
final String name,
final String email) {
_name = name;
_email = email;
}
/**
*
*/
public static Author create(
final String name,
final String email) {
return new Author(name, email);
}
/**
* @return Author's name. It is never null.
*/
public String name() {
return _name;
}
/**
* @return Author's email. It might be null.
*/
public String email() {
return _email;
}
}
}