Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
da7c57165e | |||
708c05d1e3 | |||
58b7f602bd | |||
23507b83fc | |||
c160cfd94e | |||
920399a495 |
@ -3,14 +3,14 @@ image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
|||||||
|
|
||||||
cache:
|
cache:
|
||||||
paths:
|
paths:
|
||||||
- .npmci_cache/
|
- .npmci_cache/
|
||||||
key: "$CI_BUILD_STAGE"
|
key: '$CI_BUILD_STAGE'
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- security
|
- security
|
||||||
- test
|
- test
|
||||||
- release
|
- release
|
||||||
- metadata
|
- metadata
|
||||||
|
|
||||||
# ====================
|
# ====================
|
||||||
# security stage
|
# security stage
|
||||||
@ -18,21 +18,23 @@ stages:
|
|||||||
mirror:
|
mirror:
|
||||||
stage: security
|
stage: security
|
||||||
script:
|
script:
|
||||||
- npmci git mirror
|
- npmci git mirror
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- notpriv
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
snyk:
|
snyk:
|
||||||
|
image: registry.gitlab.com/hosttoday/ht-docker-node:snyk
|
||||||
stage: security
|
stage: security
|
||||||
script:
|
script:
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
- npmci command npm install -g snyk
|
|
||||||
- npmci command npm install --ignore-scripts
|
- npmci command npm install --ignore-scripts
|
||||||
- npmci command snyk test
|
- npmci command snyk test
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- notpriv
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
# ====================
|
# ====================
|
||||||
# test stage
|
# test stage
|
||||||
@ -41,37 +43,40 @@ snyk:
|
|||||||
testStable:
|
testStable:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
- npmci node install stable
|
- npmci node install stable
|
||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci npm test
|
- npmci npm test
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- priv
|
- docker
|
||||||
|
- priv
|
||||||
|
|
||||||
testBuild:
|
testBuild:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
- npmci node install stable
|
- npmci node install stable
|
||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci command npm run build
|
- npmci command npm run build
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- notpriv
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
script:
|
script:
|
||||||
- npmci node install stable
|
- npmci node install stable
|
||||||
- npmci npm publish
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- notpriv
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
# ====================
|
# ====================
|
||||||
# metadata stage
|
# metadata stage
|
||||||
@ -85,18 +90,20 @@ codequality:
|
|||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci command "tslint -c tslint.json ./ts/**/*.ts"
|
- npmci command "tslint -c tslint.json ./ts/**/*.ts"
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- priv
|
- docker
|
||||||
|
- priv
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
stage: metadata
|
stage: metadata
|
||||||
script:
|
script:
|
||||||
- npmci trigger
|
- npmci trigger
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- lossless
|
||||||
- notpriv
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
pages:
|
pages:
|
||||||
stage: metadata
|
stage: metadata
|
||||||
@ -107,6 +114,7 @@ pages:
|
|||||||
- npmci npm install
|
- npmci npm install
|
||||||
- npmci command tsdoc
|
- npmci command tsdoc
|
||||||
tags:
|
tags:
|
||||||
|
- lossless
|
||||||
- docker
|
- docker
|
||||||
- notpriv
|
- notpriv
|
||||||
only:
|
only:
|
||||||
@ -114,5 +122,5 @@ pages:
|
|||||||
artifacts:
|
artifacts:
|
||||||
expire_in: 1 week
|
expire_in: 1 week
|
||||||
paths:
|
paths:
|
||||||
- public
|
- public
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
|
2
package-lock.json
generated
2
package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@mojoio/mailgun",
|
"name": "@mojoio/mailgun",
|
||||||
"version": "1.0.20",
|
"version": "1.0.23",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@mojoio/mailgun",
|
"name": "@mojoio/mailgun",
|
||||||
"version": "1.0.20",
|
"version": "1.0.23",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "an api abstraction package for mailgun",
|
"description": "an api abstraction package for mailgun",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
|
13
test/test.ts
13
test/test.ts
@ -5,12 +5,13 @@ import * as smartmail from '@pushrocks/smartmail';
|
|||||||
const testQenv = new Qenv('./', './.nogit');
|
const testQenv = new Qenv('./', './.nogit');
|
||||||
|
|
||||||
import * as mailgun from '../ts/index';
|
import * as mailgun from '../ts/index';
|
||||||
|
import { IMailgunMessage } from '../ts/index';
|
||||||
|
|
||||||
|
|
||||||
let testMailgunAccount: mailgun.MailgunAccount;
|
let testMailgunAccount: mailgun.MailgunAccount;
|
||||||
let testSmartmail: smartmail.Smartmail;
|
let testSmartmail: smartmail.Smartmail<IMailgunMessage>;
|
||||||
|
|
||||||
tap.test('first test', async () => {
|
tap.test('should create a mailgun account', async () => {
|
||||||
testMailgunAccount = new mailgun.MailgunAccount(testQenv.getEnvVarOnDemand('MAILGUN_API_TOKEN'));
|
testMailgunAccount = new mailgun.MailgunAccount(testQenv.getEnvVarOnDemand('MAILGUN_API_TOKEN'));
|
||||||
expect(testMailgunAccount).to.be.instanceOf(mailgun.MailgunAccount);
|
expect(testMailgunAccount).to.be.instanceOf(mailgun.MailgunAccount);
|
||||||
});
|
});
|
||||||
@ -30,9 +31,11 @@ tap.test('should send a smartmail', async () => {
|
|||||||
|
|
||||||
tap.test('should retrieve a mail using a retrieval url', async () => {
|
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==');
|
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';
|
if (result) {
|
||||||
result.options.from = 'noreply@mail.lossless.com';
|
result.options.subject = 'hi there. This is a testmail with attachment';
|
||||||
testMailgunAccount.sendSmartMail(result, 'sandbox@mail.git.zone');
|
result.options.from = 'noreply@mail.lossless.com';
|
||||||
|
testMailgunAccount.sendSmartMail(result, 'sandbox@mail.git.zone');
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
tap.start();
|
tap.start();
|
||||||
|
@ -15,14 +15,14 @@ export interface IMailgunMessage {
|
|||||||
'X-Gm-Message-State': string;
|
'X-Gm-Message-State': string;
|
||||||
'body-plain': string;
|
'body-plain': string;
|
||||||
attachments: Array<{
|
attachments: Array<{
|
||||||
url: string,
|
url: string;
|
||||||
'content-type': string,
|
'content-type': string;
|
||||||
name: string,
|
name: string;
|
||||||
size: number
|
size: number;
|
||||||
}>;
|
}>;
|
||||||
'body-html': string;
|
'body-html': string;
|
||||||
'Mime-Version': string;
|
'Mime-Version': string;
|
||||||
Date: string,
|
Date: string;
|
||||||
'Message-Id': string;
|
'Message-Id': string;
|
||||||
'Content-Type': string;
|
'Content-Type': string;
|
||||||
'X-Google-Smtp-Source': string;
|
'X-Google-Smtp-Source': string;
|
||||||
|
@ -43,5 +43,5 @@ export interface IMailgunNotification {
|
|||||||
'stripped-signature': string;
|
'stripped-signature': string;
|
||||||
|
|
||||||
// Lossless specific
|
// Lossless specific
|
||||||
X-Lossless-Auth: string
|
"X-Lossless-Auth": string;
|
||||||
}
|
}
|
@ -51,7 +51,7 @@ export class MailgunAccount {
|
|||||||
/**
|
/**
|
||||||
* sends a SmartMail
|
* sends a SmartMail
|
||||||
*/
|
*/
|
||||||
public async sendSmartMail(smartmailArg: plugins.smartmail.Smartmail, toArg: string, dataArg = {}) {
|
public async sendSmartMail(smartmailArg: plugins.smartmail.Smartmail<interfaces.IMailgunMessage>, toArg: string, dataArg = {}) {
|
||||||
const domain = smartmailArg.options.from.split('@')[1];
|
const domain = smartmailArg.options.from.split('@')[1];
|
||||||
const formFields: plugins.smartrequest.IFormField[] = [
|
const formFields: plugins.smartrequest.IFormField[] = [
|
||||||
{
|
{
|
||||||
@ -98,22 +98,29 @@ 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);
|
||||||
|
if (response.statusCode === 404) {
|
||||||
|
console.log(response.body.message);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
const responseBody: interfaces.IMailgunMessage = response.body;
|
const responseBody: interfaces.IMailgunMessage = response.body;
|
||||||
const smartmail = new plugins.smartmail.Smartmail<interfaces.IMailgunMessage>({
|
const smartmail = new plugins.smartmail.Smartmail<interfaces.IMailgunMessage>({
|
||||||
from: responseBody.From,
|
from: responseBody.From,
|
||||||
body: responseBody["body-html"],
|
body: responseBody["body-html"],
|
||||||
subject: responseBody.Subject,
|
subject: responseBody.Subject,
|
||||||
|
creationObjectRef: responseBody
|
||||||
});
|
});
|
||||||
|
|
||||||
// lets care about attachments
|
// lets care about attachments
|
||||||
for (const attachmentInfo of responseBody.attachments) {
|
if (responseBody.attachments && responseBody.attachments instanceof Array) {
|
||||||
const attachmentName = attachmentInfo.name;
|
for (const attachmentInfo of responseBody.attachments) {
|
||||||
const attachmentContents = await this.getRequest(attachmentInfo.url, true);
|
const attachmentName = attachmentInfo.name;
|
||||||
smartmail.addAttachment(new plugins.smartfile.Smartfile({
|
const attachmentContents = await this.getRequest(attachmentInfo.url, true);
|
||||||
path: `./${attachmentName}`,
|
smartmail.addAttachment(new plugins.smartfile.Smartfile({
|
||||||
base: `./${attachmentName}`,
|
path: `./${attachmentName}`,
|
||||||
contentBuffer: attachmentContents.body
|
base: `./${attachmentName}`,
|
||||||
}));
|
contentBuffer: attachmentContents.body
|
||||||
|
}));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return smartmail;
|
return smartmail;
|
||||||
|
Reference in New Issue
Block a user