Skip to content
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

Can it be possible to trust a certificate like in acrobat? #161

Open
IDontKnow2Code opened this issue Jan 29, 2024 · 57 comments
Open

Can it be possible to trust a certificate like in acrobat? #161

IDontKnow2Code opened this issue Jan 29, 2024 · 57 comments

Comments

@IDontKnow2Code
Copy link

IDontKnow2Code commented Jan 29, 2024

Here is the reference for what I am asking?
Validity-Unknown-in-Aadhaar-Card-when-it-is-not-Verified.png

Validate-E-Aadhaar-Card-Signature-after-Downloading.gif

Validated-Aadhaar-Card-Sign-after-Validating-Aadhaar-Card.png

@JakubMelka
Copy link
Owner

Hello, I have fixed it. Now, you can just open context menu and add the certificate as valid.

@IDontKnow2Code
Copy link
Author

It still shows not trusted and no green - tick either but certificate did get add to trusted store.
pic-selected-240206-2035-30.png

pic-selected-240206-2036-04.png

@JakubMelka
Copy link
Owner

Strange, it worked for me. Could you please provide sample document, where it does not work?

@IDontKnow2Code
Copy link
Author

IDontKnow2Code commented Feb 9, 2024

Strange, it worked for me. Could you please provide sample document, where it does not work?

Unfortunately, I can't provide it. It is a government issued document. I don't know where to get similar dummy document. My search about that document show that it's certificate is x.509 certificate, they generate it with iTextPDF
The document is called Aadhar card.

@itsKV
Copy link

itsKV commented Jun 26, 2024

Hello, I have fixed it. Now, you can just open context menu and add the certificate as valid.

@JakubMelka Would you plz explain how to do this? I couldn't find the context menu as no menu gets open on right click.

@JakubMelka
Copy link
Owner

@itsKV, please try this:
image

@itsKV
Copy link

itsKV commented Jun 28, 2024

Sorry to say but that context menu doesn't come on any of the field from signature sidebar content. Nothing happens when you right click on any of them.
image

This also happens for Actual PDF content too. Nothing happens when you right click or left click anywhere on the pdf content. I don't know if that's the normal behavior.

@JakubMelka
Copy link
Owner

Could you please try a newest install from daily build? Could you please attach problematic PDF, if it is possible?

@itsKV
Copy link

itsKV commented Jul 1, 2024

I am not installing the build but using the zip version by extracting it locally (no admin rights to install).
I can't share the pdf because the file is itself a critical document (analogues to your social security number SSN document)
However, I can post issuer's chained certificates if you ask.

image

@JakubMelka
Copy link
Owner

OK @itsKV , if you can post the certificates, please post them.

@itsKV
Copy link

itsKV commented Jul 1, 2024

Complete chain of trust is as follows. Read from bottom to top where root CA is at last and so on.

-----BEGIN CERTIFICATE-----
MIIHCjCCBfKgAwIBAgIEYklh9TANBgkqhkiG9w0BAQsFADCBkTELMAkGA1UEBhMC
SU4xQTA/BgNVBAoTOEd1amFyYXQgTmFybWFkYSBWYWxsZXkgRmVydGlsaXplcnMg
YW5kIENoZW1pY2FscyBMaW1pdGVkMQ8wDQYDVQQLEwZTdWItQ0ExLjAsBgNVBAMT
JShuKUNvZGUgU29sdXRpb25zIFN1Yi1DQSBmb3IgRFNDIDIwMjIwHhcNMjQwMjIx
MTIyMzE5WhcNMjYwMjE2MjIyNzQwWjCB8zELMAkGA1UEBhMCSU4xMTAvBgNVBAoT
KFVOSVFVRSBJREVOVElGSUNBVElPTiBBVVRIT1JJVFkgT0YgSU5ESUExDzANBgNV
BBETBjExMDAwMTEOMAwGA1UECBMFRGVsaGkxODA2BgNVBAkTL0JhbmdsYSBTYWhp
YiBSb2FkIEJlaGluZCBLYWxpIE1hbmRpciBHb2xlTWFya2V0MR0wGwYDVQQzExRB
YWRoYWFyIEhlYWRxdWFydGVyczE3MDUGA1UEAxMuRFMgVW5pcXVlIElkZW50aWZp
Y2F0aW9uIEF1dGhvcml0eSBvZiBJbmRpYSAwNTCCASIwDQYJKoZIhvcNAQEBBQAD
ggEPADCCAQoCggEBAJjCCSo9vCXEzdQe9qdv6YMwwqILobP62yF4Df8mzTYdDVTq
2VdipZa5k+VTmJTKwAabyKeyVP5+oZmt/zteJ+5754Cf8t3KJYfK5O5rA8FQDu2b
lQ/hgs32mDyy5FEvsKh+zOxThyJ/6ciaNUZMZvfJTt3cqMeUbixtlKpuyX1SKJpt
Le0CiaDOa3/CTbz13cLMTfPXlpU9gX+wRf/xtxSohe2R37yMsqrXv96K0URvzPNE
Ki6wz9USHjmud2U4CC13MkDm9smTqjR94jdrkikbLrDTte06ORTm9ifR3ecCDLg7
988ODFk6ygFrk2KJ/dEEnhkSr9XeQEDUbdMeXUsCAwEAAaOCAwQwggMAMA4GA1Ud
DwEB/wQEAwIGwDAqBgNVHSUEIzAhBggrBgEFBQcDBAYKKwYBBAGCNwoDDAYJKoZI
hvcvAQEFMIIBAgYDVR0gBIH6MIH3MIGGBgZggmRkAgIwfDB6BggrBgEFBQcCAjBu
DGxDbGFzcyAyIGNlcnRpZmljYXRlcyBhcmUgdXNlZCBmb3IgZm9ybSBzaWduaW5n
LCBmb3JtIGF1dGhlbnRpY2F0aW9uIGFuZCBzaWduaW5nIG90aGVyIGxvdyByaXNr
IHRyYW5zYWN0aW9ucy4wbAYGYIJkZAoBMGIwYAYIKwYBBQUHAgIwVAxSVGhpcyBj
ZXJ0aWZpY2F0ZSBwcm92aWRlcyBoaWdoZXIgbGV2ZWwgb2YgYXNzdXJhbmNlIGZv
ciBkb2N1bWVudCBzaWduaW5nIGZ1bmN0aW9uLjAMBgNVHRMBAf8EAjAAMCIGA1Ud
EQQbMBmBF2Rpci5sY2ktaHFAdWlkYWkubmV0LmluMIIBAAYDVR0fBIH4MIH1MEKg
QKA+hjxodHRwOi8vd3d3Lm5jb2Rlc29sdXRpb25zLmNvbS9yZXBvc2l0b3J5L25j
b2RlY2EyMnN1YmNhMS5jcmwwga6ggauggaikgaUwgaIxCzAJBgNVBAYTAklOMUEw
PwYDVQQKEzhHdWphcmF0IE5hcm1hZGEgVmFsbGV5IEZlcnRpbGl6ZXJzIGFuZCBD
aGVtaWNhbHMgTGltaXRlZDEPMA0GA1UECxMGU3ViLUNBMS4wLAYDVQQDEyUobilD
b2RlIFNvbHV0aW9ucyBTdWItQ0EgZm9yIERTQyAyMDIyMQ8wDQYDVQQDEwZDUkwx
ODMwKwYDVR0QBCQwIoAPMjAyNDAyMjExMjIzMTlagQ8yMDI2MDIxNjIyMjc0MFow
HwYDVR0jBBgwFoAURsE2obZEOWzewDFm8UhoheJjvzswHQYDVR0OBBYEFKzhXAem
Tyikhe8ZRfMcBEnWfEfTMBkGCSqGSIb2fQdBAAQMMAobBFY4LjMDAgMoMA0GCSqG
SIb3DQEBCwUAA4IBAQAw7POBP18z1+IG4bjBk6vgfIyTH6Vz+e1j7jcmG+sUfY0E
GVKonznB87M4hNcVcylDrwZscJwZxKaYUAt/q1Uph46v37jRjZyAvawZBD/oL1lS
qUmIGQxI+zqUFYrc5dWSHROoCGfkyHAskr60Y3tN489NKo+AsFC1iu1dY29FW2hK
Wt1dQEDYkTeYJu8WPf/XaOR562gq566IFgL6cpYujNrMuKOGj+5o2UbjmCTjkbTp
HdTU+Mja3mYfUDdBia4YVQwDXB07xZD7FiMbhm1oYsATfjiFA1jCy3X8q9dsFkMe
tMjs/7td7cCA1L45savQhcL7+c902NZMolXgRnFx
-----END CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIIGNTCCBR2gAwIBAgIEYhS1BTANBgkqhkiG9w0BAQsFADCB+DELMAkGA1UEBhMC
SU4xQTA/BgNVBAoTOEd1amFyYXQgTmFybWFkYSBWYWxsZXkgRmVydGlsaXplcnMg
YW5kIENoZW1pY2FscyBMaW1pdGVkMR0wGwYDVQQLExRDZXJ0aWZ5aW5nIEF1dGhv
cml0eTEPMA0GA1UEERMGMzgwMDU0MRAwDgYDVQQIEwdHdWphcmF0MSMwIQYDVQQJ
ExpCb2Rha2RldiBTRyBSb2FkIEFobWVkYWJhZDEbMBkGA1UEMxMSMzA0IEdORkMg
SW5mb3Rvd2VyMSIwIAYDVQQDExkobilDb2RlIFNvbHV0aW9ucyBDQSAyMDIyMB4X
DTIyMDQwMTEzMTMwOFoXDTMyMDMxNDE4MzAwMFowgZExCzAJBgNVBAYTAklOMUEw
PwYDVQQKEzhHdWphcmF0IE5hcm1hZGEgVmFsbGV5IEZlcnRpbGl6ZXJzIGFuZCBD
aGVtaWNhbHMgTGltaXRlZDEPMA0GA1UECxMGU3ViLUNBMS4wLAYDVQQDEyUobilD
b2RlIFNvbHV0aW9ucyBTdWItQ0EgZm9yIERTQyAyMDIyMIIBIjANBgkqhkiG9w0B
AQEFAAOCAQ8AMIIBCgKCAQEAzGQAmXXoP+X1PT9M7p+ImuQiXpHtMT1FuOURMbfK
n7J8AkJNY5gDJ/hnCnZNGe11IowYifyfwxbc6YIAHCxHCb8u7qscjWjLfMzxhTC1
DYrT2rKkvmyT96TGUc5ym6QEmNsmKeQ3hifFnhvfQS3bQX/UsRVM4cgAqEYNpJgB
cAEM0+5XLF0ct0m/YhoFq5Yq/qapGHtnyzjrGtkcUfAvSpvStD8YsZyHH4S9oZnh
trQT4rDrgrbJHO45O2zdg+Sat1svLG5EZQMdamzBGrWrI9EtkoXXXUdO9+JHBzC/
3+RU4xWRykb/W4x3ikD3XVzPYwCNaO5mc/fyed4VlykJVQIDAQABo4ICKjCCAiYw
DwYDVR0TBAgwBgEB/wIBADASBgNVHSAECzAJMAcGBWCCZGQCMFMGCCsGAQUFBwEB
BEcwRTBDBggrBgEFBQcwAoY3aHR0cHM6Ly93d3cubmNvZGVzb2x1dGlvbnMuY29t
L3JlcG9zaXRvcnkvbmNvZGVjYTIyLmRlcjCCAWcGA1UdHwSCAV4wggFaMD2gO6A5
hjdodHRwczovL3d3dy5uY29kZXNvbHV0aW9ucy5jb20vcmVwb3NpdG9yeS9uY29k
ZWNhMjIuY3JsMIIBF6CCAROgggEPpIIBCzCCAQcxCzAJBgNVBAYTAklOMUEwPwYD
VQQKEzhHdWphcmF0IE5hcm1hZGEgVmFsbGV5IEZlcnRpbGl6ZXJzIGFuZCBDaGVt
aWNhbHMgTGltaXRlZDEdMBsGA1UECxMUQ2VydGlmeWluZyBBdXRob3JpdHkxDzAN
BgNVBBETBjM4MDA1NDEQMA4GA1UECBMHR3VqYXJhdDEjMCEGA1UECRMaQm9kYWtk
ZXYgU0cgUm9hZCBBaG1lZGFiYWQxGzAZBgNVBDMTEjMwNCBHTkZDIEluZm90b3dl
cjEiMCAGA1UEAxMZKG4pQ29kZSBTb2x1dGlvbnMgQ0EgMjAyMjENMAsGA1UEAxME
Q1JMMTALBgNVHQ8EBAMCAQYwEwYDVR0jBAwwCoAIRMjP+tcFGZYwHQYDVR0OBBYE
FEbBNqG2RDls3sAxZvFIaIXiY787MA0GCSqGSIb3DQEBCwUAA4IBAQAIBatF1dqs
4G/AZoPDHjXoCXqB9UcfEZS/m0sCKISOmIFDiMpHNIcM01MLeh1lly2dfY9syP3E
92RCED7D9Lq72MwPPKYZk9yIMrXCi3sUTkuU42eDUT9N4XPfwSeqS0Ys6mfyjuxl
EDhvTNj+sxXASL7Wfz+zF/zxJ1gKGluileL2IYndlu2rsfGtAOjtN9QvYeZi2P/H
XAn0K868+F+2Z2GZX5g0bsilAUexGs3ErU2kJFfRfaxb+/6jU7r5aHS2dBUln4p9
3acM1rp1Rc5hpYdQg/trO8lq9FGNywB/b/x8wZvOBMr4+kSFUfNLNnqPJcSeypk3
m1P5CnhSLgK9
-----END CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIIF7jCCA9agAwIBAgIQUdOMKmfr8050nP+eFrA3mDANBgkqhkiG9w0BAQsFADA6
MQswCQYDVQQGEwJJTjESMBAGA1UEChMJSW5kaWEgUEtJMRcwFQYDVQQDEw5DQ0Eg
SW5kaWEgMjAyMjAeFw0yMjAzMTYxMjA5MzVaFw0zMjAzMTYxMjA5MzVaMIH4MQsw
CQYDVQQGEwJJTjFBMD8GA1UEChM4R3VqYXJhdCBOYXJtYWRhIFZhbGxleSBGZXJ0
aWxpemVycyBhbmQgQ2hlbWljYWxzIExpbWl0ZWQxHTAbBgNVBAsTFENlcnRpZnlp
bmcgQXV0aG9yaXR5MQ8wDQYDVQQREwYzODAwNTQxEDAOBgNVBAgTB0d1amFyYXQx
IzAhBgNVBAkTGkJvZGFrZGV2IFNHIFJvYWQgQWhtZWRhYmFkMRswGQYDVQQzExIz
MDQgR05GQyBJbmZvdG93ZXIxIjAgBgNVBAMTGShuKUNvZGUgU29sdXRpb25zIENB
IDIwMjIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC15eTJHjztttNK
0qmD5nM+rBxtkL1tmv8ARj9Z5b4TMzWh/tnUFOqCD7VWAwVnKFUmBFL3cIzR6j4L
u65DBkCoBojOUkZttti1EH28P/R4BzBJtf5SrwQPGHlzKgQGMG7+QegaNv2aGrLC
r50/YLnR1Du48D8S8qSgR5UhMXCogA2ow3mNeL3+93fB8mecZZ6H5mYo1DnFUFhi
iJZaKm35fONyu9ctDCpvlLhDJZAvZzjpYlCWOMBn9pA4eq5jmiWZXqsiR7Ch05GK
LCWEmavwla4pqz6X3b3aoNX7TvUitvo/j20fuTRcieUtaRXKCWFwKGKvSt92m43F
s4ji7QzxAgMBAAGjggEvMIIBKzASBgNVHRMBAf8ECDAGAQH/AgEBMBEGA1UdDgQK
BAhEyM/61wUZljASBgNVHSAECzAJMAcGBWCCZGQCMBMGA1UdIwQMMAqACE47SDZc
4l99MIGABggrBgEFBQcBAQR0MHIwHgYIKwYBBQUHMAGGEmh0dHA6Ly9vY3ZzLmdv
di5pbjBQBggrBgEFBQcwAoZEaHR0cDovL3d3dy5jY2EuZ292LmluL2NjYS9zaXRl
cy9kZWZhdWx0L2ZpbGVzL2ZpbGVzL0NDQUluZGlhMjAyMi5jZXIwDgYDVR0PAQH/
BAQDAgEGMEYGA1UdHwQ/MD0wO6A5oDeGNWh0dHA6Ly9jY2EuZ292LmluL3J3L3Jl
c291cmNlcy9DQ0FJbmRpYTIwMjJMYXRlc3QuY3JsMA0GCSqGSIb3DQEBCwUAA4IC
AQB+X+JRRWTevQU/Kgmh60AQiNNaFYvSj/cGHHbVPFEO2AImLT+SqBn/4MrFE17S
kNf2b2aXOXcJetKgBPxbmyDqnuKdQl1LL9KYiFhwbCgien132FTFGwQ3+qVRMAc7
K7Uiqa5X3lY0Hx4rfWDMLp3iYAKe7aW9oGmnZncymuOTHKkOMZMOth5502DIJXZm
A6T1yqroqW0yxeescWe5LHrN/DWNv9UlfZMofcZcmirl4SZ3ZUSXRxQnvH6PFcKh
9uDWxe16paYX9fRh8SZ6A7bIfI5iTZJHA+/AbFKOT16yYZUx4i1D0DU2dZMGgsjj
y0/Y6LFRm2VkZP5pdA3UtPtGi6bDRNJCvhblJw/sHxziiOEuH+QOcxufjim22Xbk
2g8yVZ2+2Mcj0KDFVF8HDuaDFiFvAfjoY8actTU0fmMxLIEC+mDWGwTSoxlDCPtG
vuDND6Qw2qyVqFnMlSUJ8EzkoOzqSjhfI8qx3POo4SvWJFFtCAlsZb6Mm1y9ZtXI
goPk7aOSM758uEEA2JhlEnKkS0Lo88AZovrmmzBq6IDYCgrclqWVVSd1PYo22Kvj
qmOzKqUyMAz3tr4pVOTQkeeXoBO1W1WVjFWKTM2+p0euWm4tdHFOxA/8MXQl89ic
iYkQb5LTnqv8m9rUzTx9bp3wVCUAa0qgcayC9rBy2Y2G5g==
-----END CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIIFNDCCAxygAwIBAgIQdiQz69smdlqFYM0KqC/hFzANBgkqhkiG9w0BAQsFADA6
MQswCQYDVQQGEwJJTjESMBAGA1UEChMJSW5kaWEgUEtJMRcwFQYDVQQDEw5DQ0Eg
SW5kaWEgMjAyMjAeFw0yMjAyMDIxMjA0MzdaFw00MjAyMDIxMjA0MzdaMDoxCzAJ
BgNVBAYTAklOMRIwEAYDVQQKEwlJbmRpYSBQS0kxFzAVBgNVBAMTDkNDQSBJbmRp
YSAyMDIyMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAv3EBudWC8HY0
oSwtJZCqpjQTGpEewl3EdDqUORV0qoFp78mdR/vuATXI83G7nF9RLvmNjgQgKr/b
Mx6gPO4Y57bMjAsgwEzleFclZka/sqc68iN5rS3huhrCX6MEINLyDOQ71MRA7GJC
aNL6E3j1438eTu011mlikeZYBdkhvfpAVjCw90w8wcWDmqx66Y561T/RiXyz2uEh
BBZAD43gV58eXStOeOTwAzEZYMrmp232GfmQKabYRfdIRus1avyuGea2nICEsRHE
8M2tdzwpGP7oIy2qHBFJJ+3AwmwQA4DjmDkJtCD+58awohQavRNhqjsGD+ZifG3V
R4i6WrKv8OWqZzcZj3g3Elr5+fRMlz1GSqkWPBw1Ev8KWTHazSUKF7OMxm3XzyXx
Qnw7fZF9GOVtx3adpfRPqYGgtbOP34EVkz4wsHvNMrvUrYcKymdOrnkTjlX26fIH
UJpKGYkLk9q0jhMNKs4Rn8lj4pJ7YF33/ND4bjpV0ex1EAQz0iZvT37OnxNiuAZ/
+4Djf075UuNX2ecWnadOrN1r8NAParZIwUoSUnWhU8TqAWWRqzFURHUZuOMQcA0g
eg4c9zqtBoUPgtQksbIAEsEXmDuRpwSIFjEkK11f5Eemfmfdg37KyIjQ67TRTmBA
+kT9Q5JIm/e7m1ILg/HKckgLUOCnAMsCAwEAAaM2MDQwDwYDVR0TAQH/BAUwAwEB
/zARBgNVHQ4ECgQITjtINlziX30wDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEB
CwUAA4ICAQCdbE8d1c1DysKtrtYlApYIXTlY3N2XHNQ6gKoaVWsKa1TJ/ovrT+FV
3bmQLet3aSoEG6pTe/vLZSg8WiF7cn7WuF4XlQS3yA2Uu8/cg/S4owqhQJp6K/Xg
6UoSBad9Kog1H8deOfV8Nmb8a89zB4Yf8/AepId+Lr/3I6O7iub+PUT2QBXnksa+
cf0yf+49GhyMCILZvctNSQd4Vxr9EgRvBARTrAgNQ9sEOJ6myOz4iTFR7T2pIFP8
Cp15e8jEVI1q4IuHu3XlwJNk9f5k3gbwrzoy9P5rP8voQU3u9wh62JZa9U63b+u/
Ur1tsKb5Lx0YUedtHvpIiIRurEPxumW0twjrx8TrAcXRrViSL7dsXAoYC0dXo154
EE8jBAzgIIur7tJizxgXDEn4i2pu8Yd615YML9ii5BooEJ2j6fQ0nzyPRmx1Egw2
Fjlgzzceai4TUOcaCKab86yyu5MZIp+BiPR840nw5MggbRgYH2nFRBA70toVm4VF
lbZs3reGmaICm4ST6R395OxYS1iYBm5kXm9tLb4pkIhUxrkgyuiwE+DsWceBjHAY
aXnCgUGKtiG9tfBMUw3fChoPb9L1yKdNof3zXDdTloMqEpO4BFrmjco8kt1v0LUQ
PhNZmQP4nqd4Hqx2384nPmWDXbQ+eePyxRteYGY0hJeDLVpyeYG8VQ==
-----END CERTIFICATE-----

@lucifer-woo
Copy link

lucifer-woo commented Sep 7, 2024

Hey folks, what is the status of the issue ?

This app is the only fully featured alternative to adobe. If this is done. It would be great.

@JakubMelka
Copy link
Owner

@lucifer-woo, sorry, I will try to take time to solve it. I will reopen the issue.

@JakubMelka JakubMelka reopened this Sep 8, 2024
@lucifer-woo
Copy link

lucifer-woo commented Sep 9, 2024 via email

@JakubMelka
Copy link
Owner

Hello, I am not an expert in internet security and I was unable to create a PDF with the given certificate chain. But I think the workaround exists. @lucifer-woo, @itsKV, could you please try to install the root certificate to the system's certificate store? When PDF4QT validates the PDF's signatures, it also looks in the system's certificate store to retrieve the root certificates for the validation.

@lucifer-woo
Copy link

lucifer-woo commented Sep 16, 2024

I understand your frustation. But how do I install the root CA to the system CA. I am novice to this stuff. I am not that much proficient in this.

Foxit PDF reader for linux also provides this feature. Maybe check it out as a reference ?

As of now, I added the certificate by right clicking and "Add to Trusted certificates". I could also see it in Tools > Options > Signatures. But I cannot see it in Tools > Certificates. Is that a problem ?

So far, this is how it is done - https://www.youtube.com/watch?v=aVNfUNlccZs.

It's an old video. Trusting isn't even needed as of now because Adobe just validates and renders it using OCSP servers. No need to trust certificates. Maybe you need to rethink the logic behind it.

Some docs regarding:

I think could be implemented using this python library : https://pyhanko.readthedocs.io/en/latest/cli-guide/validation.html

I just pulled the web regarding this info. I don't know much other than these.

@itsKV
Copy link

itsKV commented Sep 16, 2024

Hello, I am not an expert in internet security and I was unable to create a PDF with the given certificate chain. But I think the workaround exists. @lucifer-woo, @itsKV, could you please try to install the root certificate to the system's certificate store? When PDF4QT validates the PDF's signatures, it also looks in the system's certificate store to retrieve the root certificates for the validation.

The issue is not about root cert availability in cert store. The issue is UI bug which doesn't give option to validate the document's signature. See the OP. btw, the root and intermediate certs are already installed into windows store.

@itsKV
Copy link

itsKV commented Sep 16, 2024

I understand your frustation. But how do I install the root CA to the system CA. I am novice to this stuff. I am not that much proficient in this.

See the article here... https://www.itechtics.com/update-root-certificates/
Adding the signature into PDF reader's trusted database in different and adding the certificate into operating system's root store is different thing.

@lucifer-woo
Copy link

lucifer-woo commented Sep 18, 2024 via email

@JakubMelka
Copy link
Owner

Hello, I have tried to fix it. Could you please try this build? https://github.com/JakubMelka/PDF4QT/actions/runs/11306021848

@itsKV, @lucifer-woo

Thank you.

@lucifer-woo
Copy link

lucifer-woo commented Oct 12, 2024

I tried it in both .exe and .deb. Still no changes. The same, After I click "Add to trusted certificates". I can see the certificate under Options (Ctrl + K) > Signature > Trusted Certificate store.

But still it is :

image

It does not verify or render the signature. I would suggest OCSP based revocation checking and render it instead of blindly trusting it like adobe trusts.


I cannot see anything under Tools > Certificates. Just blank.

@dipak-progrc
Copy link

@lucifer-woo OSCP based revocation checking is not always possible. As some CA might not have OSCP Responder endpoint.

Additionally, the LTV(long term validation) signatures tend to contain everything(Cert Chain, CRL responses, OSCP responses, Timestamp) it needs to validate the signature, and thus do not need internet to validate signature. So a standalone implementation is required anyway.

Regarding the bug, I tried adding Root CA from a signature to Trusted list. It worked as intended. Root Certificate added and signature validated fine.

@JakubMelka Adobe manages/updates its AATL Roots via this URL - http://trustlist.adobe.com/tl12.acrobatsecuritysettings
The url returns a signed pdf file with an XML file as attachment. That XML contains all the latest AATL Root Certificates. This is undocumented url, if you'd like to ship the Trusted Roots, you can consider implementing it.

@lucifer-woo
Copy link

lucifer-woo commented Oct 17, 2024

Alright.

I tried adding Root CA from a signature to Trusted list

@dipak-progrc Do you mean, as right clicking and "add to .." or extracting the cert, add to system's root store and verifiying it ?

Because, I cannot verify and validate the signature at all from the new builds.

@dipak-progrc
Copy link

dipak-progrc commented Oct 18, 2024

@lucifer-woo I added the certificate by right clicking on the Root certificate of chain shown in Signature, then clicked the only option shown in the context menu - "Add to trusted certificates".
These Manually added Trusted Certificates show in "Tools" -> "Options" -> (Dialog Box) -> "Signatures"(Side Panel) -> "Trusted Certificate Store".

The options for Digital Signature Verification are set as -
Signature verification - ✓Enable
Strict mode - X
Ignore expired certificates - X
Use system certificate store - ✓Enable

I used PDF4QT-1.4.0.0-x86_64.AppImage on Ubuntu 24 Desktop.

@lucifer-woo
Copy link

lucifer-woo commented Oct 20, 2024

I have the same settings as you. But I can't verify and render the digital signature to a Greencheck mark as the OP denotes.

Using Fedora 40, Installed the deb package with dpkg present in fedora. (Yes it is possible to install deb packages in fedora. Just not a repostiroy that is apt unavailable to update them)

JakubMelka added a commit that referenced this issue Oct 29, 2024
@JakubMelka
Copy link
Owner

@dipak-progrc
Copy link

dipak-progrc commented Oct 30, 2024

@JakubMelka I tested the Linux version.
Signatures gets validated fine for documents signed by me with an officially issued Digital Signature Certificate.

But it fails with error "Certificate validation failed with code 26" for the Adobe Trust List pdf file, which is digitally signed by Adobe.
Attaching the screenshot -
image

The sample file can be downloaded from the AATL Trust List link I provided earlier.

@IDontKnow2Code
Copy link
Author

IDontKnow2Code commented Oct 30, 2024

I have added the AATL certificates, please have a look on it. @IDontKnow2Code, @lucifer-woo, @dipak-progrc, please test the instalations here:

I tried this build it states Trusted Certificate not found.

cert
sig

@dipak-progrc
Copy link

dipak-progrc commented Oct 30, 2024

@IDontKnow2Code I think in your case the Signature Field in the PDF file might not have the complete certificate chain. Can you confirm this with some other tools like Adobe Acrobat, or PKI Tools - PDF Validator ?

Edit: I confirmed by downloading my Aadhaar PDF, the file has incomplete chain. @IDontKnow2Code you can try with some Digitally Signed eGazzete pdf.

@IDontKnow2Code
Copy link
Author

@IDontKnow2Code I think in your case the Signature Field in the PDF file might not have the complete certificate chain. Can you confirm this with some other tools like Adobe Acrobat, or PKI Tools - PDF Validator ?

Edit: I confirmed by downloading my Aadhaar PDF, the file has incomplete chain. @IDontKnow2Code you can try with some Digitally Signed eGazzete pdf.

I opened Aadhaar in acrobat reader in win 11 it works fine.

Screenshot 2024-10-30 153933.png

Screenshot 2024-10-30 153905.png

@dipak-progrc
Copy link

I opened Aadhaar in acrobat reader in win 11 it works fine.

@IDontKnow2Code This may be because you already have the DS UIDAI Certificate trusted manually. Check the Root Trust Store of your OS.

@IDontKnow2Code
Copy link
Author

IDontKnow2Code commented Oct 30, 2024

@IDontKnow2Code This may be because you already have the DS UIDAI Certificate trusted manually. Check the Root Trust Store of your OS.

I don't understand what you mean can you elaborate?

@dipak-progrc
Copy link

I don't understand what you mean can you elaborate?

@IDontKnow2Code Similar to the PDF4QT, in Adobe Acrobat Reader we can add a certificate to the Trusted List. So I am speculating that at some point in the past, the system you are working on have had the DS UIDAI Certificate manually added to the Root Trust. That's why, the Aadhaar PDFs even with the single certificate in the chain are validating fine.

A point here can be made - if the certificate is already added to the Root Trust, why cant PDF4QT obey that and validate the signature! @JakubMelka

To see if the DS UIDAI certificate is added manually, you may check your Root Trust Certificates Store. The way to access the Store varies from OS to OS. In case of Adobe Acrobat Reader, you may go to Preference > Signatures(Sidebar of Dialog) > Identities & Trusted Certificates > More > Trusted Certificate(Sidebar of Dialog). The DS UIDAI certificate is not supposed to be in that list, as it is not a Root CA. Digital Signature Certificates issued in India all have to terminate in single root, that is CCA India.

@IDontKnow2Code
Copy link
Author

To see if the DS UIDAI certificate is added manually, you may check your Root Trust Certificates Store. The way to access the Store varies from OS to OS. In case of Adobe Acrobat Reader, you may go to Preference > Signatures(Sidebar of Dialog) > Identities & Trusted Certificates > More > Trusted Certificate(Sidebar of Dialog). The DS UIDAI certificate is not supposed to be in that list, as it is not a Root CA. Digital Signature Certificates issued in India all have to terminate in single root, that is CCA India.

Yes I can see there is DS Unique Identification... Certificate in Acrobat.

I can confirm that both Linux and windows version of PDF4QT shows this same error

I tried this build it states Trusted Certificate not found.

cert
sig

@lucifer-woo
Copy link

The same thing for me like @IDontKnow2Code both on Linux and Windows. Just works flawlessly in Adobe. I think the problem is Rendering the green check as we have trusted the certificate already as @dipak-progrc said. You need to render it as in the OG picture that seems to be the problem.

@JakubMelka
Copy link
Owner

I need a sample document to do that.

@lucifer-woo
Copy link

lucifer-woo commented Nov 9, 2024

Nobody here would do it. It's a critical document. As per a reddit post, I found this - https://www.mupdf.com/. Need to figure how to use it to validate. I have of pdfsig in various stackexchange answer. But nothing worked or I am using the command in a wrong way.

I am trying this way - https://mupdf.readthedocs.io/en/latest/mutool-run-js-api.html#validateSignature

Foxit PDF reader on Linux could do this as of now. But I do not trust it at all.

@lucifer-woo
Copy link

lucifer-woo commented Nov 9, 2024

I used pdfsig. Some insights that could help.

Digital Signature Info of: file0.pdf
Signature #1:

  • Signature Field Name: Signature1
    Syntax Error (0): Illegal values in ByteRange array
  • Signer Certificate Common Name:
  • Signer full Distinguished Name:
  • Signing Time:
  • Signing Hash Algorithm: unknown
  • Signature Type: adbe.pkcs7.detached
  • Signed Ranges: [0 - 1022752], [1039138 - 1042281]
  • Not total document signed
  • Signature Validation: Signature has not yet been verified.

Digital Signature Info of: file1.pdf
Signature #1:

  • Signature Field Name: GCMSignature
    Internal Error (0): Input couldn't be parsed as a CMS signature
  • Signer Certificate Common Name:
  • Signer full Distinguished Name:
  • Signing Time:
  • Signing Hash Algorithm: unknown
  • Signature Type: adbe.pkcs7.sha1
  • Signed Ranges: [0 - 213], [12853 - 490115]
  • Total document signed
  • Signature Validation: Unknown Validation Failure.

Seems like the signature itself is a different type. I don't things very much. Just a guess.

file0 is the document as in OP. file1 is another document by government.

@lucifer-woo
Copy link

lucifer-woo commented Nov 9, 2024

Adobe reader checks and validates it based on PKCS7 Signature via OCSP to a domain named *.gov.in ( I didn't catch the * part that much) when your device is connected to internet. If there is no internet. You need to trust it manually as in the GIF posted in 1st comment.

These are final things/help I could provide from my side. I hope it's informative.

@JakubMelka
Copy link
Owner

@lucifer-woo, I think in the link under this video: https://www.youtube.com/watch?v=aVNfUNlccZs there is a sample document, but for some reason, I am not able to download it. Could you please attach it?

@lucifer-woo
Copy link

It is a link to download the actual document of a person not a sample document.

@JakubMelka
Copy link
Owner

@lucifer-woo, is there some sample document signed with this certificate (for example, some public document), where the problem is observable?

@lucifer-woo
Copy link

This is a supreme court of India document on a controversial case. I had it for a case study. It has a digital signature similar to that of the ones as in Aadhaar. I hope you can make use of it.

article_370.pdf

@JakubMelka
Copy link
Owner

Hello @lucifer-woo, the certificate in the document has expired. However, if you setup it this way, you can verify it:
image

However, I do not change graphics of the form field.

@lucifer-woo
Copy link

Well, a lot of other public available case documents on SCI's website could be used for testing in the case of this. We insist on Graphical change of it since, in case we print a document with a digital signature but doesn't have a QR code. It might be a hurdle for us in real life while submitting documents. Since, if QR code is not present only digital signature, officials could not verify documents and is returned back for correction.

The problem for all commentors on the issue here is not only adding it to the trusted certificate store (which it gets successfully added) rather change it in the graphical form as Adobe does too to the Green checkmark.

Use this in case, you need a new document

https://www.sci.gov.in/wp-admin/admin-ajax.php?action=get_court_pdf&diary_no=501272024&type=o&order_date=2024-11-14&from=latest_judgements_order

@lucifer-woo
Copy link

lucifer-woo commented Nov 17, 2024

If I am right, the form field is separate and just a layer over the actual document than a part of PDF. So, it could be possible to change it graphically, mostly

Yes, the signature is valid and AATL seems to be working correctly as intended, since I don't see Trust certificate not found and elephant in the room is graphic change.

Question : Is AATL, static or dynamically updated by fetching from the URL provided by Dipak ?

If not updated, I would suggest Github actions to update the AATL to a Github file in the repostiory and make the app fetch it at certain intervals of time or on demand when a trusted certificate is not found for a signature.

@dipak-progrc
Copy link

In terms of PDF Specification, @JakubMelka 's implementation is conforming to the requirements. The In-Document visualizations of signature validity has been deprecated years ago. Adobe and other popular viewers are providing the feature because of backward compatibility.

The reason, I believe, for the deprecation of in-document visualization is to thwart attempts to edit a pdf into a "valid signed pdf" by just placing a green checkbox. The PDF specs wanted to move the visible signs of pdf validation out of the page to Application UI. Application UI cannot be controlled by the PDF file contents. Thus, it is way more reliable when it comes to checking validation status. Further reading - Stackoverflow answer on PDF Sign Appearance by mkl

But I do understand the practical need for the visible change of the Signature Appearance when the signature gets validated successfully. Many institutions have formed their rules around this feature. I have even seen institutions suggesting users to add the signer's certificate to the Trusted List, in order to get the green-tick validation on their documents. Not having this feature might be a big blocker to that section of users.

I'd vouch for this feature as well.

@dipak-progrc
Copy link

dipak-progrc commented Nov 18, 2024

Additionally, I'd recommend a dynamic approach in terms of processing AATL list. The list does gets updated from time to time (last update Aug 30, 2024).

I am not that experienced with C++ and QT, but from the code I think the current implementation ships the XML from AATL url pdf with PDF4QT binary, and uses it as trust store. This eliminates scope for updation at user side, if the user keeps using older version of the PDF4QT.

I think a better implementation would be to do a HEAD request to the AATL url, check for the last modified header, compare it with the current AATL's last modified date; if newer, download the file, extract xml, update AATL.

Nevertheless, huge respects for @JakubMelka for implementing 3 major features while addressing this issue.

@lucifer-woo
Copy link

Well, Foxit PDF also provides the features as adobe for backwards compatibility too.

@JakubMelka
Copy link
Owner

@lucifer-woo, I will consider to implement a way how to adjust the appearance of the form field with a signature. How should it look like? Maybe green check and display a text "PDF4QT successfully validated the signature"? Or red mark in case of error?

@dipak-progrc, I thought about it but I do not want to access internet - I would like that PDF4QT can work completely without internet connection.

@lucifer-woo
Copy link

lucifer-woo commented Dec 1, 2024

Well, It would be better if it follows like Adobe and message like you said. It is the most used one.

Sorry for delay. I didn't receive notification.

@lucifer-woo
Copy link

I thought about it but I do not want to access internet - I would like that PDF4QT can work completely without internet connection.

Maybe create a GitHub action that builds the app with the latest file on a weekly or monthly basis ?

@JakubMelka
Copy link
Owner

Yes, I am planning to do that - but after I resolve the linux Flatpak problem.

@lucifer-woo
Copy link

ocsp-1
ocsp-2

This might help you. this is what I have been telling from the beginning.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants