fix(core): update
This commit is contained in:
		
							
								
								
									
										64
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										64
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -199,23 +199,23 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smarthash": { |     "@pushrocks/smarthash": { | ||||||
|       "version": "2.0.6", |       "version": "2.1.6", | ||||||
|       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmarthash/-/smarthash-2.0.6.tgz", |       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmarthash/-/smarthash-2.1.6.tgz", | ||||||
|       "integrity": "sha512-jHk9srgRLkszk/oPCUOkxTX2Fqu7qKwx13aEeSIBx8UCtFbXPLecJAqEaGEVk1mw9e4Oq0iC6O0jEnxKo5NQwA==", |       "integrity": "sha512-TYa3wECYkeDoE8SomxcCJFg5Kt4+G4MtNMu3yATJCCoPLJIbyV1CwUvYuFYkkce2W4ZvH9h/N6dsHc69oI5Jcw==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@pushrocks/smartjson": "^3.0.5", |         "@pushrocks/smartjson": "^3.0.10", | ||||||
|         "@pushrocks/smartpromise": "^3.0.2", |         "@pushrocks/smartpromise": "^3.0.6", | ||||||
|         "@types/through2": "^2.0.34", |         "@types/through2": "^2.0.34", | ||||||
|         "through2": "^3.0.1" |         "through2": "^3.0.1" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smartjson": { |     "@pushrocks/smartjson": { | ||||||
|       "version": "3.0.8", |       "version": "3.0.10", | ||||||
|       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartjson/-/smartjson-3.0.8.tgz", |       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartjson/-/smartjson-3.0.10.tgz", | ||||||
|       "integrity": "sha512-EjC3611RSZaZmK+nXxXrYDBxdxYWtrxjOrZtQzbYn0yM33KSCH0sLIAG8B2wYZVAOj4A2pC8mVxFSJ1w3iRFHg==", |       "integrity": "sha512-0tBkET2yjmSSIf4DlgeyU8U/J2EshTmQGuMY28EjPq9VvuCFXLh72WmETpA4QqKRMqhWp1+P+RZgnQupW3GQxQ==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@types/fast-json-stable-stringify": "^2.0.0", |         "@types/fast-json-stable-stringify": "^2.0.0", | ||||||
|         "fast-json-stable-stringify": "^2.0.0", |         "fast-json-stable-stringify": "^2.1.0", | ||||||
|         "lodash.clonedeep": "^4.5.0" |         "lodash.clonedeep": "^4.5.0" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
| @@ -248,20 +248,20 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smartmail": { |     "@pushrocks/smartmail": { | ||||||
|       "version": "1.0.6", |       "version": "1.0.8", | ||||||
|       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartmail/-/smartmail-1.0.6.tgz", |       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartmail/-/smartmail-1.0.8.tgz", | ||||||
|       "integrity": "sha512-dQZi8FOLVfX6qo7b73HQ5SgdMHpS1mHNJTbwpgVT/XlhVCdreXfrAbFLVXECH4EZ8WYt9KoSUo4zHSw31g97sw==", |       "integrity": "sha512-ILUmtrJ0TlBe183/LXmJYAq268NueB6A0vA75qqR9+DeZjBAuYOcIAJxLOXyxtMcG/pSnr+AKTDBzsRn/RMz1g==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@pushrocks/smartfile": "^7.0.6", |         "@pushrocks/smartfile": "^7.0.6", | ||||||
|         "@pushrocks/smartmustache": "^2.0.8" |         "@pushrocks/smartmustache": "^2.0.9" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smartmustache": { |     "@pushrocks/smartmustache": { | ||||||
|       "version": "2.0.8", |       "version": "2.0.9", | ||||||
|       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartmustache/-/smartmustache-2.0.8.tgz", |       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartmustache/-/smartmustache-2.0.9.tgz", | ||||||
|       "integrity": "sha512-bnOST5zKPKSpCUiYqSHRdJ4NpO3/xz3LLtNE+xfWLS9Eyor/dIapqOpqwmZXNYr8QZuZWC//dlTIiQcv02D8Rg==", |       "integrity": "sha512-Wumikw03se8/hpPDyBUt0o/JynkNLhuv667jUYyXmTbs4DLnlRAwTpLTYDUoaJpNWsCN3Jg9AgVSrteRozbFig==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "handlebars": "^4.4.5" |         "handlebars": "^4.7.1" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smartparam": { |     "@pushrocks/smartparam": { | ||||||
| @@ -294,9 +294,9 @@ | |||||||
|       "integrity": "sha512-vlQlBGNVIjfClgnsfgQBU6GIKcskYSFzEcKLt18ngPzPEcjKklXcxaqzLXpnoxR+KBh30QPE8255ncYHXuPPOg==" |       "integrity": "sha512-vlQlBGNVIjfClgnsfgQBU6GIKcskYSFzEcKLt18ngPzPEcjKklXcxaqzLXpnoxR+KBh30QPE8255ncYHXuPPOg==" | ||||||
|     }, |     }, | ||||||
|     "@pushrocks/smartrequest": { |     "@pushrocks/smartrequest": { | ||||||
|       "version": "1.1.43", |       "version": "1.1.47", | ||||||
|       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartrequest/-/smartrequest-1.1.43.tgz", |       "resolved": "https://verdaccio.lossless.one/@pushrocks%2fsmartrequest/-/smartrequest-1.1.47.tgz", | ||||||
|       "integrity": "sha512-bgzzKN9SxJaYhh+BN3tuLSgdphWsxAOHgNjWWay3o/ib8/c2RwRlmjoxzxXrIhKFEwJjGIo7w04045VgkoWkMQ==", |       "integrity": "sha512-0AuqtAI14VeWeXl2WpJbgCybVlG03rOjdGchAqy5k5lg9ACLhN3Z4kmoLgpBysWO/L2SjlAKB489SRyV3acykg==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "@pushrocks/smartpromise": "^3.0.5", |         "@pushrocks/smartpromise": "^3.0.5", | ||||||
|         "@types/form-data": "^2.5.0", |         "@types/form-data": "^2.5.0", | ||||||
| @@ -793,9 +793,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "fast-json-stable-stringify": { |     "fast-json-stable-stringify": { | ||||||
|       "version": "2.0.0", |       "version": "2.1.0", | ||||||
|       "resolved": "https://verdaccio.lossless.one/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", |       "resolved": "https://verdaccio.lossless.one/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", | ||||||
|       "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" |       "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" | ||||||
|     }, |     }, | ||||||
|     "figures": { |     "figures": { | ||||||
|       "version": "3.1.0", |       "version": "3.1.0", | ||||||
| @@ -875,14 +875,14 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "graceful-fs": { |     "graceful-fs": { | ||||||
|       "version": "4.2.2", |       "version": "4.2.3", | ||||||
|       "resolved": "https://verdaccio.lossless.one/graceful-fs/-/graceful-fs-4.2.2.tgz", |       "resolved": "https://verdaccio.lossless.one/graceful-fs/-/graceful-fs-4.2.3.tgz", | ||||||
|       "integrity": "sha512-IItsdsea19BoLC7ELy13q1iJFNmd7ofZH5+X/pJr90/nRoPEX0DJo1dHDbgtYWOhJhcCgMDTOw84RZ72q6lB+Q==" |       "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==" | ||||||
|     }, |     }, | ||||||
|     "handlebars": { |     "handlebars": { | ||||||
|       "version": "4.4.5", |       "version": "4.7.1", | ||||||
|       "resolved": "https://verdaccio.lossless.one/handlebars/-/handlebars-4.4.5.tgz", |       "resolved": "https://verdaccio.lossless.one/handlebars/-/handlebars-4.7.1.tgz", | ||||||
|       "integrity": "sha512-0Ce31oWVB7YidkaTq33ZxEbN+UDxMMgThvCe8ptgQViymL5DPis9uLdTA13MiRPhgvqyxIegugrP97iK3JeBHg==", |       "integrity": "sha512-2dd6soo60cwKNJ90VewNLIzdZPR/E2YhszOTgHpN9V0YuwZk7x33/iZoIBnASwDFVHMY7iJ6NPL8d9f/DWYCTA==", | ||||||
|       "requires": { |       "requires": { | ||||||
|         "neo-async": "^2.6.0", |         "neo-async": "^2.6.0", | ||||||
|         "optimist": "^0.6.1", |         "optimist": "^0.6.1", | ||||||
| @@ -1579,9 +1579,9 @@ | |||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "uglify-js": { |     "uglify-js": { | ||||||
|       "version": "3.6.4", |       "version": "3.7.5", | ||||||
|       "resolved": "https://verdaccio.lossless.one/uglify-js/-/uglify-js-3.6.4.tgz", |       "resolved": "https://verdaccio.lossless.one/uglify-js/-/uglify-js-3.7.5.tgz", | ||||||
|       "integrity": "sha512-9Yc2i881pF4BPGhjteCXQNaXx1DCwm3dtOyBaG2hitHjLWOczw/ki8vD1bqyT3u6K0Ms/FpCShkmfg+FtlOfYA==", |       "integrity": "sha512-GFZ3EXRptKGvb/C1Sq6nO1iI7AGcjyqmIyOw0DrD0675e+NNbGO72xmMM2iEBdFbxaTLo70NbjM/Wy54uZIlsg==", | ||||||
|       "optional": true, |       "optional": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "commander": "~2.20.3", |         "commander": "~2.20.3", | ||||||
|   | |||||||
| @@ -22,8 +22,9 @@ | |||||||
|     "tslint-config-prettier": "^1.15.0" |     "tslint-config-prettier": "^1.15.0" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@pushrocks/smartmail": "^1.0.6", |     "@pushrocks/smartfile": "^7.0.6", | ||||||
|     "@pushrocks/smartrequest": "^1.1.43", |     "@pushrocks/smartmail": "^1.0.8", | ||||||
|  |     "@pushrocks/smartrequest": "^1.1.47", | ||||||
|     "@pushrocks/smartstring": "^3.0.17" |     "@pushrocks/smartstring": "^3.0.17" | ||||||
|   }, |   }, | ||||||
|   "files": [ |   "files": [ | ||||||
|   | |||||||
| @@ -28,4 +28,11 @@ tap.test('should send a smartmail', async () => { | |||||||
|   testMailgunAccount.sendSmartMail(testSmartmail, 'sandbox@mail.git.zone'); |   testMailgunAccount.sendSmartMail(testSmartmail, 'sandbox@mail.git.zone'); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | tap.test('should retrieve a mail using a retrieval url', async () => { | ||||||
|  |   const result = await testMailgunAccount.retrieveSmartMailFromMessageUrl('https://sw.api.mailgun.net/v3/domains/mail.lossless.one/messages/AgMFnnnAKC8xp_dDa79LyoxhloxtaVmnRA=='); | ||||||
|  |   result.options.subject = 'hi there. This is a testmail with attachment'; | ||||||
|  |   result.options.from = 'noreply@mail.lossless.com'; | ||||||
|  |   testMailgunAccount.sendSmartMail(result, 'sandbox@mail.git.zone'); | ||||||
|  | }); | ||||||
|  |  | ||||||
| tap.start(); | tap.start(); | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								ts/interfaces/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								ts/interfaces/index.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | export * from './message'; | ||||||
							
								
								
									
										30
									
								
								ts/interfaces/message.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								ts/interfaces/message.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | export interface IMailgunMessage { | ||||||
|  |   Received: string; | ||||||
|  |   From: string; | ||||||
|  |   'X-Envelope-From': string; | ||||||
|  |   recipients: string; | ||||||
|  |   'X-Google-Dkim-Signature': string; | ||||||
|  |   To: string; | ||||||
|  |   'message-headers': [[string, string]]; | ||||||
|  |   'Dkim-Signature': string; | ||||||
|  |   'content-id-map': any; | ||||||
|  |   subject: 'test2'; | ||||||
|  |   'stripped-html': string; | ||||||
|  |   'X-Mailgun-Incoming': 'Yes'; | ||||||
|  |   'X-Received': string; | ||||||
|  |   'X-Gm-Message-State': string; | ||||||
|  |   'body-plain': string; | ||||||
|  |   attachments: Array<{ | ||||||
|  |       url: string, | ||||||
|  |       'content-type': string, | ||||||
|  |       name: string, | ||||||
|  |       size: number | ||||||
|  |     }>; | ||||||
|  |   'body-html': string; | ||||||
|  |   'Mime-Version': string; | ||||||
|  |   Date: string, | ||||||
|  |   'Message-Id': string; | ||||||
|  |   'Content-Type': string; | ||||||
|  |   'X-Google-Smtp-Source': string; | ||||||
|  |   Subject: string; | ||||||
|  | } | ||||||
| @@ -1,19 +1,20 @@ | |||||||
| import * as plugins from './mailgun.plugins'; | import * as plugins from './mailgun.plugins'; | ||||||
|  | import * as interfaces from './interfaces'; | ||||||
|  |  | ||||||
| export class MailgunAccount { | export class MailgunAccount { | ||||||
|   public baseUrl = 'https://api.mailgun.net/v3'; |   public baseUrl = 'https://api.mailgun.net/v3'; | ||||||
|   public baseUrlSe = 'https://se.api.mailgun.net/v3'; |  | ||||||
|   public apiToken: string; |   public apiToken: string; | ||||||
|  |  | ||||||
|   constructor(apiTokenArg: string) { |   constructor(apiTokenArg: string) { | ||||||
|     this.apiToken = apiTokenArg; |     this.apiToken = apiTokenArg; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   public getRequest(routeArg: string) { |   public async getRequest(routeArg: string, binaryArg: boolean = false) { | ||||||
|     let requestUrl = routeArg; |     let requestUrl = routeArg; | ||||||
|     const needsBaseUrlPrefix = (routeArg.startsWith(this.baseUrl)) || routeArg.startsWith(this.baseUrlSe); |     const needsBaseUrlPrefix = !routeArg.startsWith('https://'); | ||||||
|     needsBaseUrlPrefix ? requestUrl = `${this.baseUrl}${routeArg}` : null; |     needsBaseUrlPrefix ? requestUrl = `${this.baseUrl}${routeArg}` : null; | ||||||
|     const response = plugins.smartrequest.request(requestUrl, { |     console.log(requestUrl); | ||||||
|  |     const requestOptions: plugins.smartrequest.ISmartRequestOptions = { | ||||||
|       method: 'GET', |       method: 'GET', | ||||||
|       headers: { |       headers: { | ||||||
|         Authorization: `Basic ${plugins.smartstring.base64.encode( |         Authorization: `Basic ${plugins.smartstring.base64.encode( | ||||||
| @@ -21,7 +22,13 @@ export class MailgunAccount { | |||||||
|         )}`, |         )}`, | ||||||
|         'Content-Type': 'application/json' |         'Content-Type': 'application/json' | ||||||
|       } |       } | ||||||
|     }); |     }; | ||||||
|  |     let response: plugins.smartrequest.IExtendedIncomingMessage; | ||||||
|  |     if (!binaryArg) { | ||||||
|  |       response = await plugins.smartrequest.request(requestUrl, requestOptions); | ||||||
|  |     } else { | ||||||
|  |       response = await plugins.smartrequest.getBinary(requestUrl, requestOptions); | ||||||
|  |     } | ||||||
|     return response; |     return response; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -69,6 +76,8 @@ export class MailgunAccount { | |||||||
|       } |       } | ||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
|  |     console.log(smartmailArg.attachments); | ||||||
|  |  | ||||||
|     for (const attachment of smartmailArg.attachments) { |     for (const attachment of smartmailArg.attachments) { | ||||||
|       formFields.push({ |       formFields.push({ | ||||||
|         name: 'attachment', |         name: 'attachment', | ||||||
| @@ -89,9 +98,27 @@ export class MailgunAccount { | |||||||
|  |  | ||||||
|   public async retrieveSmartMailFromMessageUrl(messageUrlArg: string) { |   public async retrieveSmartMailFromMessageUrl(messageUrlArg: string) { | ||||||
|     const response = await this.getRequest(messageUrlArg); |     const response = await this.getRequest(messageUrlArg); | ||||||
|     return response.body; |     const responseBody: interfaces.IMailgunMessage = response.body; | ||||||
|   } |     const smartmail = new plugins.smartmail.Smartmail({ | ||||||
|  |       from: responseBody.From, | ||||||
|  |       body: responseBody["body-html"], | ||||||
|  |       subject: responseBody.Subject, | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     // lets care about attachments | ||||||
|  |     for (const attachmentInfo of responseBody.attachments) { | ||||||
|  |       const attachmentName = attachmentInfo.name; | ||||||
|  |       const attachmentContents = await this.getRequest(attachmentInfo.url, true); | ||||||
|  |       smartmail.addAttachment(new plugins.smartfile.Smartfile({ | ||||||
|  |         path: `./${attachmentName}`, | ||||||
|  |         base: `./${attachmentName}`, | ||||||
|  |         contentBuffer: attachmentContents.body | ||||||
|  |       })); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return smartmail; | ||||||
|  |   } | ||||||
|  |    | ||||||
|   public async retrieveSmartMailFromNotifyPayload(notifyPayloadArg: any) { |   public async retrieveSmartMailFromNotifyPayload(notifyPayloadArg: any) { | ||||||
|     return await this.retrieveSmartMailFromMessageUrl(notifyPayloadArg['message-url']); |     return await this.retrieveSmartMailFromMessageUrl(notifyPayloadArg['message-url']); | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| // @pushrocks scope | // @pushrocks scope | ||||||
|  | import * as smartfile from '@pushrocks/smartfile'; | ||||||
| import * as smartmail from '@pushrocks/smartmail'; | import * as smartmail from '@pushrocks/smartmail'; | ||||||
| import * as smartrequest from '@pushrocks/smartrequest'; | import * as smartrequest from '@pushrocks/smartrequest'; | ||||||
| import * as smartstring from '@pushrocks/smartstring'; | import * as smartstring from '@pushrocks/smartstring'; | ||||||
|  |  | ||||||
| export { smartmail, smartrequest, smartstring }; | export { smartfile, smartmail, smartrequest, smartstring }; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user