Python wrapper for the Etsy api
Project description
Why?
To make it easier to interact with the Etsy API in Python.
Installation
sudp pip install python-etsy
Usage
Initialization
>>> from etsy import Etsy >>> e = Etsy(consumer_key, consumer_secret) # gotten from signing up at etsy.com/developers
Get info for user
>>> e.get_user_info('priestc') {u'count': 1, u'pagination': {}, u'params': {u'user_id': u'priestc'}, u'results': [{u'creation_tsz': 1338405910, u'feedback_info': {u'count': 0, u'score': None}, u'login_name': u'priestc', u'referred_by_user_id': None, u'user_id': 22138099}], u'type': u'User'}
Searching for users
>>> e.find_user('william') {u'count': 27956, u'pagination': {u'effective_limit': 25, u'effective_offset': 0, u'effective_page': 1, u'next_offset': 25, u'next_page': 2}, u'params': {u'keywords': u'william', u'limit': 25, u'offset': 0, u'page': None}, u'results': [{u'creation_tsz': 1320715538, u'feedback_info': {u'count': 0, u'score': None}, u'login_name': u'almostbohemian', u'referred_by_user_id': None, u'user_id': 17479899}, {u'creation_tsz': 1335125907, u'feedback_info': {u'count': 0, u'score': None}, u'login_name': u'Blawesomes', u'referred_by_user_id': None, u'user_id': 21276820}, {u'creation_tsz': 1339310987, u'feedback_info': {u'count': 0, u'score': None}, u'login_name': u'cityfleet', u'referred_by_user_id': None, u'user_id': 22385428}, {u'creation_tsz': 1321655636, u'feedback_info': {u'count': 2, u'score': 100}, u'login_name': u'way2easy4ron', u'referred_by_user_id': None, ...
Showing listings
Listings are items that are for sale on the site.
>>> e.show_listings(color='#FF00FF') {u'count': 15, u'pagination': {u'effective_limit': 25, u'effective_offset': 0, u'effective_page': 1, u'next_offset': None, u'next_page': None}, u'params': {u'category': None, u'color': u'#FF0000', u'color_accuracy': u'5', u'geo_level': u'city', u'keywords': None, u'lat': None, u'limit': 25, u'location': None, u'lon': None, u'materials': None, u'max_price': None, u'min_price': None, u'offset': 0, u'page': None, u'sort_on': u'created', u'sort_order': u'down', u'tags': None}, u'results': [{u'brightness': 99, u'category_id': 69152465, u'category_path': [u'Patterns', u'Handmade'], u'creation_tsz': 1343606971, u'currency_code': u'USD', u'description': u'This listing is for...', u'ending_tsz': 1354165200, u'featured_rank': 0, u'hue': 0, u'is_black_and_white': False, u'is_supply': None, u'last_modified_tsz': 1343606971, u'listing_id': 55489116, u'materials': [u'pdf email pattern', u'beads', u'needles and thread'], u'num_favorers': 4, u'occasion': None, u'original_creation_tsz': 1283592254, u'price': u'35.00', u'quantity': 1, u'recipient': None, u'saturation': 100, u'shop_section_id': 6766997, u'state': u'active', u'state_tsz': 1323227794, u'style': None, u'tags': [u'beading', u'beadweaving', u'peyote', u'bracelet', u'cuff', u'snow leopard', u'blue', u'red', u'white', u'grey', u'dust team', u'ebw team'], ...
Authenticating with OAuth
>>> e.get_auth_url(permissions=['email_r', 'listings_r']) {'oauth_token': u'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX', 'oauth_token_secret': u'XXXXXXXXXX', 'url': u'https://www.etsy.com/oauth/signin?oauth_consumer_key=...'}
The user then is redirected to the URL (you must save the oauth_token and oauth_token_secret for later in step two).
The list of all permissions can be found [here.](http://www.etsy.com/developers/documentation/getting_started/oauth#section_permission_scopes)
Once the user click the link and authenticates your app, the user then copy/pastes the verification code back to your app
>>> e.get_auth_token(verification_code, oauth_token, oauth_token_secret) {'oauth_token': u'XXXXXXXXXXXXXXXXXXXXXXXXXXXXX', 'oauth_token_secret': u'XXXXXXXXXXXX'}
The new oauth_token and oauth_token_secret are permanent and should be stored in a database for use in all subsequent api requests that require authentication.
Making authenticated requests
When instantiating the Etsy object, include the oauth_token and oauth_token_secret along with the consumer_key and consumer_secret:
>>> from etsy import Etsy >>> e = Etsy(consumer_key, consumer_secret, oauth_token, oauth_token_secret)
Now you have access to all authentication only methods, as well as the magic __SELF__ identifier:
>>> e.get_user_info('__SELF__') {u'count': 1, u'pagination': {}, u'params': {u'user_id': u'__SELF__'}, u'results': [{u'creation_tsz': 1344140248, u'feedback_info': {u'count': 0, u'score': None}, u'login_name': u'priestc', u'primary_email': u'nbvfour@gmail.com', u'referred_by_user_id': None, u'user_id': 14888663}], u'type': u'User'}
Notice the addition of the primary_email field, this is because this user authenticated with the app using the ‘email_r’ permission.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file python-etsy-0.1.2.tar.gz
.
File metadata
- Download URL: python-etsy-0.1.2.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67cc86ef234d2ce28cdea8cf5ad80d7d0346ee0d0a6d8dfee2db17658efd523c |
|
MD5 | e383d3667e20062f486fdace4790a53c |
|
BLAKE2b-256 | c27248ab587f57ed4a0ec561879a7506ce3e346d12f47fd698644146cb1f5dce |
File details
Details for the file python-etsy-0.1.2.macosx-10.7-intel.exe
.
File metadata
- Download URL: python-etsy-0.1.2.macosx-10.7-intel.exe
- Upload date:
- Size: 71.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cdb01e23271c82d9d8d9d9f30b33ea588fd482ee012654411eada17dc11d03cd |
|
MD5 | e8fd46eb9099df26b694449cd1b50b1a |
|
BLAKE2b-256 | ca0ff61f5398b9bdfad862054130cd74772363e79a74ba85775631a7123975a3 |