xmlenc 0.1.7 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a4f1124fa5bd31f8c364288d7d7f56e00bebab77
|
4
|
+
data.tar.gz: 6f3aa991240dc4c96873ceb7e326f0b0b886f77d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1b15580ce2af23aa3520dddb2fa143cf9a7575e191140102ef9463f2ca2b32c3f1d1ab053c3a6868c3caa6d6964898793ee57d086565f5fb398f367ba4f11a6b
|
7
|
+
data.tar.gz: 4da800f73ab72328bc092f2941d26fb7aa0cac0736d9d2c27e7e8283b91bee996f1b09e09e91ad505785bf708e66602b7ef8455698483bca5973ce1a433582fb
|
@@ -20,9 +20,13 @@ module Xmlenc
|
|
20
20
|
|
21
21
|
def decrypt(cipher_value, options = {})
|
22
22
|
cipher.decrypt
|
23
|
-
cipher.
|
24
|
-
cipher.
|
25
|
-
cipher.
|
23
|
+
cipher.padding = 0
|
24
|
+
cipher.key = @key
|
25
|
+
cipher.iv = cipher_value[0...iv_len]
|
26
|
+
result = cipher.update(cipher_value[iv_len..-1]) << cipher.final
|
27
|
+
|
28
|
+
padding_size = result.last.unpack('c').first
|
29
|
+
result[0...-padding_size]
|
26
30
|
end
|
27
31
|
|
28
32
|
def encrypt(data, options = {})
|
data/lib/xmlenc/version.rb
CHANGED
@@ -0,0 +1,27 @@
|
|
1
|
+
-----BEGIN RSA PRIVATE KEY-----
|
2
|
+
MIIEowIBAAKCAQEA0Kp+1D20R3Qs1KbuKLXZcHAoofsvMmMuO8W/g+uggPr+glId
|
3
|
+
RKWCkjBQRfC0aP3S4HSP9MJGNilUUTUsl4PC7onIPSyKqc2X92SYYz3Im4IS301I
|
4
|
+
UXnU1Br+beyLR3qHcy/hEnu31hvIozYK6qswUyL2CYzJabpwNBIGWOZXtpnTjSio
|
5
|
+
95+MiUElA4wNLTJDZjvK48HeQdiUaylx3l4oUsL+a5Fk4WpTQ6JFKnM+R0hpCj+T
|
6
|
+
EzkM066I3/KrKgJeWoaBLHSTINnXRk2nzrqsbLGy0ncyzv8w+d1X3k709W6x882Z
|
7
|
+
MnOCA3IxktZh/LM4UAoxrrdKaYGjCyC0y3qVZwIDAQABAoIBAChJUpVNmHnXLzSb
|
8
|
+
Sg3oFiQEM4Qah+E1jt6Rbklc+68LRooIqofvYIcy9ryaHWrL3qPhPU3nGEEqt5G6
|
9
|
+
L3LNSJxfU56j892WyQlFjbpTWmDTuysLs7OvTuzojUjRy44wVOhjTRQReMvIr3L7
|
10
|
+
Yx4tkPXsIQ509QoJqdITzM/rIPIq5S3JI4m3Etdbj8GkDikdpXGj41CWwlgyofwx
|
11
|
+
IiEyQS7pj7oZ1tCc+OvKPMqNM2VOfV4S4aj2ZFfSeju0ceUtR4tOByl87Sm474zo
|
12
|
+
IEuOD0VqkZbncyXkuirskV8U6XeipDiHA8jpK0ujfqHJt0t9oafEAwa10CpKr/0T
|
13
|
+
hqwmQZkCgYEA/fM0cT/kSsjH7t3utcRE4kFpBc0aBIvRPHVPLtzmbIEvJds/z1/k
|
14
|
+
h/6+1z1U2dS7VK+BzcStgW7dm4gvsyzibrwmDG4RuWVfVCFyNab+FKGuEkdNi2EN
|
15
|
+
2eNJVa8+5jE3hZBOvU090h/Fm8x6Kc35xLtY5CVLALWqYptYeUti/B0CgYEA0lm1
|
16
|
+
tp40wtiFh9x/qiLyjDFHnNYxolYBomYUPb0YRQ0lkRHGKh+pvHGO6DcB6AIaGwo7
|
17
|
+
UWDqPvjMmKWANcQLtZSXzWQ1b5m6n4NO8sdc4I8mXa+zmOAdz0aDkum4gEyj3VEz
|
18
|
+
Ys5jd/3CBqANp9IKnukWpqVOcpw2YOoTitaGuFMCgYAB3SQYZLCnP9v/y88xtFQR
|
19
|
+
GQvNSBkVyXTqra28GVDzoOsYqwhH3FtQCDWcXM3fn2kUkQkx2myvk4G634ACH6U1
|
20
|
+
zNm2o6QrqSvO8UPmUuhwfFNLvQw7pqW0YK+sGlIq3Fec+lcpmoSGo0cPAqwu3F0l
|
21
|
+
7X4UhpWLVsn+WUeH9F6wnQKBgFWhTXbtCn9zU1COc64YEfL+MK/pBkWWi43Hzl+f
|
22
|
+
tdyOUIew26HUR+29sLZZhj4jdOsjDCjBsjo2YFuXrAy3JSkjN3TWYWZwB2feNWph
|
23
|
+
vC5yN+UVnKAURC5X/0H0QTaBfIehAbEsYZO8SpsV1tlFiStNqfnm+3tumjhzscbo
|
24
|
+
M+mfAoGBAKw2fxOkm1bv0urwBtbYVN8ldAyyWUj6WgXJKMxXkiJZesbaEIqAjvQb
|
25
|
+
Rx24XSwq1PhfvlVKIksK1sLFp4FkF6NoFjc99mzwE16S02AlBAPOglDj9j+6jozz
|
26
|
+
+gC2Lnn8D8Q7EINV/+3QCjIpFwgJiA/oZNuLW0Ly0O8LiEott9UX
|
27
|
+
-----END RSA PRIVATE KEY-----
|
@@ -0,0 +1 @@
|
|
1
|
+
PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c2FtbDJwOlJlc3BvbnNlIHhtbG5zOnNhbWwycD0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnByb3RvY29sIiBEZXN0aW5hdGlvbj0iaHR0cDovL2x2aC5tZTozMDAwL3NhbWwvY29uc3VtZSIgSUQ9Il8xZDFkMmZhODgxY2Y5NmIwNTQyNTgxMmFlYjU1ZWU4OCIgSW5SZXNwb25zZVRvPSJfMGViMjY3ZTBjZmU5MDUyOGI5ZjlmMDE5YzE1MTU2MTgxZDJlNGE2NCIgSXNzdWVJbnN0YW50PSIyMDE1LTA0LTIwVDE2OjQ0OjQ4LjM1NVoiIFZlcnNpb249IjIuMCI+PHNhbWwyOklzc3VlciB4bWxuczpzYW1sMj0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOmFzc2VydGlvbiIgRm9ybWF0PSJ1cm46b2FzaXM6bmFtZXM6dGM6U0FNTDoyLjA6bmFtZWlkLWZvcm1hdDplbnRpdHkiPmh0dHBzOi8vc2hpYmJvbGV0aC52YWdyYW50LmRldi9pZHAvc2hpYmJvbGV0aDwvc2FtbDI6SXNzdWVyPjxzYW1sMnA6U3RhdHVzPjxzYW1sMnA6U3RhdHVzQ29kZSBWYWx1ZT0idXJuOm9hc2lzOm5hbWVzOnRjOlNBTUw6Mi4wOnN0YXR1czpTdWNjZXNzIi8+PC9zYW1sMnA6U3RhdHVzPjxzYW1sMjpFbmNyeXB0ZWRBc3NlcnRpb24geG1sbnM6c2FtbDI9InVybjpvYXNpczpuYW1lczp0YzpTQU1MOjIuMDphc3NlcnRpb24iPjx4ZW5jOkVuY3J5cHRlZERhdGEgeG1sbnM6eGVuYz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjIiBJZD0iX2U4NDhjODEwOTY0MTZiZGExNTdkZmEzYTYwYjY0NGQ2IiBUeXBlPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyNFbGVtZW50Ij48eGVuYzpFbmNyeXB0aW9uTWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjYWVzMTI4LWNiYyIgeG1sbnM6eGVuYz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjIi8+PGRzOktleUluZm8geG1sbnM6ZHM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvMDkveG1sZHNpZyMiPjx4ZW5jOkVuY3J5cHRlZEtleSBJZD0iX2M0ODY1ZDdhZDRiY2Y5MzY0NjI5NmEwMTcxYjRmNWRlIiB4bWxuczp4ZW5jPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyMiPjx4ZW5jOkVuY3J5cHRpb25NZXRob2QgQWxnb3JpdGhtPSJodHRwOi8vd3d3LnczLm9yZy8yMDAxLzA0L3htbGVuYyNyc2Etb2FlcC1tZ2YxcCIgeG1sbnM6eGVuYz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjIj48ZHM6RGlnZXN0TWV0aG9kIEFsZ29yaXRobT0iaHR0cDovL3d3dy53My5vcmcvMjAwMC8wOS94bWxkc2lnI3NoYTEiIHhtbG5zOmRzPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwLzA5L3htbGRzaWcjIi8+PC94ZW5jOkVuY3J5cHRpb25NZXRob2Q+PGRzOktleUluZm8+PGRzOlg1MDlEYXRhPjxkczpYNTA5Q2VydGlmaWNhdGU+TUlJRUVUQ0NBdm1nQXdJQkFnSUpBTDBCd1RERmEwWVJNQTBHQ1NxR1NJYjNEUUVCQlFVQU1HSXhDekFKQmdOVkJBWVRBbFZUTVJNdwpFUVlEVlFRSUV3cFRiMjFsTFZOMFlYUmxNUkV3RHdZRFZRUUtFd2hMZFdGc2FTNURiekVPTUF3R0ExVUVDeE1GVW1WaFpIa3hHekFaCkJnTlZCQU1URW5WeWJqcHlaV0ZrZVRwcmRXRnNhUzVqYnpBZ0Z3MHhOVEEwTVRBeE9UQXdNREphR0E4ME56VXpNRE13TmpFNU1EQXcKTWxvd1lqRUxNQWtHQTFVRUJoTUNWVk14RXpBUkJnTlZCQWdUQ2xOdmJXVXRVM1JoZEdVeEVUQVBCZ05WQkFvVENFdDFZV3hwTGtOdgpNUTR3REFZRFZRUUxFd1ZTWldGa2VURWJNQmtHQTFVRUF4TVNkWEp1T25KbFlXUjVPbXQxWVd4cExtTnZNSUlCSWpBTkJna3Foa2lHCjl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUEwS3ArMUQyMFIzUXMxS2J1S0xYWmNIQW9vZnN2TW1NdU84Vy9nK3VnZ1ByK2dsSWQKUktXQ2tqQlFSZkMwYVAzUzRIU1A5TUpHTmlsVVVUVXNsNFBDN29uSVBTeUtxYzJYOTJTWVl6M0ltNElTMzAxSVVYblUxQnIrYmV5TApSM3FIY3kvaEVudTMxaHZJb3pZSzZxc3dVeUwyQ1l6SmFicHdOQklHV09aWHRwblRqU2lvOTUrTWlVRWxBNHdOTFRKRFpqdks0OEhlClFkaVVheWx4M2w0b1VzTCthNUZrNFdwVFE2SkZLbk0rUjBocENqK1RFemtNMDY2STMvS3JLZ0plV29hQkxIU1RJTm5YUmsybnpycXMKYkxHeTBuY3l6djh3K2QxWDNrNzA5VzZ4ODgyWk1uT0NBM0l4a3RaaC9MTTRVQW94cnJkS2FZR2pDeUMweTNxVlp3SURBUUFCbzRISApNSUhFTUIwR0ExVWREZ1FXQkJSWCtnbHhOWXppcEo5TGx0WnNHKzd1VnVjbW9EQ0JsQVlEVlIwakJJR01NSUdKZ0JSWCtnbHhOWXppCnBKOUxsdFpzRys3dVZ1Y21vS0ZtcEdRd1lqRUxNQWtHQTFVRUJoTUNWVk14RXpBUkJnTlZCQWdUQ2xOdmJXVXRVM1JoZEdVeEVUQVAKQmdOVkJBb1RDRXQxWVd4cExrTnZNUTR3REFZRFZRUUxFd1ZTWldGa2VURWJNQmtHQTFVRUF4TVNkWEp1T25KbFlXUjVPbXQxWVd4cApMbU52Z2drQXZRSEJNTVZyUmhFd0RBWURWUjBUQkFVd0F3RUIvekFOQmdrcWhraUc5dzBCQVFVRkFBT0NBUUVBd2Z2SmhyN3BJSW80CnRWZVVNVThkL2Npdis1T1B0MzVFeWhJSGo2ZkU5TGdSME9HZTdqUjJ6WjJHSk5GR21nWkR1ZDZwSkNRVW9wT25GQ3ZiYUhMb2thN1YKdklJRGtSK2Rva3FMQktqU2R6ZmJHWUhCeXlna29sNmg5LzdneWVOaFhkaVpDL3Q2d1A5VGxJSUc4R0VEYWhlUEM4bGtBYzREa2NWRApwUjFGSVVzRGE0RmVlajRMR2x6SWJmYnlpZ0IwYjgzdng2Vy82QUFIaCt5d1pGM1J4czkyakE1K09mOUZOakJHeVlSRTczUEhzSkt4CnR0UVRxT0p5aFRwckwzY21JSFhWLzl4aHRVVUN0THVLbzNrYXRJKzR1VEhlcXVWK29OMEk3czA0OVREQWl0ZExKbFkzenpKNUVCSlAKRzRTblQwcUc4L1N5cXlpRGZsQnRqMlEzQmc9PTwvZHM6WDUwOUNlcnRpZmljYXRlPjwvZHM6WDUwOURhdGE+PC9kczpLZXlJbmZvPjx4ZW5jOkNpcGhlckRhdGEgeG1sbnM6eGVuYz0iaHR0cDovL3d3dy53My5vcmcvMjAwMS8wNC94bWxlbmMjIj48eGVuYzpDaXBoZXJWYWx1ZT5xQ3BueXcvRmRaMEh1b2NZYmwvMEhWQUhsTVc4c0Y4eGFRR0pCTU8rMkhpbHZHQU1zVjJSQ1RDQmE2cTU1YldqekRudjlNT2RoelJqUEdva0JvdnZQVVBaNU1nTmhMYlhEaGFjWlRsN3B4cTEwZVkzOUpnWm9UWmVSOXNUMEFCQWdMWkNXNElrbWptMjBsZWFMR1VaTVpSUUl1bm96cVF3aTIxbzB5c0NQb2RlYkJjczhxUzFlM1RDbVppUlliMXRMeWk5MjdVUGRlTmJUMlBWcFRIWlByTDdTKzE5N3ZaSEw3blpqOFZDWVpHOUJSUHU4YlBKb3VSeERuQ3RiVFZIOWZxK2hMUzFpOGV5QTZBNzQxWU5OemlwbEVPVGd6VDdRakxqbHNhQzhCeHl2Yk81bXEwTWZENTJYSGphaWwwL2VTZEpaSmxzSlpTYndDYnB4TDU0c3c9PTwveGVuYzpDaXBoZXJWYWx1ZT48L3hlbmM6Q2lwaGVyRGF0YT48L3hlbmM6RW5jcnlwdGVkS2V5PjwvZHM6S2V5SW5mbz48eGVuYzpDaXBoZXJEYXRhIHhtbG5zOnhlbmM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDEvMDQveG1sZW5jIyI+PHhlbmM6Q2lwaGVyVmFsdWU+WkxHcVRSSS9vRk01WGJ0RnV3MGRjRUxsYUFDRkZielF5RC96ek5LVXliMkpiZU5OdUhaZzk2djJrMjRXSkVjV1NyWU5RS3F6U1FtdytMVzhxSG5COTBJYVVkRWZMa3BiL3huTGprUFZWempZYTAzdVdhYTVyOXNLRnVqbUJFTGYyKzA1UGR1bjJXVGFYdmhqWW5HQXk2QnJUcmpzbVZlVGdDODRGcTRHTHVnNmYwcEF6NmRjZG5RRDRnTXJHU2ZVOGgzMnRReFRUUU9Yak4yVFpsQjQ1djFNYkdVdGhiN0U5em1iS1NhRVZEdC9ETVdOMzhYVzBmRU5qcDlZMXV5VS9WSUovdG43TVRnMTIxRHAvMWZYbDdzRmlxS1pPMDNXMkZKNDVBUERaWG1TYUluYnd5TklyczczQVlTb2F4MEpqeUttMDQ0SVNxMXZBL3RDWWEyN0g0WElmUU9rNFVHOGUwK2plSlNvNEhtRUp5bENlT1VhYjRsVk5NUVRBdTRxV2FTMld2TUtLdUI4ZkhFSCs1RTJzVTFlalQvbTN0MnZBZXJJYS9jOUFRRmQzTHNxRGZOZElxSldxRmVOczJyZXhINi9YNGp3TWtTZ3R3VXM2V09JK1hVL05YMmsyYTJydjk3ZFVZMDdsajFLTnlRK1VFSGd2TzJJWXpnaUVjU3N6Q01sRTN3YlBZS2oweDhOdGdIWmtmMzE2Z3pTdWFQRzRnNHluREx3ZmNtQjNOWFRGWk13eVJpbVJFcWkvZlNTZ1hUNWk1bVd6cUx1dDQzVGpKR3lzcjBxTjhRSTNvakw3S2E0MytJTVhNejRPeEtBdE5oTzd1ODV6NWRVemxSbE5qUUdBOGtta0d1dFJlN0kxYU5rQ3cwcW9TUldzTFNoOEtrNGdsTWpsVVFEK1V6VHVqdVhucU43djBJcFFUeStJYnMvSTBtcEswQVdyZ3JMc3NINlhmeUVSQ1ErS2ZNSmNTWVhVQXlGWFQ4MDVWbnlOUmIvajBWaXcwQ2ZuM0JMY1hjZG9nRXJHSVhNYm11R0syVjR0OGZQb2FXYzQwZGlYNHhzZVZOaTRzbEtOTUFJVVN4ODVVYk1TWnlLZDhscTF5M1UydFdrT1RLTWtHQTB6c2g0MDE5NTlWcHUzbVJva0lvNjlLZHFmMk5TdkQ0Y3c5MXM4ZHpvbllQa2c0Tm5KLzlFVkpDRHIrMUxVNnkrVXI1MEdRQ2Z2WVN6YTl5SXh3VHpzNkNSRzF1QllITkU0LytUdTdkVy9pUUVsUGU4dGE3c0hTRXA0OWpQUDVHOVhRb2crUytLbjA3eG4xekRzL1JEbXhDMGg2bnBXejVVUlZUSjVQK2FOVnA4K1gxYmtiLzdVbWhObER4VG5UdVoyeXlKZ1REcUNWV1FUM0h1TEV5ak1sQ3JHUlNlOXhSSzI4b0FoODRMWDdyV2FUS0hqWHlLcEp0K0VKL3FMVU84QkpYUHRzSUxrZjh1anlHeHlyQ3UrS2l0UjQ4OURBYkxvK21pWkZYbm9UUW9zb2dEcHIyaGI5UlpUUGZvY3pXaThOSHRoNk5GWk1NR0J6b2hHTVhVbDZYVXlKSkhPWHJpQ1c4dGVkMTEwRTYvUGRVKzNKR1hmbDExd0J1Vi9lSTRja3F6MGViUnNuK3lBWDJ1RWpISmNaRzc1TXR2aWVyM25IR0ZnZUp6TWFqQWFhMEZMSmRENlF6bVNBaDNlUElRK1BDMjJZaFk1TXZDc0d4cXYxV3o0bXdxMHc0eHFXNzhKYzU5TElXV2VTUFlJOW5yak1mSHU5VFUyU2x2QVNPOHB6eXMwbEpiNlBTUGNpc2hPR1RKeXdDOGRWSnI4eU1jQ1ZtMmp1VjE3a0Q3UUxYdFp5UHloYmlxME9xcGkxM1psUlpheEc3TEpBSk5Ob1p1Z051UDN3bDdzVTZTNkxFeFZrZ2FMUDZndzJndGRzWGlqdGMvOEhmRE56Q1dZdS9YelV5UmNjSkN3QXEyd1Qxc0NnVnd5czc4dGwxV1RzaXdFV3VtU2FyWUtDUmZqK2JwYmlmYjY4cUVxQVZFZHdQeWNZNVA1QS9VSUxxbkRDdXhPckVtdSsvVjc0VTVreTJWWm51RUg4S2R4ck9DTXY0dTQ1Nk9SS0hObEpYUG1jVVhyVnZaSnBVSVhqdjdDQ0dnYkRIbDM5R2VJbkhMQkdVeWs4TU9iNXc0L3crR25jNGtNSDVsRGptb2tTa2ZGS1BJZUgySUNPaHVWUjk0ejhZZDMyQ2VYRndPemNGWkxiVnhJb2w2Y2IzTVNGdDh2SzB5SnYycEJIY2xUdVB5MzNHN3ZManlRbndGeEpkSFl3WU9nS2pEMjFTMWZXSWFDTVpiQXJpQjVlZ3AxcUJRTHhaTi9pRVBUV3EvNzA0K2RnT2hEUzRqMHp2SkdSWUE3SndxTnErS2JudElETEZVVWFoSU1pRnI2Qm9MVjNUcStKNEp3eFZHYzdwSmg4dEdqbExHTEFDWE5NaVBLY0x3UHlIT0I5YXJFTTVoMHNSUUZMaDEyWk9QWGRWTHdSZVMwYkh5RGQ3cW1MWk5XaURodE1GL2lxNW9QZDBhdkgzdmJXTSs3RTNxU29FalFkOEZ6di9UNFlEMXVsMlFwaVdnUlNHUmlBQ1dzdUhlcHZodXl0d01wWG01L2V0WVdZNHJTOXNkRmpZMURVb3pwa0l5TTU3ZFZDY3pKREIxVTdIUW5ic2JRNXB6V3V3bmp0TFBRWlpPME5ibW0wYXNnVDBnUEVlY3hRdS9PY0Z5QTFhZ0FGS0g4TVMyMys4eDlyYTJrTytQbDNkY2RXM05TK3FXRGxWaXRhT2NnRXhFOURYbjlHd2JmYnBDU0JoaUR3ZU9NQW94SUtQNWVqeWZUVlU3SzZSS1VoQzh3NFFUYWtka053cHlaMVlPNVRrRjAxMXFLZ2FHUG9HeUJrY2lpeGpyWDY0cEJaSUxTLzJUWjV4WUtnREpmUlJkVnBldXFncW1VdHMyaUM1cDdFdmo1Q3pXdHpSbFd6T0xKdGtuTW13MWdwMFl4Q1AzSUhvUXFFdURNUDhJMXBmc3NVdmpOQ1BsUXRIU0VTTDVhY3pyNmhzK0NhN0RqUjl5MkxTVWFsVjFYeDNkdFlXTDdOS05kRHJyNU1GK3c2ZUx0NU1aZnZoVWRxb3cyZU1qZnk0Q1F3S1NQVWF4cWhUQUhCQTlmRzVWYUczNEFIcU5Xc2hJdFRMZW1scyt6QXpabGdsWE5GQ0syY1ZjLzdRNmxUTlk4dUNLVW5yVE4yWVZzYmszK3hIOU1vTjg3c0t3aHhacy9TcXhKTUxtL3ZsbE1KejNiclRCZGRFaU9CNC9Qc3M0dUZMV2ZNQWViL09FRy9MS1JJeDNtWnVhOVR6TW9hUTViOWZ3RkNDM3AwTmRuV0piZ2pvcnRCK084clJkZEdFSHpQdnNaTjZzQlZHbUd2Y3Bqa1BKQUZERUtwYlRQcjFqMGtxb2MvSXdsVWVDaGttMktiODhZUU1GRXcxWlVSQm5PcG5sZnU2YmFsb2pGazJpVkF0dVRWM1N2Q1lFc2NMOHFkVmNheGpwQUxpTFhSQS9VVThJSzhOMm9wWFM2WmcwekRTcVRoL1RyU3hSWHdJOUxuWXcvNGJlMEJxQmcrSWlqUUY2ZS92bXAwU1NmOU5NMVNOZkVRdjBEdW0zZ2NIUDRUU0lYNVFtVUJDMnU1N1hhZ1JCWG1KVFRKcnJaV3AxK3cvWGpKRFVQTnZYZzZXWUljYWsrNXdMWHZJY3pvYm93UGdYd1lJYnUydVA4TDdhV0VjOUE0bnJwcDdmcFFNNG42TnZFbDA3SU5oMWhyVmRYVjhlSWx3UEd6by9vd09Vbkg1V2krWG4xdHBLbEN1c0JyVU9hTFE5Q1cxV3pmTnNBVEtKSGFzUnkwWkdSS3htQVhleVpmTmliY2lHRTNOeE9ueU5SUFdoOVdSVFNsK0l1MWl5WXF6U1hNaHh2SkFJcXcraFlmUDJXVEZOVmJ4OFF2L0QwSVhWbStVTlJEbVF1Qk1nS3NsR0xmMHgySnVTNzROWXJHQUJPK3o0V05CbHVkcjhQRzRTbTBVc2dkaXFSYUlpWnBjMExCNFhSS3VLL3gvcGNrUFNRb1F3VzdZdXR4bEY2VGp0VVE1ZEpmN3hJWGZ0T3QvRjNaRDNCU2RHK3djeGZLRU5TMHljQWkrWHk0WHp4QzNKMnRORE5CT05ra3VPcC9DVURhQTVjUjdpYXRaN0NzUnF6VjgvK2t4a3VlcXkzeDdURzgwTGZKSTk5cEluOCtINFMyaFNBVURMM0NPd1p4NUZYbDBIUEloaVhZV212V3JXNUtEbjYwL3hpNjE0ZFpnUERXdDRuMDJvaU9CbHNSS3NZZFp1M2lXS1NXb0w0b29mNE5YZmZqL3ArZnFxd0Z4b0hZRHkrcDc3K2JKL0E0L2NFYS9HWm43aVVuMUdrV0FkeXJtU0VVc0JNS2tXUTJtdkpzTW41YXg4aHJ3N2RqOEsvTlJraitqTGE2UHZ1SmpjWnltM284eFZIMDJIeU1MdEl5TmN1SVhGT2p2QXBnZFNpQ3BnRmplYnhBVjk3R3JxcmNUOTYrZWR3TjYzRzEzWGpJU0ZYY1YxR0t0aU95akUyUW4zandMQXJZZmJkRy9hemhQcGVINERZZ0IxblpmUms4d3ZCejI2M2dBWVdodXhGTW41dDBrZnNpbzkzQ25Bd0gxSWhPNDVWdWVwV0p2RmJFU0lRc1JsYWZqTWE1aG1rdThKcnI5b2R0Rmxxczdpa0c2RUdOb0ROZWl4T3JqRmJ1enBoNzBMQ2llMkRNSlV2dlpSUnlwTDlseVdXczlQTE9EcEJOMWY1MDRKREVGUWw2clV2b1RwTVFGUkx1S01mdG9ySGd3eGloOTFxa3pBT1RHZkdKTjZYY3AwOVlZRjhpYWtXUis4NnFieWdXd21kb3hyaXZDQVo4SEpwZmpGdzRwVGVXNDdsZWI5blRqbURWUlRCWHBaMTFQdVZIYmJZWExwZGdwSStMWUplZ2EvY3NOTDUzWDFYeUNyeHN6R29NZ2FxeklqeEpTVEZlTURzdnFJZDhQRGkzSC9zS2VTSXhPdy9OMFk4bkhuOUhoeUtaOVVoQU41OHdYRVM2eXk2UUFtR1EzZnk0YVlRWklGUUNZcXRYQWk0dUY5RkdZU1E1ZW8wM2hKbTRMSkZkQzhZUWxwYTJpU2tZd2VNWmplUWhYWC9zOU5NUk1nMU4vVjlraWYwTnNFK3BhK0pDUk9qbUl1WXVxMzEzZ3lmQVA1K1lyZGpxK2M5ZFRBMkN6dkdDemNSVFRIMHRVMHBKd1R5bmZPb1pqTHp4d3RsQXVPMEdNeEdyY1lNTmdNVWxmOXkvMlVmaDYwZVRuNDl6SGllcEZ0ek5ZMTZndmVaWWk0Z216Qmx2eFZ6N1A3a2wvLzQrT1ExNXJTc0tKSnh0UjkrYUt5a0tvWnJGclp6Mld3QXMwcHM2Snl0Y2pQeUNEYlhvTjZ1WlRSTkUxRGYzU2Z0TnFUSVhMVTdGRGcwZi92blhBejJNaHBPOTlEQmYvcys5ckxtbVhSd2JKV1dqc3JOeW5hWFFlSU5GVUk3b1AyTE1Db0JUbzNIWEMyL0x1dDBzTFg0aVlzNTN5RVNvYWlWa1RrMC91MmFzcEs5WS8rVXhrODVyTnNJcUdsUXFsb25Rem90RThyK2ZuM2syckJzaWtlbTNVWTJMQldqcVVRaklxTlErU3gxbkVSRys4SXk1N2ZIZkxGR09xa0t6MmJFN1RMZ25aUnlQNmZDMXJvcTNzUVdqQXBCUU1SRkkwWGFqSjZVR3pHcUlLTGF1R09NMVdiZzdqaWVGcEl0dE56NktDcVJhUTZ0a1liK0loSml5TzBYR3lOdXpkWjBKUFpPZDZyaXlCWU1iaFRxM0ljYXNYU2JwMklsWEtuamdXM1hybUsxZ1h0Mm1HQlJmN1VtZmcrY1dFd1hoMnYvVTBjdWxnbzJ4NllFL01lMVY0UmtnQjlPWHRSY2FERkkwTTg3WHBjYTBVTVF1VHdsK1p2cG41enZWWXNNb3lsdmd4OGY5UkUzT3pmYVFKK2ZkRG54VUZqNnJrWlpVRER2NmNoakZiaEZRSStFWWpjYnJLVnlTcW9MbFI3UFh5UFpibjhZZVU1OGhtNWtOdmFyRXRkbXNFcHNXUEZJZjg4RXpHODJxNHBxQlNSNUJUV1NyRFIzQnVTVi9GZUdkWmdoano2L1hFQnovRHY1ZUtpSitLMHFaaVZVUWMzWEZnTXlGSG11YXV1T1VoSW9kbWYxN3ljS0VPcVdzSUdtcURJVzVwZC9JL0dzNlFNYUFCNXRMZ1Boc2hRNE1oM082aGt0OEMwVlBkTHhhZmIvMGt0VjJzd1NjS1FRSXRCZUNFM0YyZ2Z6OE5oTTFYUUlleGQrTFBCc1lCaGNMcTlVaUJ4S0xFeG54U21hbERJYWgwbWRtUGpjMGZsMXZwNlZwcnRocjViL3dpd2txM01mb09SRERiZjZBTmhuaEFsRkEwTXN4b2tabHFEcDJFKzdhZncvSmxNZGZ5cmFxYm93aUxXTnhVcFFOYlF1SUplc2JvRFkySjBsU1JnaEl4WmMzUmVZWlFZeHAwWFBOLzBzVUV4TjFSdXl6SHAwK2Y3ZFA4R1d6eEVyNkNJSW55cXNFdjVnNkQzNzJhZUxTczFqcXQxVVZYSjwveGVuYzpDaXBoZXJWYWx1ZT48L3hlbmM6Q2lwaGVyRGF0YT48L3hlbmM6RW5jcnlwdGVkRGF0YT48L3NhbWwyOkVuY3J5cHRlZEFzc2VydGlvbj48L3NhbWwycDpSZXNwb25zZT4=
|
@@ -0,0 +1,18 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Xmlenc do
|
4
|
+
|
5
|
+
Dir["spec/fixtures/encrypted/*.txt"].each do |document|
|
6
|
+
describe "#{document}" do
|
7
|
+
let(:encrypted_xml) { Base64.decode64(File.read(document)) }
|
8
|
+
let(:encrypted_document) { Xmlenc::EncryptedDocument.new(encrypted_xml) }
|
9
|
+
let(:private_key) { OpenSSL::PKey::RSA.new(File.read(document.gsub('.txt', '.pem'))) }
|
10
|
+
|
11
|
+
it "should be validateable" do
|
12
|
+
expect {
|
13
|
+
@decrypted = encrypted_document.decrypt(private_key)
|
14
|
+
}.not_to raise_error
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: xmlenc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Benoist
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-
|
11
|
+
date: 2015-04-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -140,6 +140,8 @@ files:
|
|
140
140
|
- lib/xmlenc/encrypted_document.rb
|
141
141
|
- lib/xmlenc/encrypted_key.rb
|
142
142
|
- lib/xmlenc/version.rb
|
143
|
+
- spec/fixtures/encrypted/java_to_ruby.pem
|
144
|
+
- spec/fixtures/encrypted/java_to_ruby.txt
|
143
145
|
- spec/fixtures/encrypted_document.xml
|
144
146
|
- spec/fixtures/encrypted_document_no_ref_list.xml
|
145
147
|
- spec/fixtures/key.pem
|
@@ -171,6 +173,7 @@ files:
|
|
171
173
|
- spec/lib/xmlenc/encrypted_document_spec.rb
|
172
174
|
- spec/lib/xmlenc/encrypted_key_spec.rb
|
173
175
|
- spec/lib/xmlenc/phaos_compat_spec.rb
|
176
|
+
- spec/lib/xmlenc/xmlenc_spec.rb
|
174
177
|
- spec/spec_helper.rb
|
175
178
|
- xmlenc.gemspec
|
176
179
|
homepage: https://github.com/digidentity/xmlenc
|
@@ -193,11 +196,13 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
193
196
|
version: '0'
|
194
197
|
requirements: []
|
195
198
|
rubyforge_project:
|
196
|
-
rubygems_version: 2.4.
|
199
|
+
rubygems_version: 2.4.6
|
197
200
|
signing_key:
|
198
201
|
specification_version: 4
|
199
202
|
summary: A (partial)implementation of the XMLENC specificiation
|
200
203
|
test_files:
|
204
|
+
- spec/fixtures/encrypted/java_to_ruby.pem
|
205
|
+
- spec/fixtures/encrypted/java_to_ruby.txt
|
201
206
|
- spec/fixtures/encrypted_document.xml
|
202
207
|
- spec/fixtures/encrypted_document_no_ref_list.xml
|
203
208
|
- spec/fixtures/key.pem
|
@@ -229,4 +234,5 @@ test_files:
|
|
229
234
|
- spec/lib/xmlenc/encrypted_document_spec.rb
|
230
235
|
- spec/lib/xmlenc/encrypted_key_spec.rb
|
231
236
|
- spec/lib/xmlenc/phaos_compat_spec.rb
|
237
|
+
- spec/lib/xmlenc/xmlenc_spec.rb
|
232
238
|
- spec/spec_helper.rb
|