-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #63 from Code4GovTech/dev
Merging Dev With Main
- Loading branch information
Showing
14 changed files
with
392 additions
and
185 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
name: Build and Push Docker Image | ||
|
||
on: | ||
push: | ||
branches: | ||
- main | ||
- dev | ||
release: | ||
types: [published] | ||
env: | ||
REGISTRY: ghcr.io | ||
IMAGE_NAME: ${{ github.repository }} | ||
|
||
jobs: | ||
build-and-push: | ||
runs-on: ubuntu-latest | ||
# Sets the permissions granted to the `GITHUB_TOKEN` for the actions in this job. | ||
permissions: | ||
contents: read | ||
packages: write | ||
steps: | ||
|
||
- name: Checkout code | ||
uses: actions/checkout@v2 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v2 | ||
|
||
- name: Log in to the Container registry | ||
uses: docker/login-action@v3 | ||
with: | ||
registry: ${{ env.REGISTRY }} | ||
username: ${{ github.actor }} | ||
password: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Extract metadata (tags, labels) for Docker | ||
id: meta | ||
uses: docker/metadata-action@9ec57ed1fcdbf14dcef7dfbe97b2010124a938b7 | ||
with: | ||
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | ||
tags: | | ||
# minimal | ||
type=pep440,pattern={{version}},value=${{ github.ref_name }},enable=${{ github.event_name == 'release' }} | ||
# branch event | ||
type=ref,event=branch | ||
type=raw,value=latest,enable=${{ github.event_name == 'release' }} | ||
- name: Build and Push Docker image | ||
uses: docker/build-push-action@v4 | ||
with: | ||
# build-args: | ||
context: . | ||
push: true | ||
cache-from: type=gha | ||
cache-to: type=gha,mode=max | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
[submodule "shared_migrations"] | ||
path = shared_migrations | ||
url = https://github.com/Code4GovTech/shared-models-migrations.git |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,61 +0,0 @@ | ||
import os, sys | ||
from typing import Any | ||
from supabase import create_client, Client | ||
from supabase.lib.client_options import ClientOptions | ||
from abc import ABC, abstractmethod | ||
|
||
client_options = ClientOptions(postgrest_client_timeout=None) | ||
|
||
|
||
|
||
class SupabaseInterface(): | ||
|
||
_instance = None | ||
|
||
def __init__(self): | ||
if not SupabaseInterface._instance: | ||
|
||
# Load environment variables | ||
from dotenv import load_dotenv | ||
load_dotenv() | ||
|
||
SUPABASE_URL = os.getenv('SUPABASE_URL') | ||
SUPABASE_KEY = os.getenv('SUPABASE_KEY') | ||
self.client: Client = create_client(SUPABASE_URL, SUPABASE_KEY) | ||
SupabaseInterface._instance = self | ||
else: | ||
SupabaseInterface._instance = self._instance | ||
|
||
|
||
|
||
@staticmethod | ||
def get_instance(): | ||
# Static method to retrieve the singleton instance | ||
if not SupabaseInterface._instance: | ||
# If no instance exists, create a new one | ||
SupabaseInterface._instance = SupabaseInterface() | ||
return SupabaseInterface._instance | ||
|
||
|
||
def readAll(self, table): | ||
data = self.client.table(f"{table}").select("*").execute() | ||
return data.data | ||
|
||
def add_data(self, data,table_name): | ||
data = self.client.table(table_name).insert(data).execute() | ||
return data.data | ||
|
||
def add_data_filter(self, data, table_name): | ||
# Construct the filter based on the provided column names and values | ||
filter_data = {column: data[column] for column in ['dmp_id','issue_number','owner']} | ||
|
||
# Check if the data already exists in the table based on the filter | ||
existing_data = self.client.table(table_name).select("*").eq('dmp_id',data['dmp_id']).execute() | ||
|
||
# If the data already exists, return without creating a new record | ||
if existing_data.data: | ||
return "Data already exists" | ||
|
||
# If the data doesn't exist, insert it into the table | ||
new_data = self.client.table(table_name).insert(data).execute() | ||
return new_data.data | ||
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.