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

Check the code format

>flake8

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

[] Remove state from check_callback method [] Remove state cookie form intall method 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.5.tar.gz (16.1 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.5-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: flask_shopify_utils-0.2.5.tar.gz
  • Upload date:
  • Size: 16.1 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.5.tar.gz
Algorithm Hash digest
SHA256 2e271faaf8b1bb0aead45f5a69d0abe5e972af9e6125c73d44b39486c2ae69fa
MD5 bb14ddadbf1e0cc0dcd82be6109b5ed0
BLAKE2b-256 f8e70e17d5e1f7a74134b2b72741b8a5fb07f2d78b90f908d3a5e8986e27b809

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for flask_shopify_utils-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 31f86dc2fab2438cefced8347018af5650613d22dfe74446eb1d33c68c1ce097
MD5 9d5a0bfff84b030cb476c9d9db655d42
BLAKE2b-256 9e5bdd16072a79cedce86028abd175edf3ad4fe81c5c0cbb975ef2545e0b97ab

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