Skip to main content

A Flask extension for Shopify app development

Project description

Flask-Shopify-Utils

The utils for Flask Application that build for Shopify Custom App


Installing

$pip install -U flask-shopify-utils

Get the sample code to start

After install the "flask-shopify-utils", you should able to get the sample code by running the following command.

$lazy-dog

Example / How to ...

Please check the example folder for more details.

Remember, this package is using Flask-SQLAlchemy, so you need to initialize the database first.

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_shopify_utils import ShopifyUtil

app = Flask(__name__)
# Init Database
db = SQLAlchemy()
db.init_app(app)

# Initial Shopify Utils
utils = ShopifyUtil()
utils.init_app(app)

# example: register default routes
utils.enroll_default_route()

Donate

Well, I have no idea how this work, just copy it from somewhere.

The Pallets organization develops and supports Flask and the libraries it uses. In order to grow the community of contributors and users, and allow the maintainers to devote more time to the projects, please donate today


First time setup

  • Download the repository to your local machine.
  • Create a virtualenv.
# Linux/macOS
$ python3 -m venv env
$ . env/bin/active

# Window
$ py -3 -m venv env
$ env/Scripts/active
  • Install pip-tools, twine and build in the virtualenv.
>pip install --upgrade pip
>pip install pip-tools twine build
  • Install the development dependencies, then install Flask-ShopifyUtils in editable mode.
$ pip install -r requirements/dev.txt && pip install -e .
  • Build the wheel
# new 
>python -m build
# For more reference https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html
  • Deploy to PyPI
# check
>twine check dist/*
# upload
>twine upload dist/* --skip-existing

requirements.txt

All dependencies are managed by pip-tools, so you need to install it first. And you can find them from the requirements folder.

# development
>pip-compile --extra=dev --output-file=requirements/dev.txt pyproject.toml

# production
>pip-compile --output-file=requirements/index.txt pyproject.toml

Running the tests

Make sure you have install the repository locally.

# install the package
>pip install -e .
# install the pytest
>pip install pytest
# run all tests
>pytest
# run tests with output
>pytest -s
# run specific test
>pytest -vs tests/test_init.py
# run specific test case
>pytest -vs tests/test_init.py::test_init_app

Reference

Packing for Python

TODO

Add test for ShopifyUtil methods

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flask_shopify_utils-0.2.3.tar.gz (16.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flask_shopify_utils-0.2.3-py3-none-any.whl (16.7 kB view details)

Uploaded Python 3

File details

Details for the file flask_shopify_utils-0.2.3.tar.gz.

File metadata

  • Download URL: flask_shopify_utils-0.2.3.tar.gz
  • Upload date:
  • Size: 16.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.16

File hashes

Hashes for flask_shopify_utils-0.2.3.tar.gz
Algorithm Hash digest
SHA256 cf0bcbaefb0b3a18de6c29ec6a4201d2504e74eb5259fceda4e3d44782af4489
MD5 d9ac90340a32f7936eaf601e88652376
BLAKE2b-256 1bd8c12b88b9b3859b66124378e4aaea4dc68c6449b541c4f3170371e8fb31c5

See more details on using hashes here.

File details

Details for the file flask_shopify_utils-0.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for flask_shopify_utils-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 224c4b93ad4ed0afcddbc8de9b95311ac7cad2e66ff965cf2869922a05b52bb5
MD5 5a4c6cccc55fc3575535e66b4df13240
BLAKE2b-256 69498967a2c394839afb1c6fcba375b22c3f6845ccd2b8ff48efe23d81be13a7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page