Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 27 additions & 0 deletions redis/1.0.0/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Base our app image off of the WALKOFF App SDK image
FROM frikky/shuffle:app_sdk as base

# We're going to stage away all of the bloat from the build tools so lets create a builder stage
FROM base as builder

# Install all alpine build tools needed for our pip installs
RUN apk --no-cache add --update alpine-sdk libffi libffi-dev musl-dev openssl-dev

# Install all of our pip packages in a single directory that we can copy to our base image later
RUN mkdir /install
WORKDIR /install
COPY requirements.txt /requirements.txt
RUN pip install --prefix="/install" -r /requirements.txt

# Switch back to our base image and copy in all of our built packages and source code
FROM base
COPY --from=builder /install /usr/local
COPY src /app
RUN apk add curl

# Install any binary dependencies needed in our final image
# RUN apk --no-cache add --update my_binary_dependency

# Finally, lets run our app!
WORKDIR /app
CMD python app.py --log-level DEBUG
110 changes: 110 additions & 0 deletions redis/1.0.0/api.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
app_version: 1.0.0
name: Redis
description: Redis integration.
tags:
- redis
categories:
- Other
# contact_info:
# name: "@frikkylikeme"
# url: https://shuffler.io
# email: frikky@shuffler.io
authentication:
required: true
parameters:
- name: server
description: Redis server ip
example: "127.0.0.1"
required: true
schema:
type: string
- name: port
description: Redis port
example: "6379"
required: true
schema:
type: string
- name: password
description: redis password
example: "*****"
required: false
schema:
type: string
- name: database
description: redis database
example: "0"
required: false
options:
- 0
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
schema:
type: string

actions:
- name: set_value
description: Set a key value pair
parameters:
- name: key
description: Key name
required: true
multiline: false
example: "my key"
schema:
type: string
- name: value
description: Value
required: true
multiline: true
example: 'my value'
schema:
type: string
- name: nx
description: Set value only if not exists
required: true
options:
- "false"
- "true"
multiline: false
example: "true"
schema:
type: bool
- name: ex
description: Expiration time in seconds
required: false
multiline: false
example: '60'
schema:
type: string
returns:
schema:
type: string

- name: get_value
description: Get value of a key
parameters:
- name: key
description: Key name
required: true
multiline: false
example: "my key"
schema:
type: string
returns:
schema:
type: string
large_image: 
# yamllint disable-line rule:line-length
Binary file added redis/1.0.0/app.zip
Binary file not shown.
1 change: 1 addition & 0 deletions redis/1.0.0/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
redis==5.2.1
58 changes: 58 additions & 0 deletions redis/1.0.0/src/app.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import json
import ast
import redis

from walkoff_app_sdk.app_base import AppBase

class REDIS(AppBase):
__version__ = "1.0.0"
app_name = "Redis"

def __init__(self, redis, logger, console_logger=None):
print("INIT")
"""
Each app should have this __init__ to set up Redis and logging.
:param redis:
:param logger:
:param console_logger:
"""
super().__init__(redis, logger, console_logger)

def set_value(self, server, port, key, value, nx, ex = None, password = None, database = 0):
"""
Sets a key-value pair in Redis.
"""

if password == None:
redis_client = redis.Redis(decode_responses=True, host=server, port=port, db=database)
else:
redis_client = redis.Redis(decode_responses=True, password=password, port=port, host=server, db=database)


result = redis_client.set(name=key, value=value, nx=nx, ex=ex) # nx=True ensures "set only if the key does not exist"
print(result)
if result: # If result is True, the key was successfully set
print(f"Success: Key {key} set with value '{value}'")
return {"success": True}
else:
print(f"Failed: Key {key} already exists.")
return {"success": False}

def get_value(self, server, port, key, password = None, database = 0):
"""
Gets a value for a key in Redis.
"""
if password == None:
redis_client = redis.Redis(decode_responses=True, host=server, port=port, db=database)
else:
redis_client = redis.Redis(decode_responses=True, password=password, port=port, host=server, db=database)

result = redis_client.get(name=key)
if result:
return {"success": True, "value": result}
else:
return {"success": False, "error": f"Key {key} does not exist", "value": None}


if __name__ == "__main__":
REDIS.run()