mirror of
https://github.com/dawidd6/action-send-mail.git
synced 2024-12-25 18:43:08 +07:00
Add connection_url input parameter (#131)
Specify connection via URL (replaces server_address, server_port, secure, username and password) Format: * smtp://user:password@server:port * smtp+starttls://user:password@server:port Closes: #127 Signed-off-by: Alon Bar-Lev <alon.barlev@gmail.com> Signed-off-by: Alon Bar-Lev <alon.barlev@gmail.com>
This commit is contained in:
parent
924d1fedb2
commit
07d4810b3b
16
.github/workflows/test.yml
vendored
16
.github/workflows/test.yml
vendored
@ -58,3 +58,19 @@ jobs:
|
|||||||
attachments: ${{matrix.attachments}}
|
attachments: ${{matrix.attachments}}
|
||||||
convert_markdown: ${{matrix.convert_markdown}}
|
convert_markdown: ${{matrix.convert_markdown}}
|
||||||
priority: high
|
priority: high
|
||||||
|
|
||||||
|
url-test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Send mail
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
connection_url: smtp+starttls://${{secrets.USERNAME}}:${{secrets.PASSWORD}}@${{secrets.ADDRESS}}/
|
||||||
|
subject: Plain body with connection_url
|
||||||
|
body: |
|
||||||
|
first line
|
||||||
|
second line
|
||||||
|
to: ${{github.event.pusher.email}}
|
||||||
|
from: github-actions
|
||||||
|
16
README.md
16
README.md
@ -16,10 +16,20 @@ Some features:
|
|||||||
- name: Send mail
|
- name: Send mail
|
||||||
uses: dawidd6/action-send-mail@v3
|
uses: dawidd6/action-send-mail@v3
|
||||||
with:
|
with:
|
||||||
# Required mail server address:
|
# Specify connection via URL (replaces server_address, server_port, secure,
|
||||||
|
# username and password)
|
||||||
|
#
|
||||||
|
# Format:
|
||||||
|
#
|
||||||
|
# * smtp://user:password@server:port
|
||||||
|
# * smtp+starttls://user:password@server:port
|
||||||
|
connection_url: ${{secrets.MAIL_CONNECTION}}
|
||||||
|
# Required mail server address if not connection_url:
|
||||||
server_address: smtp.gmail.com
|
server_address: smtp.gmail.com
|
||||||
# Required mail server port:
|
# Server port, default 25:
|
||||||
server_port: 465
|
server_port: 465
|
||||||
|
# Optional whether this connection use TLS (default is true if server_port is 465)
|
||||||
|
secure: true
|
||||||
# Optional (recommended): mail server username:
|
# Optional (recommended): mail server username:
|
||||||
username: ${{secrets.MAIL_USERNAME}}
|
username: ${{secrets.MAIL_USERNAME}}
|
||||||
# Optional (recommended) mail server password:
|
# Optional (recommended) mail server password:
|
||||||
@ -30,8 +40,6 @@ Some features:
|
|||||||
to: obiwan@example.com,yoda@example.com
|
to: obiwan@example.com,yoda@example.com
|
||||||
# Required sender full name (address can be skipped):
|
# Required sender full name (address can be skipped):
|
||||||
from: Luke Skywalker # <user@example.com>
|
from: Luke Skywalker # <user@example.com>
|
||||||
# Optional whether this connection use TLS (default is true if server_port is 465)
|
|
||||||
secure: true
|
|
||||||
# Optional plain body:
|
# Optional plain body:
|
||||||
body: Build job of ${{github.repository}} completed successfully!
|
body: Build job of ${{github.repository}} completed successfully!
|
||||||
# Optional HTML body read from file:
|
# Optional HTML body read from file:
|
||||||
|
12
action.yml
12
action.yml
@ -5,18 +5,19 @@ branding:
|
|||||||
icon: mail
|
icon: mail
|
||||||
color: blue
|
color: blue
|
||||||
inputs:
|
inputs:
|
||||||
|
connection_url:
|
||||||
|
description: Connection URL protocol://user:password@server:port, protocol can be smtp or smtp+starttls, replaces server_address, server_port, secure, username and password
|
||||||
server_address:
|
server_address:
|
||||||
description: SMTP server address
|
description: SMTP server address
|
||||||
required: true
|
|
||||||
server_port:
|
server_port:
|
||||||
description: SMTP server port
|
description: SMTP server port
|
||||||
required: true
|
default: "25"
|
||||||
|
secure:
|
||||||
|
description: Whether this connection use TLS (default is true if server_port is 465)
|
||||||
username:
|
username:
|
||||||
description: Authenticate as this user to SMTP server
|
description: Authenticate as this user to SMTP server
|
||||||
required: false
|
|
||||||
password:
|
password:
|
||||||
description: Authenticate with this password to SMTP server
|
description: Authenticate with this password to SMTP server
|
||||||
required: false
|
|
||||||
subject:
|
subject:
|
||||||
description: Subject of mail message
|
description: Subject of mail message
|
||||||
required: true
|
required: true
|
||||||
@ -26,9 +27,6 @@ inputs:
|
|||||||
from:
|
from:
|
||||||
description: Full name of mail sender (might be with an email address specified in <>)
|
description: Full name of mail sender (might be with an email address specified in <>)
|
||||||
required: true
|
required: true
|
||||||
secure:
|
|
||||||
description: Whether this connection use TLS (default is true if server_port is 465)
|
|
||||||
required: false
|
|
||||||
body:
|
body:
|
||||||
description: Body of mail message (might be a filename prefixed with file:// to read from)
|
description: Body of mail message (might be a filename prefixed with file:// to read from)
|
||||||
required: false
|
required: false
|
||||||
|
50
main.js
50
main.js
@ -39,14 +39,48 @@ async function getAttachments(attachments) {
|
|||||||
|
|
||||||
async function main() {
|
async function main() {
|
||||||
try {
|
try {
|
||||||
const serverAddress = core.getInput("server_address", { required: true })
|
let serverAddress = core.getInput("server_address")
|
||||||
const serverPort = core.getInput("server_port", { required: true })
|
let serverPort = core.getInput("server_port")
|
||||||
const username = core.getInput("username")
|
let secure = core.getInput("secure")
|
||||||
const password = core.getInput("password")
|
let username = core.getInput("username")
|
||||||
|
let password = core.getInput("password")
|
||||||
|
|
||||||
|
if (!secure) {
|
||||||
|
secure = serverPort === "465" ? "true" : "false"
|
||||||
|
}
|
||||||
|
|
||||||
|
const connectionUrl = core.getInput("connection_url")
|
||||||
|
if (connectionUrl) {
|
||||||
|
const url = new URL(connectionUrl)
|
||||||
|
switch (url.protocol) {
|
||||||
|
default:
|
||||||
|
throw new Error(`Unsupported connection protocol '${url.protocol}'`)
|
||||||
|
case "smtp:":
|
||||||
|
serverPort = "25"
|
||||||
|
secure = "false"
|
||||||
|
break
|
||||||
|
case "smtp+starttls:":
|
||||||
|
serverPort = "465"
|
||||||
|
secure = "true"
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if (url.hostname) {
|
||||||
|
serverAddress = url.hostname
|
||||||
|
}
|
||||||
|
if (url.port) {
|
||||||
|
serverPort = url.port
|
||||||
|
}
|
||||||
|
if (url.username) {
|
||||||
|
username = unescape(url.username)
|
||||||
|
}
|
||||||
|
if (url.password) {
|
||||||
|
password = unescape(url.password)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const subject = core.getInput("subject", { required: true })
|
const subject = core.getInput("subject", { required: true })
|
||||||
const from = core.getInput("from", { required: true })
|
const from = core.getInput("from", { required: true })
|
||||||
const to = core.getInput("to", { required: true })
|
const to = core.getInput("to", { required: true })
|
||||||
const secure = core.getInput("secure", { required: false })
|
|
||||||
const body = core.getInput("body", { required: false })
|
const body = core.getInput("body", { required: false })
|
||||||
const htmlBody = core.getInput("html_body", { required: false })
|
const htmlBody = core.getInput("html_body", { required: false })
|
||||||
const cc = core.getInput("cc", { required: false })
|
const cc = core.getInput("cc", { required: false })
|
||||||
@ -58,6 +92,10 @@ async function main() {
|
|||||||
const ignoreCert = core.getInput("ignore_cert", { required: false })
|
const ignoreCert = core.getInput("ignore_cert", { required: false })
|
||||||
const priority = core.getInput("priority", { required: false })
|
const priority = core.getInput("priority", { required: false })
|
||||||
|
|
||||||
|
if (!serverAddress) {
|
||||||
|
throw new Error("Server address must be specified")
|
||||||
|
}
|
||||||
|
|
||||||
if (!username || !password) {
|
if (!username || !password) {
|
||||||
core.warning("Username and password not specified. You should only do this if you are using a self-hosted runner to access an on-premise mail server.")
|
core.warning("Username and password not specified. You should only do this if you are using a self-hosted runner to access an on-premise mail server.")
|
||||||
}
|
}
|
||||||
@ -69,7 +107,7 @@ async function main() {
|
|||||||
pass: password
|
pass: password
|
||||||
} : undefined,
|
} : undefined,
|
||||||
port: serverPort,
|
port: serverPort,
|
||||||
secure: secure == "true" ? true : serverPort == "465",
|
secure: secure === "true",
|
||||||
tls: ignoreCert == "true" ? {
|
tls: ignoreCert == "true" ? {
|
||||||
rejectUnauthorized: false
|
rejectUnauthorized: false
|
||||||
} : undefined,
|
} : undefined,
|
||||||
|
Loading…
Reference in New Issue
Block a user