#TuesPechkin TuesPechkin is a .NET Wrapper for the wkhtmltopdf library.
- It supports .NET 2.0+, 32 and 64-bit processes, and IIS-hosted applications.
- Azure Websites does not currently support the use of wkhtmltopdf.
- It is not tested with any operating systems besides Windows.
- It is available as a NuGet package for your convenience.
- It is built and tested around wkhtmltopdf 0.11.0, 0.12.0, and 0.12.1.
The wkhtmltox.dll file and any dependencies it might have (for older versions, 0.11.0-) are not included in the TuesPechkin NuGet package; however, you can bring your own copy of the library or download one of the following NuGet packages that contain the library:
- TuesPechkin.Wkhtmltox.Win32
- TuesPechkin.Wkhtmltox.Win64
If something doesn't seem right with your converted document, try converting with wkhtmltopdf directly. If you still have the problem, then you will need to take your issue to wkhtmltopdf's issues. Any issues related to visual problems like this will be closed unless the reporter can show that the problem is unique to this library.
Please follow similar guidelines as StackOverflow -- that is, provide any contextual information that you can about your application to help solve the issue.
For 2.0.0 I am wanting to use the 'git flow' style of branching/merging/releasing. If you have a hotfix, please branch off of hotfix. If you are adding something, please branch off of develop. I won't fully re-explain the methodology here.
The API drastically changed once more for 2.0.0 for the sake of modularity and extensibility. Please read the following sections thoroughly.
TuesPechkin exposes an 'IDeployment' interface to represent the folder where wkhtmltox.dll resides. There exists a StaticDeployment
implementation that accepts a string path, and there exists an abstract EmbeddedDeployment
class that can be implemented to automatically deploy the wkhtmltopdf dll(s) wherever you need them.
TuesPechkin exposes an IToolset
interface to represent the wkhtmltopdf library. There are two officially supported implementations:
PdfToolset
: Exposes operations from the library to convert HTML into PDFRemotingToolset<TToolset>
: Manages a toolset of typeTToolset
across an AppDomain boundary. This is necessary for use in IIS-hosted applications.
There is also an abstract class from which you may inherit: NestingToolset
. It provides wrapping functionality that is used by RemotingToolset<TToolset>
.
Feel free to submit a pull request to the develop branch for a ImageToolset
implementation! ;)
TuesPechkin exposes an IConverter
interface. An implementation of IConverter
properly makes all of the calls to wkhtmltopdf to convert an IDocument
instance (which we will cover shortly.) TuesPechkin supplies two implementations:
StandardConverter
: A converter that may be used in single-threaded applicationsThreadSafeConverter
: A converter that manages a single background thread and queues document conversions against it. This is necessary for use in multi-threaded applications, including IIS-hosted applications.
TuesPechkin exposes three interfaces and one attribute that define an HTML document. These are:
WkhtmltoxSettingAttribute
: an attribute for properties that instructs anIConverter
to apply the property's value to the wkhtmltopdf global or object setting with the name passed to the attribute's constructor.ISettings
: a token interface whose implementors are implied to have properties decorated withWkhtmltoxSettingAttribute
and/or otherISettings
properties.IObject
: an interface that represents a wkhtmltopdf 'ObjectSettings'. It requires one method to be implemented:byte[] GetData()
. AllIObject
instances are alsoISettings
instances by inheritance.IDocument
: an interface that represents an HTML document. It requires one method to be implemented:IEnumerable<IObject> GetObjects()
. AllIDocument
instances are alsoISettings
instances by inheritance.
Because TuesPechkin exposes these interfaces/attributes, you are free to write your own implementations that support whichever wkhtmltopdf settings you so desire. If TuesPechkin's included HtmlDocument
class and its related classes do not provide support for a setting you want to use, you may then extend them or create your own classes altogether -- this also goes for use cases where you are only setting a handful of properties and you find the included implementations to be too verbose.
The included HtmlToPdfDocument
class and its related classes do not supply any default values to wkhtmltopdf.
Here is how an IDocument
is to be processed by an IConverter
:
- A wkhtmltopdf 'GlobalSettings' is created for the document.
- The
IDocument
is recursively crawled for allISettings
andWkhtmltoxSettingAttribute
-decorated properties; these properties are applied to the 'GlobalSettings'. - 'GetObjects()' is called on 'IDocument', and for each 'IObject' that is not null, a wkhtmltopdf 'ObjectSettings' is created and that 'IObject' is recursively crawled for all
ISettings
andWkhtmltoxSettingAttribute
-decorated properties; these properties are applied to the 'ObjectSettings'. The 'ObjectSettings' is then added to the converter.
var document = new HtmlToPdfDocument
{
GlobalSettings =
{
ProduceOutline = true,
DocumentTitle = "Pretty Websites",
PaperSize = PaperKind.A4, // Implicit conversion to PechkinPaperSize
Margins =
{
All = 1.375,
Unit = Unit.Centimeters
}
},
Objects = {
new ObjectSettings { HtmlText = "<h1>Pretty Websites</h1><p>This might take a bit to convert!</p>" },
new ObjectSettings { PageUrl = "www.google.com" },
new ObjectSettings { PageUrl = "www.microsoft.com" },
new ObjectSettings { PageUrl = "www.github.com" }
}
};
IConverter converter =
new StandardConverter(
new PdfToolset(
new StaticDeployment(DLL_FOLDER_PATH)));
byte[] result = converter.convert(document);
IConverter converter =
new ThreadSafeConverter(
new PdfToolset(
new StaticDeployment(DLL_FOLDER_PATH)));
// Keep the converter somewhere static, or as a singleton instance!
byte[] result = converter.convert(document);
IConverter converter =
new ThreadSafeConverter(
new RemotingToolset<PdfToolset>(
new StaticDeployment(DLL_FOLDER_PATH)));
// Keep the converter somewhere static, or as a singleton instance!
byte[] result = converter.convert(document);
IConverter converter =
new StandardConverter(
new PdfToolset(
new Win32EmbeddedDeployment(
new StaticDeployment(DLL_FOLDER_PATH))));
byte[] result = converter.convert(document);
This work, "TuesPechkin", is a derivative of "Pechkin" by gmanny (Slava Kolobaev) used under the Creative Commons Attribution 3.0 license. This work is made available under the terms of the Creative Commons Attribution 3.0 license (viewable at http://creativecommons.org/licenses/by/3.0/) by tuespetre (Derek Gray.)