Skip to main content

A lightweight client for the feedly api (https://developers.feedly.com).

Project description

python-api-client

Python client code for the feedly api https://developers.feedly.com/

Initializing a client

To initialize a client, first you need an access token. To just play around, login to feedly and go to the console. Then find the feedlyToken property. This is your web access token. You can make requests with this token but it will expire. It's not suitable for building an application, but will get you going.

If you're serious about building an app, you probably want to get a developer token. Check the page for more details.

You can run examples/setup_auth.py to get your access token saved into the default config directory, ~/.config/feedly. Then, you can initialize the client as follows:

from feedly.api_client.session import FeedlySession

sess = FeedlySession()

Clients are lightweight -- you can keep a client around for the lifetime of your program, or you can create a new one when needed. It's a bit more efficient to keep it around. If you do choose to create clients as needed, you should pass in the user's ID in the constructor, otherwise you'll incur a /v3/profile request.

Examples

Setup

To run the examples we provide, you'll first need to clone and install the project (preferably in a new virtualenv environment):

git clone https://github.com/feedly/python-api-client.git
cd python-api-client
pip install .

Auth

When running an example, for the first time, you'll be prompted to enter your token. It will be saved in ~/.config/feedly

API Oriented Usage

You can use the FeedlySession object to make arbitrary API requests. E.g.:

sess.do_api_request('/v3/feeds/feed%2Fhttp%3A%2F%2Fblog.feedly.com%2Ffeed%2F')
{
  "id": "feed/http://blog.feedly.com/feed/",
  "feedId": "feed/http://blog.feedly.com/feed/",
  "title": "Feedly Blog",
  ...
}

Object Oriented Usage

Retrieving Streams

Alternatively, you can use the object-oriented code, which facilitates common usage patterns. E.g. you can list your user categories:

sess.user.user_categories.name2stream
{'comics': <UserCategory: user/xxx/category/aaa>,
 'econ': <UserCategory: user/xxx/category/bbb>,
 'global.must': <UserCategory: user/xxx/category/ccc>,
 'politics': <UserCategory: user/xxx/category/ddd>,
}

where xxx is your actual user ID.

It's not necessary to list categories beforehand, if you know the ones that exist, you can get one on the fly, by querying it by id or name:

sess.user.user_categories.get('comics')  # From the category name
sess.user.user_categories.get('aaa')  # From the category id
<UserCategory: user/xxx/category/aaa>

You can access:

  • User feeds with sess.user.user_categories
  • User boards with sess.user.user_tags
  • Team feeds with sess.user.enterprise_categories
  • Team boards with sess.user.enterprise_tags

Accessing Entries (articles)

If you need to access entries or entry IDs, you can use easily stream them via stream_contents and stream_ids, respectively:

with FeedlySession(auth_token=token) as sess:
    for eid in sess.user.user_categories.get('politics').stream_ids():
         print(eid)
Dz51gkBgvGUvFOfTATCYLB2uqVaBIaGGazzxpZh2WL0=_16549c827dd:1645ba:3da9d93
Dz51gkBgvGUvFOfTATCYLB2uqVaBIaGGazzxpZh2WL0=_16549c827dd:1645bb:3da9d93
Z/Hzx8NYfSSE8sweA2v5+4r5h7HC5ALdE2YGYB8MYbQ=_1654a26f3fe:79d9ef9:6f86c10b
...

Take note of the StreamOptions class. There are important max_count and count properties that control streaming. To download all items, something like this could be done:

opts = StreamOptions(max_count=sys.maxsize) # down all items that exist
opts.count = sys.maxsize # download as many items as possible in every API request
with FeedlySession() as sess:
    for eid in sess.user.get_category('politics').stream_ids(opts):
         print(eid)

Tagging Existing Entries

with FeedlySession() as sess:
    sess.user.get_tag('politics').tag_entry(eid)

Odds and Ends

Feedly APIs are rate limited. Do not make multiple requests concurrently. You can download quite a few entries at a time, see the previous section for details. Once you get rate limited, the client will stop any attempted requests until you have available quota.

To debug things, set the log level to DEBUG. This will print log messages on every API request.

Token Management

The above examples assume the auth (access) token is valid. However these tokens do expire. Instead of passing the auth token itself, you can create a feedly.session.Auth implementation to refresh the auth token. A file based implementation is already provided (FileAuthStore). Once this is done the client will automatically try to refresh the auth token if a 401 response is encountered.

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

feedly_client-0.27.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

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

feedly_client-0.27-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file feedly_client-0.27.tar.gz.

File metadata

  • Download URL: feedly_client-0.27.tar.gz
  • Upload date:
  • Size: 18.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for feedly_client-0.27.tar.gz
Algorithm Hash digest
SHA256 32f1e8d10d41de62e469f2cc2e654a33013ff247aac79ff85e0c3ee16e1046df
MD5 1c343aeef9f4d88b87528f7da14d4056
BLAKE2b-256 fea65bae6093cd0fe20c35b25b391e01ee7648ea8fd04e35a8532f90435fb64d

See more details on using hashes here.

Provenance

The following attestation bundles were made for feedly_client-0.27.tar.gz:

Publisher: publish.yml on feedly/python-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file feedly_client-0.27-py3-none-any.whl.

File metadata

  • Download URL: feedly_client-0.27-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for feedly_client-0.27-py3-none-any.whl
Algorithm Hash digest
SHA256 3055fc6216bd460a73464b712e56e708e466d779143ba0b09d858c6595342cbf
MD5 ed7f2360a1f5b5d2cd0f53ec7cc6aadf
BLAKE2b-256 bfb36d604f79d03b83274ed05aa32ec29d48f46a3ba9b2e2dae449fd519dc347

See more details on using hashes here.

Provenance

The following attestation bundles were made for feedly_client-0.27-py3-none-any.whl:

Publisher: publish.yml on feedly/python-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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