diff --git a/.env.example b/.env.example
index e5f3fc0..9a10ff4 100644
--- a/.env.example
+++ b/.env.example
@@ -1,4 +1,10 @@
STATIC_DIR='./client'
PAYSTACK_SECRET_KEY=
PORT='5000'
+SERVER_URL='http://localhost:5000'
+
+DOKCER_PORT=6334
+STATIC_DIR='./client'
+PAYSTACK_SECRET_KEY=sk_test_e880ee5f37602e3f5d8703b1a691f3f800fcea68
+PORT='5000'
SERVER_URL='http://localhost:5000'
\ No newline at end of file
diff --git a/.idea/.gitignore b/.idea/.gitignore
new file mode 100644
index 0000000..13566b8
--- /dev/null
+++ b/.idea/.gitignore
@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/.idea/digifi-PayStack.iml b/.idea/digifi-PayStack.iml
new file mode 100644
index 0000000..c956989
--- /dev/null
+++ b/.idea/digifi-PayStack.iml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 0000000..cc9f749
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/php.xml b/.idea/php.xml
new file mode 100644
index 0000000..f324872
--- /dev/null
+++ b/.idea/php.xml
@@ -0,0 +1,19 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..35eb1dd
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 0000000..81f1454
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,123 @@
+#FROM node:erbium
+
+FROM alpine:3.18
+
+ENV NODE_VERSION 22.1.0
+
+RUN addgroup -g 1000 node \
+ && adduser -u 1000 -G node -s /bin/sh -D node \
+ && apk add --no-cache \
+ libstdc++ \
+ && apk add --no-cache --virtual .build-deps \
+ curl \
+ && ARCH= OPENSSL_ARCH='linux*' && alpineArch="$(apk --print-arch)" \
+ && case "${alpineArch##*-}" in \
+ x86_64) ARCH='x64' CHECKSUM="087edf483f8bf94acfd41bdada76a296d0673f7739ebfe1179971c90f34d3a95" OPENSSL_ARCH=linux-x86_64;; \
+ x86) OPENSSL_ARCH=linux-elf;; \
+ aarch64) OPENSSL_ARCH=linux-aarch64;; \
+ arm*) OPENSSL_ARCH=linux-armv4;; \
+ ppc64le) OPENSSL_ARCH=linux-ppc64le;; \
+ s390x) OPENSSL_ARCH=linux-s390x;; \
+ *) ;; \
+ esac \
+ && if [ -n "${CHECKSUM}" ]; then \
+ set -eu; \
+ curl -fsSLO --compressed "https://unofficial-builds.nodejs.org/download/release/v$NODE_VERSION/node-v$NODE_VERSION-linux-$ARCH-musl.tar.xz"; \
+ echo "$CHECKSUM node-v$NODE_VERSION-linux-$ARCH-musl.tar.xz" | sha256sum -c - \
+ && tar -xJf "node-v$NODE_VERSION-linux-$ARCH-musl.tar.xz" -C /usr/local --strip-components=1 --no-same-owner \
+ && ln -s /usr/local/bin/node /usr/local/bin/nodejs; \
+ else \
+ echo "Building from source" \
+ # backup build
+ && apk add --no-cache --virtual .build-deps-full \
+ binutils-gold \
+ g++ \
+ gcc \
+ gnupg \
+ libgcc \
+ linux-headers \
+ make \
+ python3 \
+ # use pre-existing gpg directory, see https://github.com/nodejs/docker-node/pull/1895#issuecomment-1550389150
+ && export GNUPGHOME="$(mktemp -d)" \
+ # gpg keys listed at https://github.com/nodejs/node#release-keys
+ && for key in \
+ 4ED778F539E3634C779C87C6D7062848A1AB005C \
+ 141F07595B7B3FFE74309A937405533BE57C7D57 \
+ 74F12602B6F1C4E913FAA37AD3A89613643B6201 \
+ DD792F5973C6DE52C432CBDAC77ABFA00DDBF2B7 \
+ 61FC681DFB92A079F1685E77973F295594EC4689 \
+ 8FCCA13FEF1D0C2E91008E09770F7A9A5AE15600 \
+ C4F0DFFF4E8C1A8236409D08E73BC641CC11F4C8 \
+ 890C08DB8579162FEE0DF9DB8BEAB4DFCF555EF4 \
+ C82FA3AE1CBEDC6BE46B9360C43CEC45C17AB93C \
+ 108F52B48DB57BB0CC439B2997B01419BD92F80A \
+ A363A499291CBBC940DD62E41F10027AF002F8B0 \
+ CC68F5A3106FF448322E48ED27F5E38D5B0A215F \
+ ; do \
+ gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \
+ gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \
+ done \
+ && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION.tar.xz" \
+ && curl -fsSLO --compressed "https://nodejs.org/dist/v$NODE_VERSION/SHASUMS256.txt.asc" \
+ && gpg --batch --decrypt --output SHASUMS256.txt SHASUMS256.txt.asc \
+ && gpgconf --kill all \
+ && rm -rf "$GNUPGHOME" \
+ && grep " node-v$NODE_VERSION.tar.xz\$" SHASUMS256.txt | sha256sum -c - \
+ && tar -xf "node-v$NODE_VERSION.tar.xz" \
+ && cd "node-v$NODE_VERSION" \
+ && ./configure \
+ && make -j$(getconf _NPROCESSORS_ONLN) V= \
+ && make install \
+ && apk del .build-deps-full \
+ && cd .. \
+ && rm -Rf "node-v$NODE_VERSION" \
+ && rm "node-v$NODE_VERSION.tar.xz" SHASUMS256.txt.asc SHASUMS256.txt; \
+ fi \
+ && rm -f "node-v$NODE_VERSION-linux-$ARCH-musl.tar.xz" \
+ # Remove unused OpenSSL headers to save ~34MB. See this NodeJS issue: https://github.com/nodejs/node/issues/46451
+ && find /usr/local/include/node/openssl/archs -mindepth 1 -maxdepth 1 ! -name "$OPENSSL_ARCH" -exec rm -rf {} \; \
+ && apk del .build-deps \
+ # smoke tests
+ && node --version \
+ && npm --version
+
+ENV YARN_VERSION 1.22.19
+
+RUN apk add --no-cache --virtual .build-deps-yarn curl gnupg tar \
+ # use pre-existing gpg directory, see https://github.com/nodejs/docker-node/pull/1895#issuecomment-1550389150
+ && export GNUPGHOME="$(mktemp -d)" \
+ && for key in \
+ 6A010C5166006599AA17F08146C2130DFD2497F5 \
+ ; do \
+ gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$key" || \
+ gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" ; \
+ done \
+ && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz" \
+ && curl -fsSLO --compressed "https://yarnpkg.com/downloads/$YARN_VERSION/yarn-v$YARN_VERSION.tar.gz.asc" \
+ && gpg --batch --verify yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
+ && gpgconf --kill all \
+ && rm -rf "$GNUPGHOME" \
+ && mkdir -p /opt \
+ && tar -xzf yarn-v$YARN_VERSION.tar.gz -C /opt/ \
+ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarn /usr/local/bin/yarn \
+ && ln -s /opt/yarn-v$YARN_VERSION/bin/yarnpkg /usr/local/bin/yarnpkg \
+ && rm yarn-v$YARN_VERSION.tar.gz.asc yarn-v$YARN_VERSION.tar.gz \
+ && apk del .build-deps-yarn \
+ # smoke test
+ && yarn --version \
+ && rm -rf /tmp/*
+
+
+
+# Create app directory
+RUN mkdir -p /usr/src
+WORKDIR /usr/src
+
+# Install app dependencies
+COPY package.json /usr/src/
+RUN npm install
+
+COPY . /usr/src
+
+CMD [ "npm", "start" ]
\ No newline at end of file
diff --git a/docker-compose.yml b/docker-compose.yml
new file mode 100644
index 0000000..21ff925
--- /dev/null
+++ b/docker-compose.yml
@@ -0,0 +1,17 @@
+version: '3'
+services:
+ digifi-paystack-micro:
+ build:
+ context: .
+ dockerfile: Dockerfile
+ restart: unless-stopped
+ volumes:
+ - ./:/usr/src
+ - '/usr/src/node_modules'
+ ports:
+ - ${DOKCER_PORT}:5000
+ # environment:
+ # - PORT=${WRENCHJOB_PORT}
+ # - POSTGRE_URL=${WRENCHJOB_POSTGRE_URL}
+volumes:
+ src:
\ No newline at end of file
diff --git a/package.json b/package.json
index 71a4fa7..db78329 100644
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
- "name": "Sample Subscriptions App",
+ "name": "DigiFi Subscriptions",
"version": "1.0.0",
- "description": "A sample application showing how to use Paystack's Subscription API",
+ "description": "DigiFi Subscriptions with how Paystack's Subscription API",
"main": "server.js",
"scripts": {
"start": "node server.js",