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.6.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.6-py3-none-any.whl (16.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for flask_shopify_utils-0.2.6.tar.gz
Algorithm Hash digest
SHA256 f592c150fe1d564d66327badd2abf6b69158596be416f30b7966a68d45f67a26
MD5 a2d500f1df6a0f6a335751f748900d35
BLAKE2b-256 5786b907b4cfcacef195dd24cf71f3bbd6c2227a3bcf227908268274fc4199d4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for flask_shopify_utils-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 d156c85a9f1960d4512176e03cc3cc126c03fdbb16b10b25b884e04123122959
MD5 679a59ccb16cee8274ae4e646d640117
BLAKE2b-256 109d8a2928ef01d1d1dbb23d6891febb5e4cb5c48fc3268813f03f00081a4193

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