made it work
This commit is contained in:
parent
8978c7ae4c
commit
b6031b93e6
7 changed files with 113 additions and 101 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -35,4 +35,5 @@ build/
|
||||||
.vscode/
|
.vscode/
|
||||||
|
|
||||||
### Mac OS ###
|
### Mac OS ###
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
/m724/
|
||||||
|
|
7
pom.xml
7
pom.xml
|
@ -12,6 +12,7 @@
|
||||||
<maven.compiler.source>21</maven.compiler.source>
|
<maven.compiler.source>21</maven.compiler.source>
|
||||||
<maven.compiler.target>21</maven.compiler.target>
|
<maven.compiler.target>21</maven.compiler.target>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
<exec.mainClass>eu.m724.blog.Main</exec.mainClass>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
@ -26,9 +27,9 @@
|
||||||
<version>7.1.0.202411261347-r</version>
|
<version>7.1.0.202411261347-r</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.hubspot.jinjava</groupId>
|
<groupId>io.pebbletemplates</groupId>
|
||||||
<artifactId>jinjava</artifactId>
|
<artifactId>pebble</artifactId>
|
||||||
<version>2.7.4</version>
|
<version>3.2.2</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.google.code.gson</groupId>
|
<groupId>com.google.code.gson</groupId>
|
||||||
|
|
|
@ -1,45 +1,89 @@
|
||||||
package eu.m724.blog;
|
package eu.m724.blog;
|
||||||
|
|
||||||
import org.apache.commons.io.FileUtils;
|
import eu.m724.blog.data.Post;
|
||||||
|
import eu.m724.blog.data.Site;
|
||||||
|
import eu.m724.blog.data.Template;
|
||||||
|
import org.apache.commons.io.file.PathUtils;
|
||||||
import org.eclipse.jgit.api.Git;
|
import org.eclipse.jgit.api.Git;
|
||||||
import org.eclipse.jgit.lib.RepositoryBuilder;
|
import org.eclipse.jgit.lib.RepositoryBuilder;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.FileAlreadyExistsException;
|
import java.nio.file.FileAlreadyExistsException;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
public class Main {
|
public class Main {
|
||||||
public static void main(String[] args) throws IOException {
|
public static void main(String[] args) throws IOException {
|
||||||
System.out.println("Hello world!");
|
System.out.println("Hello world!");
|
||||||
|
|
||||||
var workingDirectory = new File("m724");
|
var workingDirectory = Path.of("m724");
|
||||||
var templateDirectory = new File(workingDirectory, "template");
|
var templateDirectory = workingDirectory.resolve("template");
|
||||||
var outputDirectory = new File(workingDirectory, "generated_out");
|
var outputDirectory = workingDirectory.resolve("generated_out");
|
||||||
var force = true;
|
var force = true;
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
var repository = new RepositoryBuilder()
|
var repository = new RepositoryBuilder()
|
||||||
.setGitDir(workingDirectory)
|
.setGitDir(workingDirectory.toFile())
|
||||||
.build();
|
.build();
|
||||||
var git = new Git(repository);
|
var git = new Git(repository);
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
if (outputDirectory.exists()) {
|
if (outputDirectory.toFile().exists()) {
|
||||||
if (force) {
|
if (force) {
|
||||||
outputDirectory.delete();
|
PathUtils.deleteDirectory(outputDirectory);
|
||||||
} else {
|
} else {
|
||||||
throw new FileAlreadyExistsException(outputDirectory.getAbsolutePath(), null, "Output directory already exists");
|
throw new FileAlreadyExistsException(outputDirectory.toString(), null, "Output directory already exists");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
outputDirectory.mkdir();
|
var site = Site.fromConfig(git);
|
||||||
FileUtils.copyDirectory(new File(workingDirectory, "assets"), new File(outputDirectory, "assets"));
|
var template = new Template(templateDirectory);
|
||||||
FileUtils.copyDirectory(new File(templateDirectory, "static"), new File(outputDirectory, "static"));
|
|
||||||
|
Files.createDirectory(outputDirectory);
|
||||||
|
|
||||||
|
copyIfExists(workingDirectory.resolve("assets"), outputDirectory.resolve("assets"));
|
||||||
|
copyIfExists(templateDirectory.resolve("static"), outputDirectory.resolve("static"));
|
||||||
|
|
||||||
|
Files.createDirectory(outputDirectory.resolve("post"));
|
||||||
|
var postDirectory = workingDirectory.resolve("posts");
|
||||||
|
try (var stream = Files.walk(postDirectory)) {
|
||||||
|
for (var path : stream.collect(Collectors.toSet())) {
|
||||||
|
if (!Files.isRegularFile(path)) continue;
|
||||||
|
|
||||||
|
if (!path.toString().endsWith(".html")) {
|
||||||
|
System.out.println("Post " + path.getFileName() + ": unsupported file type");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
path = postDirectory.relativize(path);
|
||||||
|
var post = Post.fromFile(git, path);
|
||||||
|
|
||||||
|
var render = template.renderPost(site, post);
|
||||||
|
var outFile = outputDirectory.resolve("post").resolve(path);
|
||||||
|
|
||||||
|
try {
|
||||||
|
Files.createDirectory(outFile.getParent());
|
||||||
|
} catch (FileAlreadyExistsException e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Files.writeString(outFile, render);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static void copyIfExists(Path src, Path dest) throws IOException {
|
||||||
|
System.out.print(src);
|
||||||
|
|
||||||
|
if (Files.exists(src)) {
|
||||||
|
PathUtils.copyDirectory(src, dest);
|
||||||
|
System.out.println(" copied");
|
||||||
|
} else {
|
||||||
|
System.out.println(" doesn't exist, not copying");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,28 +0,0 @@
|
||||||
package eu.m724.blog;
|
|
||||||
|
|
||||||
import com.google.common.io.Resources;
|
|
||||||
import com.hubspot.jinjava.Jinjava;
|
|
||||||
import eu.m724.blog.data.Site;
|
|
||||||
import org.apache.commons.net.nntp.Article;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class Renderer {
|
|
||||||
private final
|
|
||||||
|
|
||||||
public void renderIndex(Site site, Article... articles) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void renderArticle(Site site, Article article) {
|
|
||||||
Jinjava jinjava = new Jinjava();
|
|
||||||
Map<String, Object> context = Map.of(
|
|
||||||
"site", site,
|
|
||||||
"article", article
|
|
||||||
);
|
|
||||||
|
|
||||||
String template = Resources.toString(Resources.getResource("my-template.html"), Charsets.UTF_8);
|
|
||||||
|
|
||||||
return jinjava.render(template, context);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,25 +0,0 @@
|
||||||
package eu.m724.blog;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.nio.file.Files;
|
|
||||||
import java.nio.file.Path;
|
|
||||||
|
|
||||||
public class Template {
|
|
||||||
private final Path templateDirectory;
|
|
||||||
|
|
||||||
public Template(Path templateDirectory) {
|
|
||||||
this.templateDirectory = templateDirectory;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String postTemplate() throws IOException {
|
|
||||||
return Files.readString(templateDirectory.resolve("article_template.html"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public String indexTemplate() throws IOException {
|
|
||||||
return Files.readString(templateDirectory.resolve("index.html"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void copyStatic() {
|
|
||||||
templateDirectory.resolve("static").co
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,13 +1,11 @@
|
||||||
package eu.m724.blog.data;
|
package eu.m724.blog.data;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
|
||||||
import com.google.common.io.Resources;
|
|
||||||
import com.hubspot.jinjava.Jinjava;
|
|
||||||
import org.eclipse.jgit.api.Git;
|
import org.eclipse.jgit.api.Git;
|
||||||
import org.eclipse.jgit.api.errors.GitAPIException;
|
import org.eclipse.jgit.api.errors.GitAPIException;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
import java.time.*;
|
import java.time.*;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -24,29 +22,20 @@ public record Post(
|
||||||
String modifiedBy,
|
String modifiedBy,
|
||||||
ZonedDateTime modifiedAt,
|
ZonedDateTime modifiedAt,
|
||||||
|
|
||||||
Map<String, String> customProperties,
|
Map<String, String> custom,
|
||||||
String rawContent
|
String rawContent
|
||||||
) {
|
) {
|
||||||
public String renderHtml(String template) {
|
|
||||||
Jinjava jinjava = new Jinjava();
|
|
||||||
|
|
||||||
Map<String, Object> context = Map.of(
|
|
||||||
"article", this
|
|
||||||
)
|
|
||||||
|
|
||||||
return jinjava.render(template, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getHtmlContent() {
|
public String getHtmlContent() {
|
||||||
return rawContent;
|
return rawContent;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Post fromFile(Git git, String slug) throws IOException {
|
public static Post fromFile(Git git, Path path) throws IOException {
|
||||||
/* read properties before filtering */
|
/* read properties before filtering */
|
||||||
|
|
||||||
var properties = new HashMap<String, String>();
|
var slug = path.getFileName().toString().split("\\.")[0];
|
||||||
|
var lines = Files.readAllLines(git.getRepository().getDirectory().toPath().resolve("posts").resolve(path));
|
||||||
|
|
||||||
var lines = Files.readAllLines(new File(git.getRepository().getDirectory(), "archive/" + slug + ".html").toPath());
|
var properties = new HashMap<String, String>();
|
||||||
|
|
||||||
String line;
|
String line;
|
||||||
while ((line = lines.removeFirst()) != null) {
|
while ((line = lines.removeFirst()) != null) {
|
||||||
|
@ -59,7 +48,7 @@ public record Post(
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (properties.putIfAbsent(key, data) != null)
|
if (properties.putIfAbsent(key, data) != null)
|
||||||
System.out.printf("%s: Duplicate property \"%s\". Only the first one will be used.\n", slug, key);
|
System.out.printf("Post %s: Duplicate property \"%s\". Only the first one will be used.\n", slug, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
var content = String.join("\n", lines).strip();
|
var content = String.join("\n", lines).strip();
|
||||||
|
@ -99,7 +88,7 @@ public record Post(
|
||||||
ZonedDateTime modifiedAt = null;
|
ZonedDateTime modifiedAt = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
var commits = git.log().addPath("archive/" + slug + ".html").call().iterator();
|
var commits = git.log().addPath("posts/" + slug + ".html").call().iterator();
|
||||||
|
|
||||||
while (commits.hasNext()) {
|
while (commits.hasNext()) {
|
||||||
var commit = commits.next();
|
var commit = commits.next();
|
||||||
|
|
|
@ -1,23 +1,53 @@
|
||||||
package eu.m724.blog.data;
|
package eu.m724.blog.data;
|
||||||
|
|
||||||
import com.google.gson.Gson;
|
import io.pebbletemplates.pebble.PebbleEngine;
|
||||||
import com.google.gson.JsonObject;
|
import io.pebbletemplates.pebble.loader.FileLoader;
|
||||||
|
import io.pebbletemplates.pebble.template.PebbleTemplate;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.file.Files;
|
import java.io.StringWriter;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
public record Template(
|
public class Template {
|
||||||
String name,
|
private final PebbleEngine pebbleEngine;
|
||||||
int version,
|
|
||||||
|
|
||||||
int articlesPerPage,
|
private final PebbleTemplate indexTemplate, articleTemplate;
|
||||||
|
|
||||||
JsonObject customProperties
|
public Template(Path directory) {
|
||||||
) {
|
var loader = new FileLoader();
|
||||||
public static Template fromDirectory(Path templateDirectory) throws IOException {
|
loader.setPrefix(directory.toString());
|
||||||
var content = Files.readString(templateDirectory.resolve("template.json"));
|
loader.setSuffix(".html");
|
||||||
|
|
||||||
return new Gson().fromJson(content, Template.class);
|
this.pebbleEngine = new PebbleEngine.Builder()
|
||||||
|
.loader(loader)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
this.indexTemplate = pebbleEngine.getTemplate("index_template");
|
||||||
|
this.articleTemplate = pebbleEngine.getTemplate("article_template");
|
||||||
|
}
|
||||||
|
|
||||||
|
public String renderIndex(Site site, Post... posts) throws IOException {
|
||||||
|
Map<String, Object> context = Map.of(
|
||||||
|
"site", site,
|
||||||
|
"articles", posts
|
||||||
|
);
|
||||||
|
|
||||||
|
var writer = new StringWriter();
|
||||||
|
indexTemplate.evaluate(writer, context);
|
||||||
|
|
||||||
|
return writer.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String renderPost(Site site, Post post) throws IOException {
|
||||||
|
Map<String, Object> context = Map.of(
|
||||||
|
"site", site,
|
||||||
|
"article", post
|
||||||
|
);
|
||||||
|
|
||||||
|
var writer = new StringWriter();
|
||||||
|
articleTemplate.evaluate(writer, context);
|
||||||
|
|
||||||
|
return writer.toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue