# BigCommerce Toolkit
BigCommerce Toolkit is a command-line interface (CLI) tool for BigCommerce's API. It follows UNIX principles of "do one thing well" and organizes commands based on resource type and action. This structure aligns with RESTful API principles, providing a logical and hierarchical system for managing various BigCommerce resources.
## Features
- **Resource-based Commands:** Commands are structured around resource types (e.g., products, categories, customers) and their respective actions (e.g., get, create, update, delete).
- **Hierarchical Command Structure:** Similar to UNIX tools like `git`, commands are grouped logically to align with BigCommerce's API structure.
- **Environment Variable Support:** Store hash and authentication token can be set via environment variables for convenience.
- **Paginated Requests:** Supports fetching all pages of data for GET requests with pagination.
- **Standard Input (stdin) Support:** Allows reading values from stdin for easier scripting and piping data between commands.
## Installation
To install BigCommerce Toolkit, clone the repository and install the necessary dependencies.
```sh
pip install bigcommerce-toolkit
```
## Usage
### Basic Command Structure
The CLI uses a structure similar to UNIX commands, where you specify the resource type, action, and additional parameters or options as needed.
```sh
bigc [<options>] <resource> [<subresource>] <action> [<arguments>]
```
### Setting Up Environment Variables
Before using the tool, set the environment variables for your BigCommerce store hash and authentication token.
```sh
export BIGCOMMERCE_STORE_HASH=your_store_hash
export BIGCOMMERCE_AUTH_TOKEN=your_auth_token
```
Alternatively, you can pass these values directly via command-line options.
```sh
bigc --store-hash your_store_hash --auth-token your_auth_token …
```
### Example Commands
## Create a Product (via Arguments)
To create a new product with data provided as named arguments:
```sh
bigc products create --name "New Product" --price 19.99 --type physical --weight 0
```
## Create a Product (via Standard Input)
BigCommerce Toolkit also supports reading values from `stdin`, allowing for piping data between commands for easier scripting. For example:
```sh
echo '{"name": "New Product", "price": 19.99, "type": "physical", "weight": 0}' | bigc products create --data -
```
### Update a Product
This can be further leveraged by piping through additional tools like `jq`. First, retrieving a product's ID by the product's name, and then updating that product's price:
```sh
bigc products get --name:like "New Product" | jq -r '.data[0].id' | bigc product update --id - --price 24.99
```
## Fetching All Products
For endpoints that support pagination, you can fetch all pages of data. Using tools like `jq` and `csvlook`, it is possible to format the data into a more readable format.
```sh
bigc products get-all | jq -r '["id","sku","name"], (.data[] | [.id,.sku,.name]) | @csv' | csvlook
```
## Contributing
We welcome contributions to improve the project. Please submit issues and pull requests via GitHub.
Raw data
{
"_id": null,
"home_page": "https://github.com/TrellisCommerce/bigcommerce-toolkit",
"name": "bigcommerce-toolkit",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.12",
"maintainer_email": null,
"keywords": "bigcommerce, api, cli",
"author": "Joey Hoer",
"author_email": "me@joeyhoer.com",
"download_url": "https://files.pythonhosted.org/packages/b5/ae/b386428916d8232a3dc87dd008a8c32fd9a61eacb33be0966796bc6965b3/bigcommerce_toolkit-0.1.7.tar.gz",
"platform": null,
"description": "# BigCommerce Toolkit\n\nBigCommerce Toolkit is a command-line interface (CLI) tool for BigCommerce's API. It follows UNIX principles of \"do one thing well\" and organizes commands based on resource type and action. This structure aligns with RESTful API principles, providing a logical and hierarchical system for managing various BigCommerce resources.\n\n## Features\n\n- **Resource-based Commands:** Commands are structured around resource types (e.g., products, categories, customers) and their respective actions (e.g., get, create, update, delete).\n- **Hierarchical Command Structure:** Similar to UNIX tools like `git`, commands are grouped logically to align with BigCommerce's API structure.\n- **Environment Variable Support:** Store hash and authentication token can be set via environment variables for convenience.\n- **Paginated Requests:** Supports fetching all pages of data for GET requests with pagination.\n- **Standard Input (stdin) Support:** Allows reading values from stdin for easier scripting and piping data between commands.\n\n## Installation\n\nTo install BigCommerce Toolkit, clone the repository and install the necessary dependencies.\n\n```sh\npip install bigcommerce-toolkit\n```\n\n## Usage\n\n### Basic Command Structure\n\nThe CLI uses a structure similar to UNIX commands, where you specify the resource type, action, and additional parameters or options as needed.\n\n```sh\nbigc [<options>] <resource> [<subresource>] <action> [<arguments>]\n```\n\n### Setting Up Environment Variables\n\nBefore using the tool, set the environment variables for your BigCommerce store hash and authentication token.\n\n```sh\nexport BIGCOMMERCE_STORE_HASH=your_store_hash\nexport BIGCOMMERCE_AUTH_TOKEN=your_auth_token\n```\n\nAlternatively, you can pass these values directly via command-line options.\n\n```sh\nbigc --store-hash your_store_hash --auth-token your_auth_token \u2026\n```\n\n### Example Commands\n\n## Create a Product (via Arguments)\n\nTo create a new product with data provided as named arguments:\n\n```sh\nbigc products create --name \"New Product\" --price 19.99 --type physical --weight 0\n```\n\n## Create a Product (via Standard Input)\n\nBigCommerce Toolkit also supports reading values from `stdin`, allowing for piping data between commands for easier scripting. For example:\n\n```sh\necho '{\"name\": \"New Product\", \"price\": 19.99, \"type\": \"physical\", \"weight\": 0}' | bigc products create --data -\n```\n\n### Update a Product\n\nThis can be further leveraged by piping through additional tools like `jq`. First, retrieving a product's ID by the product's name, and then updating that product's price:\n\n```sh\nbigc products get --name:like \"New Product\" | jq -r '.data[0].id' | bigc product update --id - --price 24.99\n```\n\n## Fetching All Products\n\nFor endpoints that support pagination, you can fetch all pages of data. Using tools like `jq` and `csvlook`, it is possible to format the data into a more readable format.\n\n```sh\nbigc products get-all | jq -r '[\"id\",\"sku\",\"name\"], (.data[] | [.id,.sku,.name]) | @csv' | csvlook\n```\n\n## Contributing\n\nWe welcome contributions to improve the project. Please submit issues and pull requests via GitHub.\n",
"bugtrack_url": null,
"license": null,
"summary": "A UNIX-style tool which provides easy access to BigCommerce's API from the command line.",
"version": "0.1.7",
"project_urls": {
"Homepage": "https://github.com/TrellisCommerce/bigcommerce-toolkit",
"Repository": "https://github.com/TrellisCommerce/bigcommerce-toolkit"
},
"split_keywords": [
"bigcommerce",
" api",
" cli"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "9c38645dae3c53b13c1643fc747064d7528716e03e1b37e3c5ff7d0f75a52795",
"md5": "31f602c159af96865d7bd5a797ab42ef",
"sha256": "2e1c7503c81423f0575b4fb0531e9d0b6a9a11b5e41f0c0fbe059601ac898188"
},
"downloads": -1,
"filename": "bigcommerce_toolkit-0.1.7-py3-none-any.whl",
"has_sig": false,
"md5_digest": "31f602c159af96865d7bd5a797ab42ef",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.12",
"size": 7436,
"upload_time": "2024-10-01T15:04:18",
"upload_time_iso_8601": "2024-10-01T15:04:18.687161Z",
"url": "https://files.pythonhosted.org/packages/9c/38/645dae3c53b13c1643fc747064d7528716e03e1b37e3c5ff7d0f75a52795/bigcommerce_toolkit-0.1.7-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b5aeb386428916d8232a3dc87dd008a8c32fd9a61eacb33be0966796bc6965b3",
"md5": "25e626d27dc31f49b6aca14ed38087d5",
"sha256": "6d528a08b62ef3a54c4b76cc6c71837672bc1d52ab5599b50adf718785414a34"
},
"downloads": -1,
"filename": "bigcommerce_toolkit-0.1.7.tar.gz",
"has_sig": false,
"md5_digest": "25e626d27dc31f49b6aca14ed38087d5",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.12",
"size": 7655,
"upload_time": "2024-10-01T15:04:19",
"upload_time_iso_8601": "2024-10-01T15:04:19.623260Z",
"url": "https://files.pythonhosted.org/packages/b5/ae/b386428916d8232a3dc87dd008a8c32fd9a61eacb33be0966796bc6965b3/bigcommerce_toolkit-0.1.7.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-01 15:04:19",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "TrellisCommerce",
"github_project": "bigcommerce-toolkit",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "bigcommerce-toolkit"
}