Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gdelugre/origami
Origami is a pure Ruby library to parse, modify and generate PDF documents.
https://github.com/gdelugre/origami
parser pdf ruby writer
Last synced: 2 days ago
JSON representation
Origami is a pure Ruby library to parse, modify and generate PDF documents.
- Host: GitHub
- URL: https://github.com/gdelugre/origami
- Owner: gdelugre
- License: lgpl-3.0
- Created: 2016-08-19T12:32:55.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-02-21T14:51:50.000Z (almost 2 years ago)
- Last Synced: 2024-04-26T09:46:31.720Z (9 months ago)
- Topics: parser, pdf, ruby, writer
- Language: Ruby
- Size: 567 KB
- Stars: 309
- Watchers: 17
- Forks: 112
- Open Issues: 40
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: COPYING.LESSER
Awesome Lists containing this project
README
Origami
=====
[![Gem Version](https://badge.fury.io/rb/origami.svg)](https://rubygems.org/gems/origami)
[![Downloads](https://img.shields.io/gem/dt/origami.svg)](https://rubygems.org/gems/origami)
[![Build Status](https://secure.travis-ci.org/gdelugre/origami.svg?branch=master)](https://travis-ci.org/gdelugre/origami)
[![License: LGPL v3](https://img.shields.io/badge/License-LGPL%20v3-blue.svg)](https://www.gnu.org/licenses/lgpl-3.0)Overview
--------Origami is a framework written in pure Ruby to manipulate PDF files.
It offers the possibility to parse the PDF contents, modify and save the PDF
structure, as well as creating new documents.Origami supports some advanced features of the PDF specification:
* Compression filters with predictor functions
* Encryption using RC4 or AES, including the undocumented Revision 6 derivation algorithm
* Digital signatures and Usage Rights
* File attachments
* AcroForm and XFA forms
* Object streamsOrigami is able to parse PDF, FDF and PPKLite (Adobe certificate store) files.
Requirements
------------As of version 2, the minimal version required to run Origami is Ruby 2.1.
Some optional features require additional gems:
* [therubyracer][the-ruby-racer] for JavaScript emulation of PDF scripts
Quick start
-----------First install Origami using the latest gem available:
$ gem install origami
Then import Origami with:
```ruby
require 'origami'
```To process a PDF document, you can use the ``PDF.read`` method:
```ruby
pdf = Origami::PDF.read "something.pdf"puts "This document has #{pdf.pages.size} page(s)"
```The default behavior is to parse the entire contents of the document at once. This can be changed by passing the ``lazy`` flag to parse objects on demand.
```ruby
pdf = Origami::PDF.read "something.pdf", lazy: truepdf.each_page do |page|
page.each_font do |name, font|
# ... only parse the necessary bits
end
end
```You can also create documents directly by instanciating a new PDF object:
```ruby
pdf = Origami::PDF.newpdf.append_page
pdf.pages.first.write "Hello", size: 30pdf.save("example.pdf")
# Another way of doing it
Origami::PDF.write("example.pdf") do |pdf|
pdf.append_page do |page|
page.write "Hello", size: 30
end
end
```Take a look at the [examples](examples) and [bin](bin) directories for some examples of advanced usage.
Tools
-----Origami comes with a set of tools to manipulate PDF documents from the command line.
* [pdfcop](bin/pdfcop): Runs some heuristic checks to detect dangerous contents.
* [pdfdecompress](bin/pdfdecompress): Strips compression filters out of a document.
* [pdfdecrypt](bin/pdfdecrypt): Removes encrypted contents from a document.
* [pdfencrypt](bin/pdfencrypt): Encrypts a PDF document.
* [pdfexplode](bin/pdfexplode): Explodes a document into several documents, each of them having one deleted resource. Useful for reduction of crash cases after a fuzzing session.
* [pdfextract](bin/pdfextract): Extracts binary resources of a document (images, scripts, fonts, etc.).
* [pdfmetadata](bin/pdfmetadata): Displays the metadata contained in a document.
* [pdf2ruby](bin/pdf2ruby): Converts a PDF into an Origami script rebuilding an equivalent document (experimental).
* [pdfsh](bin/pdfsh): An IRB shell running inside the Origami namespace.**Note**: Since version 2.1, [pdfwalker][pdfwalker-gem] has been moved to a [separate repository][pdfwalker-repo].
License
-------Origami is distributed under the [LGPL](COPYING.LESSER) license.
Copyright © 2019 Guillaume Delugré.
[the-ruby-racer]: https://rubygems.org/gems/therubyracer
[pdfwalker-gem]: https://rubygems.org/gems/pdfwalker
[pdfwalker-repo]: https://github.com/gdelugre/pdfwalker