All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bsc.mojo.ConfluenceBlogpostMojo Maven / Gradle / Ivy

package org.bsc.mojo;

import com.google.common.io.Files;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.bsc.confluence.ConfluenceService;
import org.bsc.markdown.MarkdownProcessor;
import org.bsc.mojo.configuration.MarkdownProcessorInfo;

import java.io.File;
import java.nio.charset.Charset;
import java.nio.charset.UnsupportedCharsetException;
import java.nio.file.Path;

import static java.lang.String.format;
import static org.bsc.confluence.ConfluenceService.Model;
import static org.bsc.confluence.ConfluenceService.Storage;
import static org.bsc.confluence.FileExtension.*;


/**
 * Publish a an article to the blog
 *
 * @since 6.9-rc1
 */
@Mojo(name = "blogpost", requiresProject = false, threadSafe = true)
public class ConfluenceBlogpostMojo extends AbstractBaseConfluenceMojo {

    /**
     * The file encoding of the source files.
     *
     */
    @Parameter(property = "encoding", defaultValue = "${project.build.sourceEncoding}")
    private String encoding;

    /**
     * Markdown processor Info
*
     *   <markdownProcessor>
     *     <name>processor name</name> <git branch!-- default: pegdown -->
     *   </markdownProcessor>
     * 
* * @since 6.8 */ @Parameter( alias="markdownProcessor" ) private MarkdownProcessorInfo markdownProcessorInfo = new MarkdownProcessorInfo(); /** * * @return */ private final Charset getCharset() { if (encoding == null) { getLog().debug("encoding is null! default charset will be used"); return Charset.defaultCharset(); } try { Charset result = Charset.forName(encoding); return result; } catch (UnsupportedCharsetException e) { getLog().warn(format("encoding [%s] is not valid! default charset will be used", encoding)); return Charset.defaultCharset(); } } @Parameter( property="blog.title" ) private String title; @Parameter( property="blog.content" ) private File content; @Parameter( property="blog.version", defaultValue = "0") private int version; @Override public void execute(ConfluenceService confluenceService) throws Exception { if(title==null) throw new IllegalArgumentException( "blogTitle cannot be null!. Check configuration"); if(content==null) throw new IllegalArgumentException( "blogInfo.content cannot be null!. Check configuration"); if( !content.exists() ) throw new IllegalArgumentException( format("blogContent [%s] doesn't exists!. Check configuration", content) ); if( !content.isFile() ) throw new IllegalArgumentException( format("blogContent [%s] isn't a file!. Check configuration", content) ); final Path path = content.toPath(); final boolean isMarkdown = MARKDOWN.isExentionOf(path); final boolean isStorage = XML.isExentionOf(path) || XHTML.isExentionOf(path); final Storage.Representation representation = ( isStorage ) ? Storage.Representation.STORAGE : Storage.Representation.WIKI; getLog().debug( format("Blog representation = %s", representation )); final String contentData = Files.toString(content, getCharset()); final Storage storage = Storage.of( ( isMarkdown ) ? MarkdownProcessor.shared.load().processMarkdown(contentData) : contentData, representation); final Model.Blogpost blogpost = confluenceService.createBlogpost( getSpaceKey(), title, storage, version); confluenceService.addBlogpost( blogpost ).thenAccept( result -> { getLog().info( format("Blog [%s] succesfully posted!", result.getTitle()) ); }) .join(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy