Skip to main content

Make Post Sell

Project description

Make Post Sell

The Make Post Sell monolith platform service.

You can use the SaaS or self-host! Accepts credit cards (Stripe), PayPal, Monero (XMR), and Dogecoin (DOGE) payments.

Our blog acts as our user guide & also uses make_post_sell!

Quick Start: Operating a Server with PyPI or Source Code

Before you start, navigate to the directory where you want to install make_post_sell database & files.

This Makefile-based workflow lets you choose between installing make_post_sell from PyPI packages or directly from the source code (editable mode). Both flows create a virtual environment in ./env and store configuration and SQLite data in the persistent ./data directory.

  1. Install make_post_sell

    • PyPI Installation: Download the Makefile and run:

      wget "https://git.unturf.com/engineering/make-post-sell/make_post_sell/-/raw/master/Makefile"
      make install-from-pypi
    • Source Installation (Editable Mode): Clone the repository and run:

      git clone ssh://git@git.unturf.com:2222/engineering/make-post-sell/make_post_sell.git
      make install-from-source
    • Production Installation (Non‑Editable): For production use (non‑editable even from source), run:

      git clone ssh://git@git.unturf.com:2222/engineering/make-post-sell/make_post_sell.git
      make install-from-source-prod
  2. Activate the Virtual Environment

    Before running any commands, activate the virtual environment:

    source env/bin/activate
  3. Start the Development Server

    You’ll want to configure the system in data/development.ini.

    Typically I control most stuff with environment vars, for example vars.sh:

    # boto3 style credentials for s3/digital-ocean spaces.
    # this is for storing content & physical products.
    export MPS_APP_MAIN_BUCKET="removed"
    export MPS_APP_SECURE_UPLOADS_ACCESS_KEY="removed"
    export MPS_APP_SECURE_UPLOADS_SECRET_KEY="removed"
    
    # stripe keys for collecting credit cards & crypto.
    # NOTE: These are used by tests, shops configure their own keys in the UI
    export MPS_TEST_STRIPE_PUBLIC_API_KEY="pk_test_removed"
    export MPS_TEST_STRIPE_SECRET_API_KEY="sk_test_removed"
    
    # the root domain acts as a SaaS for many shop domains!
    export MAKE_POST_SELL_ROOT_DOMAIN="example.com"
    export MAKE_POST_SELL_ROOT_URL="http://example.com:6501"
    
    # optional: email for the root domain owner
    export MAKE_POST_SELL_DOMAIN_OWNER_EMAIL="admin@example.com"
    
    # optional: DKIM email signing (commented out by default)
    # export MPS_APP_DKIM_PRIVATE_KEY_PATH="/path/to/dkim/private.key"
    # export MPS_APP_DKIM_SELECTOR="selector"

    With the virtual environment active, start the server:

    source vars.sh
    make serve

    Then browse to http://127.0.0.1:6501/ to view the app.

Running Tests

We currently use pytest:

make test

SQL Migrations

If your deployment is brand new, you don’t need to run any migrations.

Otherwise, it should be safe to run this at anytime to catch your database up:

alembic -c development.ini upgrade head

To look at the current revision and the history run these:

alembic -c development.ini history
alembic -c development.ini current

If you ever want to cut a new migration script, you can run this:

alembic -c development.ini revision -m "Added email_id column to User table."

Then you can edit / modify the generated .py file with your changes.

You can also autogenerate a new migration script using –autogenerate. Alembic will prepare a migration script by comparing the state of the database with the state of the model:

alembic -c development.ini revision --autogenerate -m "autogenerated indicies."

You should review the recommended migration script before upgrade.

misc

You may source the new Python virtual environment during development:

# source env/bin/activate.fish
. env/bin/activate

Python Pyramid Shell

If you want to use an interactive Python interpreter to interact with Make Post Sell app/models & DB:

pshell development.ini

For example, we needed to migrate production data using this script:

# begin the database transaction.
request.tm.begin()

suses = models.stripe_user_shop.get_all_stripe_user_shop_objects(request.dbsession)
for sus in suses:
    try:
        sus.active_card_id = sus.stripe_customer_default_source.id
        request.dbsession.add(sus)
    except AttributeError:
        pass

# flush / commit all changes stored the the sqlachemy session.
request.dbsession.flush()

# commit/close the database transaction to really make changes.
request.tm.commit()

Contributing

  • Establish communication with Russell or another admin to bless your git.unturf.com gitlab account & put you into the proper roles.

  • Russell should see your account request but due to spam you have to ask him directly for approval via email or some other means of comms.

  • Clone repo & make commits

  • Create merge requests, we automatically run the unit & headless functional tests on each commit

  • On merge we release to the production site & see the change across users.

Optionally, format your code.

This is not set in stone, but if you want to use a formatter this is the path for now!

Python

black (manual)

Jinja2

None (not needed, neither is an HTML formatter)

JavaScript

Prettier or biome (manual)

CSS

Prettier or biome (manual)

Licence

All contributed code is placed in the public domain.

source code: https://git.unturf.com/engineering/make-post-sell/make_post_sell

MakePostSell & make-post-sell are trademarked, do not misrepresent the brand.

Feel free to white label any code or themes into your own brand.

Original Developer: Russell Ballestrini

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

make_post_sell-1.1.5.tar.gz (495.7 kB view details)

Uploaded Source

Built Distribution

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

make_post_sell-1.1.5-py3-none-any.whl (540.8 kB view details)

Uploaded Python 3

File details

Details for the file make_post_sell-1.1.5.tar.gz.

File metadata

  • Download URL: make_post_sell-1.1.5.tar.gz
  • Upload date:
  • Size: 495.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for make_post_sell-1.1.5.tar.gz
Algorithm Hash digest
SHA256 195eaea84bb9dec1db513b973afdc79c96304338fcf6a7d3ee4f66fab98d05ec
MD5 6bafdc4faedb187c05190283b9b897dd
BLAKE2b-256 31f362f507a05f44c23492ede0a97137c449ccb79527b6091bc29fe1f6807a36

See more details on using hashes here.

File details

Details for the file make_post_sell-1.1.5-py3-none-any.whl.

File metadata

  • Download URL: make_post_sell-1.1.5-py3-none-any.whl
  • Upload date:
  • Size: 540.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for make_post_sell-1.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 f46e8ff25e77c7767a8ebb14c8633e2014eab47ab00990fb0830832c7ced56d5
MD5 f7c043cc5adff4953e611cdfb9bcfd75
BLAKE2b-256 fca1e687156d74262d23b183490dafad5bc2b69cbf6b8f4511abecd0db233254

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