@adeelgulzar/nodemailwizz 中文文档教程
node-mailwizz
我采用了 ntlzz93 的包并添加了更多功能。
当前版本为 1.0.0,请随时提出拉取请求或提出问题。
要了解可用的 API 和参数,请转到 api
目录。
这个SDK使用原生的Promise而不是Callback,所以你可以async/await随心所欲
How to use
首先,你需要添加配置:
const mailWizz = require("node-mailwizz");
const config = {
publicKey: "publicKey",
secret: "secretKey",
baseUrl: "yourMailwizzApiUrl"
};
如何创建订阅者:
const subscribers = new mailWizz.ListSubscribers(config);
var userInfo = { //replace the values with your user info
EMAIL: "contact@mikelcalvo.net",
FNAME: "Mikel",
LNAME: "Calvo",
CUSTOM: "custom"
};
//You can replace CUSTOM with the parameters you want
subscribers.create("LIST-UNIQUE-ID", userInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何更新订阅者:
const subscribers = new mailWizz.ListSubscribers(config);
var userInfo = { //replace the values with your user's new info
EMAIL: "contact@mikelcalvo.net",
FNAME: "Mikel",
LNAME: "Calvo",
CUSTOM: "custom"
};
//You can replace CUSTOM with the parameters you want
subscribers.update("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID", userInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何删除订阅者:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.delete("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何取消订阅:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.unsubscribe("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何获得您的订阅者:
const subscribers = new mailWizz.ListSubscribers(config);
/Value 1 is the page number you want to get
//Value 10 is the items per package
//So if you set (1, 10) it will get the first 10 subscribers
subscribers.getSubscribers("LIST-UNIQUE-ID", 1, 10)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何通过他们的 ID
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.getSubscriber("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
获得订阅者:如何通过他们的电子邮件获得订阅者:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.emailSearch("LIST-UNIQUE-ID", "SUBSCRIBER-EMAIL")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何获得您的列表:
const lists = new mailWizz.Lists(config);
//Value 1 is the page number you want to get
//Value 10 is the items per package
//So if you set (1, 10) it will get the first 10 lists
lists.getLists(1, 10)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如果您有列表 ID,您可以直接获取它:
const lists = new mailWizz.Lists(config);
lists.getList("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何创建新列表:
const lists = new mailWizz.Lists(config);
var listInfo = { //Replace the values with your list info
name: "Main List", //Required
description: "This is a test list", //Required
optIn: "single", //single or double
optOut: "single", //single or double
fromName: "Mikel Calvo", //Required
fromEmail: "contact@mikelcalvo.net", //Required
replyTo: "contact@mikelcalvo.net", //Required
subject: "Hi!",
//notification when new subscriber added
notificationSubscribe: "yes", //yes or no
notificationUnsubscribe: "yes", //yes or no
//where to send the notification
notificationSubscribeTo: "contact@mikelcalvo.net",
notificationUnsubscribeTo: "contact@mikelcalvo.net",
//This is optional, if not set customer company data will be used:
companyName: "Mikel Calvo SL", //required
companyCountry: "Spain", //required
companyZone: "Community of Madrid", //required
companyAddress1: "Some street address", //required
companyAddress2: "",
companyZoneName: "", //when country doesn't have required zone
companyCity: "Madrid",
companyZipCode: "28013",
};
lists.create(listInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何复制列表:
const lists = new mailWizz.Lists(config);
lists.copy("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何删除列表:
const lists = new mailWizz.Lists(config);
lists.delete("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
如何更新列表:
const lists = new mailWizz.Lists(config);
var newInfo = { //Replace the values with your updated list info
name: "Main List", //Required
description: "This is a test list", //Required
optIn: "single", //single or double
optOut: "single", //single or double
fromName: "Mikel Calvo", //Required
fromEmail: "contact@mikelcalvo.net", //Required
replyTo: "contact@mikelcalvo.net", //Required
subject: "Hi!",
//notification when new subscriber added
notificationSubscribe: "yes", //yes or no
notificationUnsubscribe: "yes", //yes or no
//where to send the notification
notificationSubscribeTo: "contact@mikelcalvo.net",
notificationUnsubscribeTo: "contact@mikelcalvo.net",
//This is optional, if not set customer company data will be used:
companyName: "Mikel Calvo SL", //required
companyCountry: "Spain", //required
companyZone: "Community of Madrid", //required
companyAddress1: "Some street address", //required
companyAddress2: "",
companyZoneName: "", //when country doesn't have required zone
companyCity: "Madrid",
companyZipCode: "28013",
};
lists.update("LIST-UNIQUE-ID", newInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
node-mailwizz
I took ntlzz93's package and added some more features.
Current version is 1.0.0, feel free to make a pull request or open an issue.
To to know which API is available and params, go to api
directory.
This SDK are using native Promise instead of Callback, so you can async/await as you want
How to use
First, you need to add the configuration:
const mailWizz = require("node-mailwizz");
const config = {
publicKey: "publicKey",
secret: "secretKey",
baseUrl: "yourMailwizzApiUrl"
};
How to create a subscriber:
const subscribers = new mailWizz.ListSubscribers(config);
var userInfo = { //replace the values with your user info
EMAIL: "contact@mikelcalvo.net",
FNAME: "Mikel",
LNAME: "Calvo",
CUSTOM: "custom"
};
//You can replace CUSTOM with the parameters you want
subscribers.create("LIST-UNIQUE-ID", userInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to update a subscriber:
const subscribers = new mailWizz.ListSubscribers(config);
var userInfo = { //replace the values with your user's new info
EMAIL: "contact@mikelcalvo.net",
FNAME: "Mikel",
LNAME: "Calvo",
CUSTOM: "custom"
};
//You can replace CUSTOM with the parameters you want
subscribers.update("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID", userInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to delete a subscriber:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.delete("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to unsubscribe:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.unsubscribe("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to get your subscribers:
const subscribers = new mailWizz.ListSubscribers(config);
/Value 1 is the page number you want to get
//Value 10 is the items per package
//So if you set (1, 10) it will get the first 10 subscribers
subscribers.getSubscribers("LIST-UNIQUE-ID", 1, 10)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to get a subscriber with their id:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.getSubscriber("LIST-UNIQUE-ID", "SUBSCRIBER-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to get a subscriber with their email:
const subscribers = new mailWizz.ListSubscribers(config);
subscribers.emailSearch("LIST-UNIQUE-ID", "SUBSCRIBER-EMAIL")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to get your lists:
const lists = new mailWizz.Lists(config);
//Value 1 is the page number you want to get
//Value 10 is the items per package
//So if you set (1, 10) it will get the first 10 lists
lists.getLists(1, 10)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
If you have your list id you can directly get it:
const lists = new mailWizz.Lists(config);
lists.getList("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to create a new list:
const lists = new mailWizz.Lists(config);
var listInfo = { //Replace the values with your list info
name: "Main List", //Required
description: "This is a test list", //Required
optIn: "single", //single or double
optOut: "single", //single or double
fromName: "Mikel Calvo", //Required
fromEmail: "contact@mikelcalvo.net", //Required
replyTo: "contact@mikelcalvo.net", //Required
subject: "Hi!",
//notification when new subscriber added
notificationSubscribe: "yes", //yes or no
notificationUnsubscribe: "yes", //yes or no
//where to send the notification
notificationSubscribeTo: "contact@mikelcalvo.net",
notificationUnsubscribeTo: "contact@mikelcalvo.net",
//This is optional, if not set customer company data will be used:
companyName: "Mikel Calvo SL", //required
companyCountry: "Spain", //required
companyZone: "Community of Madrid", //required
companyAddress1: "Some street address", //required
companyAddress2: "",
companyZoneName: "", //when country doesn't have required zone
companyCity: "Madrid",
companyZipCode: "28013",
};
lists.create(listInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to copy a list:
const lists = new mailWizz.Lists(config);
lists.copy("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to remove a list:
const lists = new mailWizz.Lists(config);
lists.delete("LIST-UNIQUE-ID")
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});
How to update a list:
const lists = new mailWizz.Lists(config);
var newInfo = { //Replace the values with your updated list info
name: "Main List", //Required
description: "This is a test list", //Required
optIn: "single", //single or double
optOut: "single", //single or double
fromName: "Mikel Calvo", //Required
fromEmail: "contact@mikelcalvo.net", //Required
replyTo: "contact@mikelcalvo.net", //Required
subject: "Hi!",
//notification when new subscriber added
notificationSubscribe: "yes", //yes or no
notificationUnsubscribe: "yes", //yes or no
//where to send the notification
notificationSubscribeTo: "contact@mikelcalvo.net",
notificationUnsubscribeTo: "contact@mikelcalvo.net",
//This is optional, if not set customer company data will be used:
companyName: "Mikel Calvo SL", //required
companyCountry: "Spain", //required
companyZone: "Community of Madrid", //required
companyAddress1: "Some street address", //required
companyAddress2: "",
companyZoneName: "", //when country doesn't have required zone
companyCity: "Madrid",
companyZipCode: "28013",
};
lists.update("LIST-UNIQUE-ID", newInfo)
.then(function(result) {
//TODO: do what you want
})
.catch(function(err) {
//handle error here
});