Skip to content

Commit

Permalink
Merge branch 'Shuffle:master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
nusantara-self authored Feb 16, 2024
2 parents 9857084 + 2fb2483 commit 943dbbd
Show file tree
Hide file tree
Showing 26 changed files with 2,756 additions and 530 deletions.
2 changes: 2 additions & 0 deletions .github/labeler.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
App:
- '/.*/'
2 changes: 1 addition & 1 deletion .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ jobs:
with:
context: ${{ matrix.app }}/${{ matrix.version }}
file: ${{ matrix.app }}/${{ matrix.version }}/Dockerfile
platforms: linux/amd64,linux/arm64,linux/386
platforms: linux/amd64,linux/arm64
push: true
tags: |
${{ secrets.DOCKERHUB_USERNAME }}/${{ matrix.app }}:${{ matrix.version }}
Expand Down
10 changes: 10 additions & 0 deletions .github/workflows/project_automation.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,16 @@ on:
- opened

jobs:
add-label:
name: Add label to issue
runs-on: ubuntu-latest
steps:
- uses: github/[email protected] #May not be the latest version
with:
configuration-path: .github/labeler.yml
repo-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
enable-versioned-regex: 0

add-to-project:
name: Add issue to project
runs-on: ubuntu-latest
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Shuffle Apps
This is a repository for apps to be used in [Shuffle](https://github.com/frikky/shuffle)
All public apps are available in the search, engine either in your local instance or on [https://shuffler.io/search?tab=apps](https://shuffler.io/search?tab=apps). This is a repository for apps to be used in [Shuffle](https://github.com/frikky/shuffle)

**PS:** These apps should be valid with WALKOFF, but the SDK is different, meaning you have to change the FIRST line in each Dockerfile (FROM frikky/shuffle:app_sdk).
**PS:** These apps should be valid with WALKOFF (from NSA), but the SDK is different, meaning you have to change the FIRST line in each Dockerfile (FROM frikky/shuffle:app_sdk) to make it compatible with Shuffle.

## App Creation
App creation can be done with the Shuffle App Creator (exports as OpenAPI) or Python, which makes it possible to connect _literally_ any tool. Always prioritize using the App Creator when applicable.
Expand Down
2 changes: 1 addition & 1 deletion email/1.2.0/src/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -394,7 +394,7 @@ def parse_email_file(self, file_id, file_extension):
print("File: %s" % file_path)
if file_extension.lower() == 'eml':
print('working with .eml file')
ep = eml_parser.EmlParser(include_attachment_data=True, include_raw_body=True)
ep = eml_parser.EmlParser(include_attachment_data=True, include_raw_body=True, parse_attachment=True)
try:
parsed_eml = ep.decode_email_bytes(file_path['data'])
if str(parsed_eml["header"]["date"]) == "1970-01-01 00:00:00+00:00":
Expand Down
1 change: 1 addition & 0 deletions servicenow/1.0.0/Dockerfile → email/1.3.0/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -24,3 +24,4 @@ COPY src /app
# Finally, lets run our app!
WORKDIR /app
CMD python app.py --log-level DEBUG

280 changes: 280 additions & 0 deletions email/1.3.0/api.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,280 @@
walkoff_version: 1.3.0
app_version: 1.3.0
name: email
description: Email app
tags:
- email
categories:
- communication
contact_info:
name: "@frikkylikeme"
url: https://github.com/frikky
email: "[email protected]"
actions:
- name: send_email_shuffle
description: Send an email from Shuffle
parameters:
- name: apikey
description: Your https://shuffler.io apikey
multiline: false
example: "https://shuffler.io apikey"
required: true
schema:
type: string
- name: recipients
description: The recipients of the email
multiline: false
example: "[email protected],[email protected]"
required: true
schema:
type: string
- name: subject
description: The subject to use
multiline: false
example: "SOS this is an alert :o"
required: true
schema:
type: string
- name: body
description: The body to add to the email
multiline: true
example: "This is an email alert from Shuffler.io :)"
required: true
schema:
type: string
returns:
schema:
type: string
- name: send_email_smtp
description: Send an email with SMTP
parameters:
- name: username
description: The SMTP login username
multiline: false
example: "[email protected]"
required: false
schema:
type: string
- name: password
description: The password to log in with SMTP
multiline: false
example: "******************"
required: false
schema:
type: string
- name: smtp_host
description: The host of the SMTP
multiline: false
example: "smtp-mail.outlook.com"
required: true
schema:
type: string
- name: smtp_port
description: The port to use for SMTP
multiline: false
example: "587"
required: true
schema:
type: string
- name: recipient
description: The receiver(s) of the email
multiline: false
example: "[email protected],[email protected]"
required: true
schema:
type: string
- name: subject
description: The subject of the email
multiline: false
example: "This is a subject, hello there :)"
required: true
schema:
type: string
- name: body
description: The body to add to the email
multiline: true
example: "This is an email alert from Shuffler.io :)"
required: true
schema:
type: string
- name: attachments
description: Send files from shuffle as part of the email
multiline: false
example: "file_id1,file_id2,file_id3"
required: false
schema:
type: string
- name: ssl_verify
description: Whether to use TLS or not
example: "true"
required: false
options:
- true
- false
schema:
type: string
- name: body_type
description: The type of body to send. HTML by default
example: "true"
required: false
options:
- "html"
- "plain"
schema:
type: string
returns:
schema:
type: string
- name: get_emails_imap
description: Get emails using IMAP (e.g. imap.gmail.com / Outlook.office365.com)
parameters:
- name: username
description: The SMTP login username
multiline: false
example: "[email protected]"
required: true
schema:
type: string
- name: password
description: The password to log in with SMTP
multiline: false
example: "******************"
required: true
schema:
type: string
- name: imap_server
description: The imap server host
multiline: false
example: "Outlook.office365.com"
required: true
schema:
type: string
- name: foldername
description: The folder to use, e.g. "inbox"
multiline: false
example: "inbox"
required: true
schema:
type: string
- name: amount
description: Amount of emails to retrieve
multiline: false
example: "10"
required: true
schema:
type: string
- name: unread
description: Retrieve just unread emails
multiline: false
options:
- "false"
- "true"
required: true
schema:
type: bool
- name: fields
description: Comma separated list of fields to be exported
multiline: false
example: "body, header.subject, header.header.message-id"
required: false
schema:
type: string
- name: include_raw_body
description: Include raw body in email export
multiline: false
options:
- "true"
- "false"
required: true
schema:
type: bool
- name: include_attachment_data
description: Include raw attachments in email export
multiline: false
options:
- "false"
- "true"
required: true
schema:
type: bool
- name: upload_email_shuffle
description: Upload email in shuffle, return uid
multiline: false
options:
- "false"
- "true"
required: true
schema:
type: bool
- name: upload_attachments_shuffle
description: Upload attachments in shuffle, return uids
multiline: false
options:
- "false"
- "true"
required: true
schema:
type: bool
- name: ssl_verify
description: Whether to use TLS or not
example: "true"
required: false
options:
- true
- false
schema:
type: string
- name: mark_as_read
description: Mark email as read or not
multiline: false
options:
- "false"
- "true"
required: false
schema:
type: bool
- name: parse_email_file
description: Takes a file from shuffle and analyzes it if it's a valid .eml or .msg
parameters:
- name: file_id
description: file id
required: true
multiline: true
example: 'adf5e3d0fd85633be17004735a0a119e'
schema:
type: string
- name: extract_attachments
description: Whether to extract the attachments straight into files
required: true
options:
- true
- false
example: 'true'
schema:
type: string
- name: parse_email_headers
description:
parameters:
- name: email_headers
description: Email headers
required: true
multiline: true
example: 'Email Headers'
schema:
type: string
returns:
schema:
type: string
- name: analyze_headers
description:
parameters:
- name: headers
description: Email headers in any format
required: true
multiline: true
schema:
type: string
returns:
schema:
type: string
large_image: 
8 changes: 8 additions & 0 deletions email/1.3.0/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
requests==2.25.1
glom==20.11.0
eml-parser==1.17.0
msg-parser==1.2.0
mail-parser==3.15.0
extract-msg==0.30.9
jsonpickle==2.0.0

Loading

0 comments on commit 943dbbd

Please sign in to comment.