Skip to content
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
3917744
chore: initial changes to include postgrest in monorepo
o-santi Aug 28, 2025
b08af16
chore: add postgrest to release-please
o-santi Aug 28, 2025
40da11e
chore: modify READMEs
o-santi Aug 28, 2025
70f0c16
chore: improve `make help` message
o-santi Aug 28, 2025
f3d1e2e
fix: fix reference in `make postgrest.build`
o-santi Aug 28, 2025
edec3f5
chore: improve the README to reflect the current setup
o-santi Aug 29, 2025
044c719
fix: fix release please config
o-santi Aug 29, 2025
181ba57
chore: improve readme some more
o-santi Aug 29, 2025
c95b593
fix: add `run-unasync.py`
o-santi Aug 29, 2025
988249a
chore: move most badges to top of repo
o-santi Aug 29, 2025
03a4aa5
chore: rename realtime to pypi package name
o-santi Aug 29, 2025
8ae4d15
chore: fix more readmes to mention uv, remove poetry backwards compat…
o-santi Aug 29, 2025
49a528a
chore: modify pyproject's urls to reflect monorepo
o-santi Aug 29, 2025
fef7417
chore: add myself as a maintaner to all the projects
o-santi Aug 29, 2025
fd5da10
fix: fix coverage badge to use coveralls
o-santi Aug 29, 2025
4f48d3e
fix: make main coveralls badge point to correct repo
o-santi Aug 29, 2025
bbe82f0
fix: actually grab badge from coveralls website so it is correct
o-santi Aug 29, 2025
c261594
chore: remove unused whitespace
o-santi Sep 1, 2025
fe8a66e
chore: add name parameter to auth and postgrest docker compose
o-santi Sep 1, 2025
a428e7c
fix: change postgres port in postgrest to not conflict with auth
o-santi Sep 1, 2025
6204de6
fix: do not run ci with -j for now
o-santi Sep 1, 2025
12b60b8
fix: improve nix setup, add manual override
o-santi Sep 2, 2025
3ee900e
fix: set UV_PROJECT_ENVIRONMENT in nix so that uv doesnt generate a v…
o-santi Sep 2, 2025
c429957
fix: remove obsolete `version` keywords from docker-compose
o-santi Sep 2, 2025
cc1848f
fix: add a sleep after `postgrest.start-infra` to ensure reproducibility
o-santi Sep 2, 2025
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
1 change: 1 addition & 0 deletions .release-please-manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
"src/realtime": "2.7.0",
"src/functions": "0.10.1",
"src/storage": "0.12.1",
"src/postgrest": "1.1.1",
"src/auth": "2.12.3"
}
17 changes: 12 additions & 5 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
.PHONY: ci, default, pre-commit, clean, start-infra, stop-infra

PACKAGES := functions realtime storage auth supabase
PACKAGES := functions realtime storage auth postgrest supabase
FORALL_PKGS = $(foreach pkg, $(PACKAGES), $(pkg).$(1))

help::
Expand All @@ -17,19 +17,23 @@ help::
@echo " pre-commit -- Run pre-commit on all files"

clean: $(call FORALL_PKGS,clean)
rm -rf dist .ruff_cache .pytest_cache
help::
@echo " clean -- Delete cache files and coverage reports from tests"

publish: $(call FORALL_PKGS,build)
uv publish

# not all packages have infra, so just manually instantiate the ones that do for now
start-infra: realtime.start-infra storage.start-infra auth.start-infra
start-infra: realtime.start-infra storage.start-infra auth.start-infra postgrest.start-infra
help::
@echo " start-infra -- Start all containers necessary for tests. NOTE: it is not necessary to this before running CI tests, they start the infra by themselves"
stop-infra: realtime.stop-infra storage.stop-infra auth.stop-infra
@echo " start-infra -- Start all containers necessary for tests."
@echo " NOTE: it is not necessary to this command before running CI tests"

stop-infra: realtime.stop-infra storage.stop-infra auth.stop-infra postgrest.stop-infra
help::
@echo " stop-infra -- Stop all infra used by tests. NOTE: tests do leave their infra running, so run this to ensure all containers are stopped"
@echo " stop-infra -- Stop all infra used by tests."
@echo " NOTE: run this command to ensure all containers are stopped after tests"


realtime.%:
Expand All @@ -44,6 +48,9 @@ storage.%:
auth.%:
@$(MAKE) -C src/auth $*

postgrest.%:
@$(MAKE) -C src/postgrest $*

supabase.%:
@$(MAKE) -C src/supabase $*

Expand Down
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
# `supabase-py`

Python monorepo for all [Supabase](https://supabase.com) libraries. This is a work in progress, and currently these are the ones contained in this repository:
Python monorepo for all [Supabase](https://supabase.com) libraries.

- [supabase](src/supabase/README.md)
- [realtime](src/realtime/README.md)
- [supabase_functions](src/functions/README.md)
- [storage3](src/storage/README.md)
- [postgrest](src/postgrest/README.md)
- [supabase_auth](src/auth/README.md)

Relevant links:
Expand Down
2 changes: 2 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ members = [
"src/functions",
"src/supabase",
"src/storage",
"src/postgrest",
"src/auth"
]

Expand All @@ -12,6 +13,7 @@ realtime = { workspace = true }
supabase_functions = { workspace = true }
supabase_auth = { workspace = true }
storage3 = { workspace = true }
postgrest = { workspace = true }
supabase = { workspace = true }

[tool.pytest.ini_options]
Expand Down
4 changes: 4 additions & 0 deletions release-please-config.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,10 @@
"changelog-path": "src/storage/CHANGELOG.md",
"release-type": "python"
},
"src/storage": {
"changelog-path": "src/postgrest/CHANGELOG.md",
"release-type": "python"
},
"src/supabase": {
"changelog-path": "src/supabase/CHANGELOG.md",
"release-type": "python"
Expand Down
21 changes: 21 additions & 0 deletions src/postgrest/.devcontainer/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# See here for image contents: https://github.com/microsoft/vscode-dev-containers/tree/v0.203.0/containers/python-3/.devcontainer/base.Dockerfile

# [Choice] Python version (use -bullseye variants on local arm64/Apple Silicon): 3, 3.10, 3.9, 3.8, 3.7, 3.6, 3-bullseye, 3.10-bullseye, 3.9-bullseye, 3.8-bullseye, 3.7-bullseye, 3.6-bullseye, 3-buster, 3.10-buster, 3.9-buster, 3.8-buster, 3.7-buster, 3.6-buster
ARG VARIANT="3.10-bullseye"
FROM mcr.microsoft.com/vscode/devcontainers/python:0-${VARIANT}

# [Choice] Node.js version: none, lts/*, 16, 14, 12, 10
ARG NODE_VERSION="none"
RUN if [ "${NODE_VERSION}" != "none" ]; then su vscode -c "umask 0002 && . /usr/local/share/nvm/nvm.sh && nvm install ${NODE_VERSION} 2>&1"; fi

# [Optional] If your pip requirements rarely change, uncomment this section to add them to the image.
# COPY requirements.txt /tmp/pip-tmp/
# RUN pip3 --disable-pip-version-check --no-cache-dir install -r /tmp/pip-tmp/requirements.txt \
# && rm -rf /tmp/pip-tmp

# [Optional] Uncomment this section to install additional OS packages.
# RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
# && apt-get -y install --no-install-recommends <your-package-list-here>

# [Optional] Uncomment this line to install global node packages.
# RUN su vscode -c "source /usr/local/share/nvm/nvm.sh && npm install -g <your-package-here>" 2>&1
87 changes: 87 additions & 0 deletions src/postgrest/.devcontainer/devcontainer.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at:
// https://github.com/microsoft/vscode-dev-containers/tree/v0.203.0/containers/python-3
{
"name": "Python 3",
"runArgs": [
"--init"
],
"build": {
"dockerfile": "Dockerfile",
"context": "..",
"args": {
// Update 'VARIANT' to pick a Python version: 3, 3.10, 3.9, 3.8, 3.7, 3.6
// Append -bullseye or -buster to pin to an OS version.
// Use -bullseye variants on local on arm64/Apple Silicon.
"VARIANT": "3.10-bullseye",
// Options
"NODE_VERSION": "lts/*"
}
},
// Set *default* container specific settings.json values on container create.
"settings": {
"python.pythonPath": "/usr/local/bin/python",
"python.languageServer": "Pylance",
"python.linting.enabled": true,
"python.linting.flake8Enabled": true,
"python.formatting.autopep8Path": "/usr/local/py-utils/bin/autopep8",
"python.formatting.blackPath": "/usr/local/py-utils/bin/black",
"python.formatting.yapfPath": "/usr/local/py-utils/bin/yapf",
"python.linting.banditPath": "/usr/local/py-utils/bin/bandit",
"python.linting.flake8Path": "/usr/local/py-utils/bin/flake8",
"python.linting.mypyPath": "/usr/local/py-utils/bin/mypy",
"python.linting.pycodestylePath": "/usr/local/py-utils/bin/pycodestyle",
"python.linting.pydocstylePath": "/usr/local/py-utils/bin/pydocstyle",
"python.linting.pylintPath": "/usr/local/py-utils/bin/pylint",
"python.analysis.diagnosticMode": "workspace",
"files.exclude": {
"**/.ipynb_checkpoints": true,
"**/.pytest_cache": true,
"**/*pycache*": true
},
"python.formatting.provider": "black",
"python.linting.flake8Args": [
"--max-line-length=88",
"--extend-ignore=E203"
],
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.organizeImports": true
},
"python.sortImports.args": [
"--multi-line=3",
"--trailing-comma",
"--force-grid-wrap=0",
"--use-parentheses",
"--line-width=88",
],
"markdownlint.config": {
"MD022": false,
"MD024": false,
"MD032": false,
"MD033": false
}
},
// Add the IDs of extensions you want installed when the container is created.
"extensions": [
"ms-python.python",
"ms-python.vscode-pylance",
"ms-azuretools.vscode-docker",
"donjayamanne.githistory",
"felipecaputo.git-project-manager",
"github.copilot-nightly",
"eamodio.gitlens",
"davidanson.vscode-markdownlint"
],
// Use 'forwardPorts' to make a list of ports inside the container available locally.
// "forwardPorts": [],
// Use 'postCreateCommand' to run commands after the container is created.
// "postCreateCommand": "pip3 install --user -r requirements.txt",
// Comment out connect as root instead. More info: https://aka.ms/vscode-remote/containers/non-root.
"remoteUser": "vscode",
"features": {
"docker-in-docker": "latest",
"git": "latest",
"git-lfs": "latest",
"github-cli": "latest"
}
}
Loading
Loading