~ubuntu-branches/ubuntu/raring/libitext-java/raring-proposed

« back to all changes in this revision

Viewing changes to core/com/lowagie/tools/EncryptPdf.java

  • Committer: Bazaar Package Importer
  • Author(s): Adriaan Peeters
  • Date: 2008-11-23 12:26:51 UTC
  • mfrom: (5.1.2 sid)
  • Revision ID: james.westby@ubuntu.com-20081123122651-ab7juwjz41q1123k
New upstream release

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * $Id: EncryptPdf.java 3373 2008-05-12 16:21:24Z xlv $
 
3
 *
 
4
 * Copyright 2002 by Paulo Soares
 
5
 *
 
6
 * The contents of this file are subject to the Mozilla Public License Version 1.1
 
7
 * (the "License"); you may not use this file except in compliance with the License.
 
8
 * You may obtain a copy of the License at http://www.mozilla.org/MPL/
 
9
 *
 
10
 * Software distributed under the License is distributed on an "AS IS" basis,
 
11
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 
12
 * for the specific language governing rights and limitations under the License.
 
13
 *
 
14
 * The Original Code is 'iText, a free JAVA-PDF library'.
 
15
 *
 
16
 * The Initial Developer of the Original Code is Bruno Lowagie. Portions created by
 
17
 * the Initial Developer are Copyright (C) 1999-2006 by Bruno Lowagie.
 
18
 * All Rights Reserved.
 
19
 * Co-Developer of the code is Paulo Soares. Portions created by the Co-Developer
 
20
 * are Copyright (C) 2000-2006 by Paulo Soares. All Rights Reserved.
 
21
 *
 
22
 * Contributor(s): all the names of the contributors are added in the source code
 
23
 * where applicable.
 
24
 *
 
25
 * Alternatively, the contents of this file may be used under the terms of the
 
26
 * LGPL license (the "GNU LIBRARY GENERAL PUBLIC LICENSE"), in which case the
 
27
 * provisions of LGPL are applicable instead of those above.  If you wish to
 
28
 * allow use of your version of this file only under the terms of the LGPL
 
29
 * License and not to allow others to use your version of this file under
 
30
 * the MPL, indicate your decision by deleting the provisions above and
 
31
 * replace them with the notice and other provisions required by the LGPL.
 
32
 * If you do not delete the provisions above, a recipient may use your version
 
33
 * of this file under either the MPL or the GNU LIBRARY GENERAL PUBLIC LICENSE.
 
34
 *
 
35
 * This library is free software; you can redistribute it and/or modify it
 
36
 * under the terms of the MPL as stated above or under the terms of the GNU
 
37
 * Library General Public License as published by the Free Software Foundation;
 
38
 * either version 2 of the License, or any later version.
 
39
 *
 
40
 * This library is distributed in the hope that it will be useful, but WITHOUT
 
41
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 
42
 * FOR A PARTICULAR PURPOSE. See the GNU Library general Public License for more
 
43
 * details.
 
44
 *
 
45
 * If you didn't download this code from the following link, you should check if
 
46
 * you aren't using an obsolete version:
 
47
 * http://www.lowagie.com/iText/
 
48
 */
 
49
package com.lowagie.tools;
 
50
 
 
51
import java.io.FileOutputStream;
 
52
import java.util.HashMap;
 
53
 
 
54
import com.lowagie.text.pdf.PdfEncryptor;
 
55
import com.lowagie.text.pdf.PdfReader;
 
56
import com.lowagie.text.pdf.PdfWriter;
 
57
 
 
58
/**
 
59
 * Encrypts a PDF document. It needs iText (http://www.lowagie.com/iText).
 
60
 * @author Paulo Soares (psoares@consiste.pt)
 
61
 * @since 2.1.1 (renamed to follow Java naming conventions)
 
62
 */
 
63
public class EncryptPdf {
 
64
    
 
65
    private final static int INPUT_FILE = 0;
 
66
    private final static int OUTPUT_FILE = 1;
 
67
    private final static int USER_PASSWORD = 2;
 
68
    private final static int OWNER_PASSWORD = 3;
 
69
    private final static int PERMISSIONS = 4;
 
70
    private final static int STRENGTH = 5;
 
71
    private final static int MOREINFO = 6;
 
72
    private final static int permit[] = {
 
73
        PdfWriter.ALLOW_PRINTING,
 
74
        PdfWriter.ALLOW_MODIFY_CONTENTS,
 
75
        PdfWriter.ALLOW_COPY,
 
76
        PdfWriter.ALLOW_MODIFY_ANNOTATIONS,
 
77
        PdfWriter.ALLOW_FILL_IN,
 
78
        PdfWriter.ALLOW_SCREENREADERS,
 
79
        PdfWriter.ALLOW_ASSEMBLY,
 
80
        PdfWriter.ALLOW_DEGRADED_PRINTING};
 
81
 
 
82
    private static void usage() {
 
83
        System.out.println("usage: input_file output_file user_password owner_password permissions 128|40 [new info string pairs]");
 
84
        System.out.println("permissions is 8 digit long 0 or 1. Each digit has a particular security function:");
 
85
        System.out.println();
 
86
        System.out.println("AllowPrinting");
 
87
        System.out.println("AllowModifyContents");
 
88
        System.out.println("AllowCopy");
 
89
        System.out.println("AllowModifyAnnotations");
 
90
        System.out.println("AllowFillIn (128 bit only)");
 
91
        System.out.println("AllowScreenReaders (128 bit only)");
 
92
        System.out.println("AllowAssembly (128 bit only)");
 
93
        System.out.println("AllowDegradedPrinting (128 bit only)");
 
94
        System.out.println("Example permissions to copy and print would be: 10100000");
 
95
    }
 
96
    
 
97
    /**
 
98
     * Encrypts a PDF document.
 
99
     * 
 
100
     * @param args input_file output_file user_password owner_password permissions 128|40 [new info string pairs]
 
101
     */
 
102
    public static void main (String args[]) {
 
103
        System.out.println("PDF document encryptor");
 
104
        if (args.length <= STRENGTH || args[PERMISSIONS].length() != 8) {
 
105
            usage();
 
106
            return;
 
107
        }
 
108
        try {
 
109
            int permissions = 0;
 
110
            String p = args[PERMISSIONS];
 
111
            for (int k = 0; k < p.length(); ++k) {
 
112
                permissions |= (p.charAt(k) == '0' ? 0 : permit[k]);
 
113
            }
 
114
            System.out.println("Reading " + args[INPUT_FILE]);
 
115
            PdfReader reader = new PdfReader(args[INPUT_FILE]);
 
116
            System.out.println("Writing " + args[OUTPUT_FILE]);
 
117
            HashMap moreInfo = new HashMap();
 
118
            for (int k = MOREINFO; k < args.length - 1; k += 2)
 
119
                moreInfo.put(args[k], args[k + 1]);
 
120
            PdfEncryptor.encrypt(reader, new FileOutputStream(args[OUTPUT_FILE]),
 
121
                args[USER_PASSWORD].getBytes(), args[OWNER_PASSWORD].getBytes(), permissions, args[STRENGTH].equals("128"), moreInfo);
 
122
            System.out.println("Done.");
 
123
        }
 
124
        catch (Exception e) {
 
125
            e.printStackTrace();
 
126
        }
 
127
    }
 
128
}
 
 
b'\\ No newline at end of file'