signature.dart
2.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
* Copyright (C) 2017, David PHAM-VAN <dev.nfet.net@gmail.com>
*
* Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import 'dart:typed_data';
import '../data_types.dart';
import '../document.dart';
import '../stream.dart';
import 'object.dart';
import 'object_dict.dart';
import 'object_stream.dart';
/// Signature flags
enum PdfSigFlags {
/// The document contains at least one signature field.
signaturesExist,
/// The document contains signatures that may be invalidated if the file is
/// saved (written) in a way that alters its previous contents, as opposed
/// to an incremental update.
appendOnly,
}
class PdfSignature extends PdfObjectDict {
PdfSignature(
PdfDocument pdfDocument, {
required this.value,
required this.flags,
List<Uint8List>? crl,
List<Uint8List>? cert,
List<Uint8List>? ocsp,
}) : super(pdfDocument, type: '/Sig') {
if (crl != null) {
for (final o in crl) {
this.crl.add(PdfObjectStream(pdfDocument)..buf.putBytes(o));
}
}
if (cert != null) {
for (final o in cert) {
this.cert.add(PdfObjectStream(pdfDocument)..buf.putBytes(o));
}
}
if (ocsp != null) {
for (final o in ocsp) {
this.ocsp.add(PdfObjectStream(pdfDocument)..buf.putBytes(o));
}
}
}
final Set<PdfSigFlags> flags;
final PdfSignatureBase value;
int get flagsValue => flags.isEmpty
? 0
: flags
.map<int>((PdfSigFlags e) => 1 << e.index)
.reduce((int a, int b) => a | b);
final crl = <PdfObjectStream>[];
final cert = <PdfObjectStream>[];
final ocsp = <PdfObjectStream>[];
int? _offsetStart;
int? _offsetEnd;
@override
void write(PdfStream os) {
value.preSign(this, params);
_offsetStart = os.offset + '$objser $objgen obj\n'.length;
super.write(os);
_offsetEnd = os.offset;
}
Future<void> writeSignature(PdfStream os) async {
assert(_offsetStart != null && _offsetEnd != null,
'Must reserve the object space before signing the document');
await value.sign(this, os, params, _offsetStart, _offsetEnd);
}
}
abstract class PdfSignatureBase {
/// Modification detection and prevention
bool get hasMDP => false;
void preSign(PdfObject object, PdfDict params);
Future<void> sign(PdfObject object, PdfStream os, PdfDict params,
int? offsetStart, int? offsetEnd);
}