Skip to content

Commit 4d9f033

Browse files
committed
feat[shuffle-tools-fork]: Shuffle tools fork
1 parent 11a6f7a commit 4d9f033

File tree

8 files changed

+622
-0
lines changed

8 files changed

+622
-0
lines changed
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
# Base our app image off of the WALKOFF App SDK image
2+
FROM frikky/shuffle:app_sdk as base
3+
4+
# We're going to stage away all of the bloat from the build tools so lets create a builder stage
5+
FROM base as builder
6+
7+
# Install all alpine build tools needed for our pip installs
8+
RUN apk --no-cache add --update alpine-sdk libffi libffi-dev musl-dev openssl-dev git
9+
10+
# Install all of our pip packages in a single directory that we can copy to our base image later
11+
RUN mkdir /install
12+
WORKDIR /install
13+
COPY requirements.txt /requirements.txt
14+
RUN pip install --no-cache-dir --prefix="/install" -r /requirements.txt
15+
16+
# Switch back to our base image and copy in all of our built packages and source code
17+
FROM base
18+
COPY --from=builder /install /usr/local
19+
COPY src /app
20+
21+
# Install any binary dependencies needed in our final image
22+
# RUN apk --no-cache add --update my_binary_dependency
23+
RUN apk --no-cache add jq git curl
24+
25+
# Finally, lets run our app!
26+
WORKDIR /app
27+
CMD ["python", "app.py", "--log-level", "DEBUG"]

shuffle-tools-fork/1.2.0/api.yaml

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
---
2+
app_version: 1.2.0
3+
name: Shuffle Tools Fork
4+
description: A tool app for Shuffle. Gives access to most missing features along with Liquid.
5+
tags:
6+
- Testing
7+
- Shuffle
8+
categories:
9+
- Other
10+
contact_info:
11+
name: "@frikkylikeme"
12+
url: https://shuffler.io
13+
14+
actions:
15+
- name: execute_python
16+
description: Runs python with the data input. Any prints will be returned.
17+
parameters:
18+
- name: code
19+
description: The code to run. Can be a file ID from within Shuffle.
20+
required: true
21+
multiline: true
22+
example: print("hello world")
23+
schema:
24+
type: string
25+
26+
large_image: 
27+
# yamllint disable-line rule:line-length
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
version: '3.4'
2+
services:
3+
shuffle-tools-fork:
4+
build:
5+
context: .
6+
dockerfile: Dockerfile
7+
# image: walkoff_registry:5000/walkoff_app_HelloWorld-v1-0
8+
deploy:
9+
mode: replicated
10+
replicas: 10
11+
restart_policy:
12+
condition: none
13+
restart: "no"
14+
secrets:
15+
- secret1
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
ioc_finder==7.2.1
2+
py7zr==0.11.3
3+
rarfile==4.0
4+
pyminizip==0.2.4
5+
requests==2.25.1
6+
xmltodict==0.11.0
7+
json2xml==5.0.5
8+
ipaddress==1.0.23
9+
google.auth==1.23.0
10+
paramiko==3.1.0
11+
shufflepy

shuffle-tools-fork/1.2.0/run.sh

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
# Build testing
2+
NAME=frikky/shuffle:shuffle-tools-fork_1.1.0
3+
docker rmi $NAME --force
4+
docker build . -t frikky/shuffle:shuffle-tools-fork_1.1.0
5+
6+
# Run testing
7+
#docker run -e SHUFFLE_SWARM_CONFIG=run -e SHUFFLE_APP_EXPOSED_PORT=33334 frikky/shuffle:shuffle-tools_1.1.0
8+
echo $NAME
9+
#docker service create --env SHUFFLE_SWARM_CONFIG=run --env SHUFFLE_APP_EXPOSED_PORT=33334 $NAME
10+
11+
#cat walkoff_app_sdk/app_base.py #cat walkoff_app_sdk/app_sdk.py
Lines changed: 127 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,127 @@
1+
import hmac
2+
import datetime
3+
import json
4+
import time
5+
import markupsafe
6+
import os
7+
import re
8+
import subprocess
9+
import tempfile
10+
import zipfile
11+
import base64
12+
import ipaddress
13+
import hashlib
14+
import shufflepy
15+
from io import StringIO
16+
from contextlib import redirect_stdout
17+
import random
18+
import string
19+
20+
import xmltodict
21+
from json2xml import json2xml
22+
from json2xml.utils import readfromstring
23+
24+
from ioc_finder import find_iocs
25+
from dateutil.parser import parse as dateutil_parser
26+
from google.auth import crypt
27+
from google.auth import jwt
28+
29+
import py7zr
30+
import pyminizip
31+
import rarfile
32+
import requests
33+
import tarfile
34+
import binascii
35+
import struct
36+
37+
import paramiko
38+
import concurrent.futures
39+
import multiprocessing
40+
41+
from walkoff_app_sdk.app_base import AppBase
42+
43+
class Tools(AppBase):
44+
__version__ = "1.2.0"
45+
app_name = (
46+
"Shuffle Tools Fork" # this needs to match "name" in api.yaml for WALKOFF to work
47+
)
48+
49+
def __init__(self, redis, logger, console_logger=None):
50+
"""
51+
Each app should have this __init__ to set up Redis and logging.
52+
:param redis:
53+
:param logger:
54+
:param console_logger:
55+
"""
56+
super().__init__(redis, logger, console_logger)
57+
58+
def execute_python(self, code):
59+
if len(code) == 36 and "-" in code:
60+
filedata = self.get_file(code)
61+
if filedata["success"] == False:
62+
return {
63+
"success": False,
64+
"message": f"Failed to get file for ID {code}",
65+
}
66+
67+
if ".py" not in filedata["filename"]:
68+
return {
69+
"success": False,
70+
"message": f"Filename needs to contain .py",
71+
}
72+
73+
74+
# Write the code to a file
75+
# 1. Take the data into a file
76+
# 2. Subprocess execute file?
77+
try:
78+
f = StringIO()
79+
def custom_print(*args, **kwargs):
80+
return print(*args, file=f, **kwargs)
81+
82+
#with redirect_stdout(f): # just in case
83+
# Add globals in it too
84+
globals_copy = globals().copy()
85+
globals_copy["print"] = custom_print
86+
87+
# Add self to globals_copy
88+
for key, value in locals().copy().items():
89+
if key not in globals_copy:
90+
globals_copy[key] = value
91+
92+
globals_copy["self"] = self
93+
94+
exec(code, globals_copy)
95+
96+
s = f.getvalue()
97+
f.close() # why: https://www.youtube.com/watch?v=6SA6S9Ca5-U
98+
99+
#try:
100+
# s = s.encode("utf-8")
101+
#except Exception as e:
102+
103+
try:
104+
return {
105+
"success": True,
106+
"message": json.loads(s.strip()),
107+
}
108+
except Exception as e:
109+
try:
110+
return {
111+
"success": True,
112+
"message": s.strip(),
113+
}
114+
except Exception as e:
115+
return {
116+
"success": True,
117+
"message": s,
118+
}
119+
120+
except Exception as e:
121+
return {
122+
"success": False,
123+
"message": f"exception: {e}",
124+
}
125+
126+
if __name__ == "__main__":
127+
Tools.run()

0 commit comments

Comments
 (0)