mirror of
				https://github.com/Instadapp/Swap-Aggregator-Subgraph.git
				synced 2024-07-29 21:57:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			172 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
| import * as asmCrypto from '../asmcrypto.all.es8';
 | |
| import chai from 'chai';
 | |
| const expect = chai.expect;
 | |
| 
 | |
| const pubKey = [
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     'c13f894819c136381a94c193e619851ddfcde5eca770003ec354f3142e0f61f0676d7d4215cc7a13b06e0744aa8316c9c3766cbefa30b2346fba8f1236d7e6548cf87d9578e6904fc4291e096a2737fcd96624f72e762793505f9dfc5fa17b44611add54f5c00bf54373d720cb6f4e5cabae36c4442b39dbf49158414547f453',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes('10001'),
 | |
| ];
 | |
| 
 | |
| const privkey = [
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     'c13f894819c136381a94c193e619851ddfcde5eca770003ec354f3142e0f61f0676d7d4215cc7a13b06e0744aa8316c9c3766cbefa30b2346fba8f1236d7e6548cf87d9578e6904fc4291e096a2737fcd96624f72e762793505f9dfc5fa17b44611add54f5c00bf54373d720cb6f4e5cabae36c4442b39dbf49158414547f453',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes('10001'),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     '75497aa8a7f8fc4f50d2b82a6b9d518db027e7449adaff4b18829685c8eecd227ba3984263b896df1c55ab53a1a9ae4b06b6f9896f8fde98b4b725de882ac13fc11b614cb2cc81bcc69b9ad167dda093c5c6637754acd0ec9e9845b1b2244d597c9f63d7ea076bda19feadcdb3bd1ba9018915fec981657fb7a4301cb87a3e1',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     'ef2f8d91d7cd96710d6b3b5ea1b6762b4214efe329e7d0609ab8419744ef8620391e423d5890c864aebb36c0daf5035d27f3427e6a84fde36466a14b56ad1cfb',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     'ced5477e0acb9c836c3c54e33268e064ce8cdfd40452c8b87ab838b36b498ae22fdbdb331f59f61dd3ca1512143e77a68f8f2400dbe9e576a000084e6fcbb689',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     '227882f9a2d5513a27c9ed7b7ce8d3ecf61018666fb2a5f85633f9d7f82a60f521e6377ba9d8ebd87eca2260f6ed5ab7c13b30b91156eb542b331349cd4b13a3',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     '4dea2a3460fcb2c90f4ceaed6b5ff6a802e72eaa3fb6afc64ef476e79fd2e46eb078b1ea60351371c906a7495836effbdeb89d67757076f068f59a2b7211db81',
 | |
|   ),
 | |
|   asmCrypto.hex_to_bytes(
 | |
|     '261a93613a93e438fa62858758d1db3b3db8366319517c039acfcc0ce04cd0d7349d7e8d8cb0e8a05ac966d04c18c81c49025de2b50bb87f78facccd19cd8602',
 | |
|   ),
 | |
| ];
 | |
| 
 | |
| describe('RSA', () => {
 | |
|   it('asmCrypto.RSA.privateKey', function() {
 | |
|     const m = new asmCrypto.Modulus(new asmCrypto.BigNumber(privkey[0]));
 | |
|     const e = new asmCrypto.BigNumber(privkey[1]);
 | |
|     const d = new asmCrypto.BigNumber(privkey[2]);
 | |
|     const p = new asmCrypto.BigNumber(privkey[3]);
 | |
|     const q = new asmCrypto.BigNumber(privkey[4]);
 | |
|     const dp = new asmCrypto.BigNumber(privkey[5]);
 | |
|     const dq = new asmCrypto.BigNumber(privkey[6]);
 | |
|     const qi = new asmCrypto.BigNumber(privkey[7]);
 | |
| 
 | |
|     expect(p.multiply(q).toString(16), 'm == p*q').to.equal(m.toString(16));
 | |
|     expect(
 | |
|       e
 | |
|         .multiply(d)
 | |
|         .divide(p.subtract(asmCrypto.BigNumber.fromNumber(1)).multiply(q.subtract(asmCrypto.BigNumber.fromNumber(1))))
 | |
|         .remainder.toString(16),
 | |
|       'e*d == 1 mod (p-1)(q-1)',
 | |
|     ).to.equal('1');
 | |
|     expect(
 | |
|       d.divide(p.subtract(asmCrypto.BigNumber.fromNumber(1))).remainder.toString(16),
 | |
|       'dp == d mod (p-1)',
 | |
|     ).to.equal(dp.toString(16));
 | |
|     expect(
 | |
|       d.divide(q.subtract(asmCrypto.BigNumber.fromNumber(1))).remainder.toString(16),
 | |
|       'dq == d mod (q-1)',
 | |
|     ).to.equal(dq.toString(16));
 | |
|     expect(
 | |
|       qi
 | |
|         .multiply(q)
 | |
|         .divide(p)
 | |
|         .remainder.toString(16),
 | |
|       'qi*q == 1 mod p',
 | |
|     ).to.equal('1');
 | |
|     expect(m.slice(m.bitLength - 1).valueOf(), 'm highest bit is 1').to.equal(1);
 | |
|   });
 | |
| });
 | |
| 
 | |
| describe('RSA-OAEP', () => {
 | |
|   it('asmCrypto.RSA_OAEP_SHA256 encrypt/decrypt', function() {
 | |
|     const cleartext = asmCrypto.string_to_bytes('HelloWorld!');
 | |
|     const rsaOaepEnc = new asmCrypto.RSA_OAEP(pubKey, new asmCrypto.Sha256(), asmCrypto.string_to_bytes('test'));
 | |
|     const rsaOaepDec = new asmCrypto.RSA_OAEP(privkey, new asmCrypto.Sha256(), asmCrypto.string_to_bytes('test'));
 | |
| 
 | |
|     const ciphertext = rsaOaepEnc.encrypt(cleartext);
 | |
| 
 | |
|     const result = rsaOaepDec.decrypt(ciphertext);
 | |
|     expect(asmCrypto.bytes_to_string(result), 'decrypt').to.equal('HelloWorld!');
 | |
|   });
 | |
| });
 | |
| 
 | |
| describe('RSA-PSS-SHA256', () => {
 | |
|   it('asmCrypto.RSA_PSS_SHA256 sign/verify', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha256());
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha256());
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text));
 | |
|   });
 | |
| 
 | |
|   it('asmCrypto.RSA_PSS_SHA256 sign/verify with non-default salt length', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha256(), 32);
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha256(), 32);
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text));
 | |
|   });
 | |
| 
 | |
|   it('asmCrypto.RSA_PSS_SHA256 sign/verify with salt length mismatch', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha256(), 4);
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha256(), 32);
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     expect(() => rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text))).to.throw;
 | |
|   });
 | |
| 
 | |
|   it('asmCrypto.RSA_PSS_SHA256 sign/verify with default salt length mismatch', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha256(), 32);
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha256());
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     expect(() => rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text))).to.throw;
 | |
|   });
 | |
| 
 | |
|   it('asmCrypto.RSA_PSS_SHA512 sign/verify', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha512());
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha512());
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text));
 | |
|   });
 | |
| 
 | |
|   // This requires a RSA2048 key instead of RSA1024
 | |
|   it.skip('asmCrypto.RSA_PSS_SHA512 sign/verify with non-default salt length', function() {
 | |
|     const text = 'HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!HelloWorld!';
 | |
|     const rsaPssSign = new asmCrypto.RSA_PSS(privkey, new asmCrypto.Sha512(), 64);
 | |
|     const rsaPssVerify = new asmCrypto.RSA_PSS(pubKey, new asmCrypto.Sha512(), 64);
 | |
| 
 | |
|     const signature = rsaPssSign.sign(asmCrypto.string_to_bytes(text));
 | |
|     rsaPssVerify.verify(signature, asmCrypto.string_to_bytes(text));
 | |
|   });
 | |
| 
 | |
|   it('asmCrypto.RSA_PSS_SHA256 verify OpenSSL-signed-data', function() {
 | |
|     const key = [
 | |
|       asmCrypto.hex_to_bytes(
 | |
|         'f30be5ce8941c8e6e764c78d12f3ce6e02a0dea03577bc0c16029de258321b74ceb43ea94f768aec900011c78eb247ab0e94b4477ea8f086ba7b5ce4b03c0ad7e0bf2f54ed509a536a0f179e27db539f729b38a279873f7b3a360690c8390e289dedca6da1ba232d8edc3c1eb229e1072716ddf3ef88caf4a824c152d6ad38f1',
 | |
|       ),
 | |
|       asmCrypto.hex_to_bytes('10001'),
 | |
|       /*
 | |
|             asmCrypto.hex_to_bytes('a2f4032c2ad2b4843bf851e2c0263eed7b4da875f9e3416d4904901ec5cb32a56a416711d5794143c278897326b5595fd2f2d8bc66ab96387ea75f6ce4cc1ce7ba0269a49ce03eb4aea16ca914938e88e5398b10b314276ba9f3f2e448a5f643515ee591cb4c4c5270edccacf7e5b88f86a0c08dc05311513a4ed01802de2511'),
 | |
|             asmCrypto.hex_to_bytes('fc592285e370d57900bfd2f8c66b15274b3381ca7ec485091d5aa0092ca8f2b97f8796e608a2fc6aa1df3647b10198c49801e3201fefa72ef9d7ccafcdae5d37'),
 | |
|             asmCrypto.hex_to_bytes('f6904d99d7cf9f1237c6798e5343fe730149be31e0363bf33039af84a09b5e9d0dd71239384b6cf6421e4ad41097b2cd09fd0114eb29a4339c433f37d7286f17'),
 | |
|             asmCrypto.hex_to_bytes('252e1ce00d3abab9315b12028579918c50902e375fa624d3caf7674cf2bf91c3b2fe8f4525509e5037b9638dfc8e77abbf99c7951c1f7b4a78954b1b3bfaccd1'),
 | |
|             asmCrypto.hex_to_bytes('9f036da89c10208cc53fd14142de0509f278b69abff8fa2cda9b3961159b5e2777b78edf2c3928aaa0f59c58abe2c9c3867f8ee508ccb04340b1f5e17377763d'),
 | |
|             asmCrypto.hex_to_bytes('c07e9ca15c2cc38cc4faab0729403e02b33982b7d1219e15cd74614f3485437d2c800d66a0c368b3cf36513e4b1e05d31d7e0186f00cf036433e35f13b5cfda8')
 | |
| */
 | |
|     ];
 | |
| 
 | |
|     const text = 'Hello There!';
 | |
| 
 | |
|     const signature = asmCrypto.hex_to_bytes(
 | |
|       'A68BE713861409B4E536C12066B3D30650C7578F9B7AB61C1A302B42ECA14D58AE11899BC55FCB838F0AE06B99381DE26CE8D6318BD59BBFC4FFF56A995E9EFB0306FF105766F508297D1E74F22648B6BD66C18E06F4748BD258358ECB5BB722AC4AFFA146C04EE7BE84AD77ED2A84B5458D6CA4A7DA4D86DAB3F2B39FD647F4',
 | |
|     );
 | |
| 
 | |
|     const saltlen = 32;
 | |
| 
 | |
|     const rsaPss = new asmCrypto.RSA_PSS(key, new asmCrypto.Sha256(), saltlen);
 | |
|     rsaPss.verify(signature, asmCrypto.string_to_bytes(text));
 | |
|   });
 | |
| });
 | 
