-
Notifications
You must be signed in to change notification settings - Fork 20
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: sign protected pdfs #498
base: main
Are you sure you want to change the base?
Changes from all commits
ff84ad3
6d00beb
84a311f
6eed34d
aad94b7
bb7c5a1
acb36d4
11ef8b9
553dd41
9d07e15
83bd4df
e74a283
065f674
56cc58a
2778cb2
f8a4f77
a8770c1
a8a2b5d
cf8473c
ff4eca7
3c03aef
2940dff
762b7b9
72d3337
39279d1
d6660e1
0a38cb2
1a51bca
d936977
6f99e22
a5d5899
7d94479
1cc94b5
6c15d52
e587086
5a1a71e
0df85f7
b846984
eebceae
5266922
c064992
a0a9e42
b69a83b
577cd03
d230231
10bd450
91dd90d
5b6c2a8
9e84caf
5803279
6b0d033
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,10 +4,12 @@ | |
import digital.slovensko.autogram.core.visualization.DocumentVisualizationBuilder; | ||
import digital.slovensko.autogram.core.visualization.UnsupportedVisualization; | ||
import digital.slovensko.autogram.drivers.TokenDriver; | ||
import digital.slovensko.autogram.model.AutogramDocument; | ||
import digital.slovensko.autogram.ui.BatchUiResult; | ||
import digital.slovensko.autogram.ui.UI; | ||
import digital.slovensko.autogram.util.Logging; | ||
import digital.slovensko.autogram.util.PDFUtils; | ||
import eu.europa.esig.dss.enumerations.SignatureLevel; | ||
import eu.europa.esig.dss.model.DSSException; | ||
import eu.europa.esig.dss.pdfa.PDFAStructureValidator; | ||
import eu.europa.esig.dss.spi.x509.tsp.TSPSource; | ||
|
@@ -56,22 +58,45 @@ public void checkPDFACompliance(SigningJob job) { | |
return; | ||
|
||
ui.onWorkThreadDo(() -> { | ||
// PDF/A doesn't support encryption | ||
if (job.getDocument().hasOpenDocumentPassword()) { | ||
ui.onUIThreadDo(() -> ui.onPDFAComplianceCheckFailed(job)); | ||
return; | ||
} | ||
|
||
var result = new PDFAStructureValidator().validate(job.getDocument()); | ||
if (!result.isCompliant()) { | ||
ui.onUIThreadDo(() -> ui.onPDFAComplianceCheckFailed(job)); | ||
} | ||
}); | ||
} | ||
|
||
public void handleProtectedPdfDocument(AutogramDocument document) { | ||
var protection = PDFUtils.determinePDFProtection(document); | ||
if (protection == PDFUtils.PDFProtection.NONE) | ||
return; | ||
|
||
var password = ui.getDocumentPassword(document); | ||
switch (protection) { | ||
case OPEN_DOCUMENT_PASSWORD -> document.setOpenDocumentPassword(password); | ||
case MASTER_PASSWORD -> document.setMasterPassword(password); | ||
} | ||
} | ||
|
||
public SigningJob buildSigningJobFromFile(File file, Responder responder, boolean checkPDFACompliance, SignatureLevel signatureType, boolean isEn319132, TSPSource tspSource, boolean plainXmlEnabled) { | ||
var document = SigningJob.createDSSFileDocumentFromFile(file); | ||
handleProtectedPdfDocument(document); | ||
|
||
var parameters = SigningJob.getParametersForFile(document, checkPDFACompliance, signatureType, isEn319132, tspSource, plainXmlEnabled); | ||
return SigningJob.build(document, parameters, responder); | ||
} | ||
|
||
public void wrapInWorkThread(Runnable callback) { | ||
ui.onWorkThreadDo(callback); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Toto sa pouziva presne na 1 mieste, cize dajme inline, nijako to nezvysuje prehladnost, skor naopak. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ešte k tomu komentáru vyššie o PDF/A enkrypcií, tak nikdy mi to nešlo a podľa https://en.wikipedia.org/wiki/PDF/A#:~:text=PDF/A%20differs%20from%20PDF%20by%20prohibiting%20features%20unsuitable%20for%20long%2Dterm%20archiving%2C%20such%20as%20font%20linking%20(as%20opposed%20to%20font%20embedding)%20and%20encryption to nie je povolené. Mám to aj tak nechať prejsť kontrolou než to takto okamžite nechať failnúť? |
||
} | ||
|
||
public void startVisualization(SigningJob job) { | ||
ui.onWorkThreadDo(() -> { | ||
if (PDFUtils.isPdfAndPasswordProtected(job.getDocument())) { | ||
ui.onUIThreadDo(() -> { | ||
ui.showError(new AutogramException("Nastala chyba", "Dokument je chránený heslom", "Snažíte sa podpísať dokument chránený heslom, čo je funkcionalita, ktorá nie je podporovaná.\n\nOdstráňte ochranu heslom a potom budete môcť dokument podpísať.")); | ||
}); | ||
return; | ||
} | ||
|
||
try { | ||
var visualization = DocumentVisualizationBuilder.fromJob(job, settings); | ||
ui.onUIThreadDo(() -> ui.showVisualization(visualization, this)); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
package digital.slovensko.autogram.core.errors; | ||
|
||
public class InvalidPasswordException extends AutogramException { | ||
public InvalidPasswordException(String message) { | ||
super("Nesprávne heslo", "Heslo je nesprávne", message); | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
package digital.slovensko.autogram.model; | ||
|
||
import eu.europa.esig.dss.enumerations.DigestAlgorithm; | ||
import eu.europa.esig.dss.enumerations.MimeType; | ||
import eu.europa.esig.dss.model.DSSDocument; | ||
|
||
import java.io.IOException; | ||
import java.io.InputStream; | ||
import java.io.OutputStream; | ||
|
||
public class AutogramDocument implements DSSDocument { | ||
private final DSSDocument document; | ||
|
||
private char[] openDocumentPassword = new char[0]; | ||
private char[] masterPassword = new char[0]; | ||
|
||
public AutogramDocument(DSSDocument document) { | ||
this.document = document; | ||
} | ||
|
||
public boolean hasOpenDocumentPassword() { | ||
return openDocumentPassword.length > 0; | ||
} | ||
|
||
public char[] getOpenDocumentPassword() { | ||
return openDocumentPassword; | ||
} | ||
|
||
public void setOpenDocumentPassword(char[] openDocumentPassword) { | ||
this.openDocumentPassword = openDocumentPassword; | ||
} | ||
|
||
public char[] getMasterPassword() { | ||
return masterPassword; | ||
} | ||
|
||
public void setMasterPassword(char[] masterPassword) { | ||
this.masterPassword = masterPassword; | ||
} | ||
|
||
public char[] getSigningPassword() { | ||
return hasOpenDocumentPassword() ? openDocumentPassword : masterPassword; | ||
} | ||
|
||
@Override | ||
public String getName() { | ||
return document.getName(); | ||
} | ||
|
||
@Override | ||
public void setName(String s) { | ||
document.setName(s); | ||
} | ||
|
||
@Override | ||
public MimeType getMimeType() { | ||
return document.getMimeType(); | ||
} | ||
|
||
@Override | ||
public void setMimeType(MimeType mimeType) { | ||
document.setMimeType(mimeType); | ||
} | ||
|
||
@Override | ||
public void save(String s) throws IOException { | ||
document.save(s); | ||
} | ||
|
||
@Override | ||
public String getDigest(DigestAlgorithm digestAlgorithm) { | ||
return document.getDigest(digestAlgorithm); | ||
} | ||
|
||
@Override | ||
public InputStream openStream() { | ||
return document.openStream(); | ||
} | ||
|
||
@Override | ||
public void writeTo(OutputStream outputStream) throws IOException { | ||
document.writeTo(outputStream); | ||
} | ||
|
||
public DSSDocument getDSSDocument() { | ||
return document; | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ešte uvažujem, či sa neplatí vyrobiť pre tento prípad inú hlášku. Prípadne vedieť do toho
onPDFAComplianceCheckFailed
poslať ešte AutogramException, na základe ktorej sa zobrazí taký alebo onaký text. Totiž, pri tomto hesle má zmysel povedať userovi konkrétne, že nie len že dokument nie je v súlade s PDF/A, ale je to práva preto, že je zaheslovaný.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Urcite ano. Poslime tam
ui.onPDFPasswordProtectedCheck(job)