KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > apache > poi > hssf > record > PasswordRev4Record


1
2 /* ====================================================================
3    Copyright 2002-2004 Apache Software Foundation
4
5    Licensed under the Apache License, Version 2.0 (the "License");
6    you may not use this file except in compliance with the License.
7    You may obtain a copy of the License at
8
9        http://www.apache.org/licenses/LICENSE-2.0
10
11    Unless required by applicable law or agreed to in writing, software
12    distributed under the License is distributed on an "AS IS" BASIS,
13    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14    See the License for the specific language governing permissions and
15    limitations under the License.
16 ==================================================================== */

17         
18
19 package org.apache.poi.hssf.record;
20
21 import org.apache.poi.util.LittleEndian;
22
23 /**
24  * Title: Protection Revision 4 password Record<P>
25  * Description: Stores the (2 byte??!!) encrypted password for a shared
26  * workbook<P>
27  * REFERENCE: PG 374 Microsoft Excel 97 Developer's Kit (ISBN: 1-57231-498-2)<P>
28  * @author Andrew C. Oliver (acoliver at apache dot org)
29  * @version 2.0-pre
30  */

31
32 public class PasswordRev4Record
33     extends Record
34 {
35     public final static short sid = 0x1BC;
36     private short field_1_password;
37
38     public PasswordRev4Record()
39     {
40     }
41
42     /**
43      * Constructs a PasswordRev4 (PROT4REVPASS) record and sets its fields appropriately.
44      *
45      * @param id id must be 0x1bc or an exception will be throw upon validation
46      * @param size the size of the data area of the record
47      * @param data data of the record (should not contain sid/len)
48      */

49
50     public PasswordRev4Record(short id, short size, byte [] data)
51     {
52         super(id, size, data);
53     }
54
55     /**
56      * Constructs a PasswordRev4 (PROT4REVPASS) record and sets its fields appropriately.
57      *
58      * @param id id must be 0x1bc or an exception will be throw upon validation
59      * @param size the size of the data area of the record
60      * @param data data of the record (should not contain sid/len)
61      * @param offset of the data
62      */

63
64     public PasswordRev4Record(short id, short size, byte [] data, int offset)
65     {
66         super(id, size, data, offset);
67     }
68
69     protected void validateSid(short id)
70     {
71         if (id != sid)
72         {
73             throw new RecordFormatException("NOT A PROT4REVPASSWORD RECORD");
74         }
75     }
76
77     protected void fillFields(byte [] data, short size, int offset)
78     {
79         field_1_password = LittleEndian.getShort(data, 0 + offset);
80     }
81
82     /**
83      * set the password
84      *
85      * @param pw representing the password
86      */

87
88     public void setPassword(short pw)
89     {
90         field_1_password = pw;
91     }
92
93     /**
94      * get the password
95      *
96      * @return short representing the password
97      */

98
99     public short getPassword()
100     {
101         return field_1_password;
102     }
103
104     public String JavaDoc toString()
105     {
106         StringBuffer JavaDoc buffer = new StringBuffer JavaDoc();
107
108         buffer.append("[PROT4REVPASSWORD]\n");
109         buffer.append(" .password = ")
110             .append(Integer.toHexString(getPassword())).append("\n");
111         buffer.append("[/PROT4REVPASSWORD]\n");
112         return buffer.toString();
113     }
114
115     public int serialize(int offset, byte [] data)
116     {
117         LittleEndian.putShort(data, 0 + offset, sid);
118         LittleEndian.putShort(data, 2 + offset,
119                               (( short ) 0x02)); // 2 bytes (6 total)
120
LittleEndian.putShort(data, 4 + offset, getPassword());
121         return getRecordSize();
122     }
123
124     public int getRecordSize()
125     {
126         return 6;
127     }
128
129     public short getSid()
130     {
131         return this.sid;
132     }
133 }
134
Popular Tags