R1D4 Buffer API

| programming | python |

For Day 4 I started working with the Buffer API for OldPosts since ultimately I want the script to run once a day and add posts to my buffer.

The docs are great, and getting started with the API was straightforward. Luckily, they provide you with an access token so that you do not have to do an Oauth dance if you are making a “single user application”.

I used Postman to explore the Buffer API since its dead simple to make requests, and inspect results.

I used two API calls to make this happen. First I get a list of all profile ID’s that are connected to my buffer and use a “fancy” list comprehension to extract just the ID values.

def get_buffer_profiles():
    """
    Return list of all connected profile ID's in Buffer Account
    """
    profiles = requests.get("https://api.bufferapp.com/1/profiles.json?access_token={0}".format(os.environ['BUFFER_TOKEN']))
return [s['id'] for s in profiles.json()]

Next I pass in the text that I want to post for the update, create the update via the API, and move it to the top of the queue.
def create_buffer_update(update):
payload = {
    'profile_ids[]': get_buffer_profiles(),
    'text': update,
    'top': 'True'
}

response = requests.post("<a class="vglnk" href="https://api.bufferapp.com/1/updates/create.json?access_token={0}%22.format(os.environ[%27BUFFER_TOKEN%27])" rel="nofollow">https://api.bufferapp.com/1/updates/create.json?access_token={0}".format(os.environ['BUFFER_TOKEN'])</a>, data=payload)

return response.json()

It worked on the first try. I see posts added to the top of my buffer. Buffer Posts

Last step is to set up a CloudWatch event to kick off this Lambda job once a day. :)

Thank you for reading! Share your thoughts with me on bluesky, mastodon, or via email.

Check out some more stuff to read down below.

Most popular posts this month

Recent Favorite Blog Posts

This is a collection of the last 8 posts that I bookmarked.

Articles from blogs I follow around the net

MusicBrainz Picard identifies songs from *.mp3 files and automatically fixes metadata

In my first attempt to switch from streaming to move back to listening to *.mp3 files, one of the issues I encountered was organization: how to standardize the metadata of the songs? The solution I was familiar with at the time — manually editing each son…

via Manual do Usuário April 24, 2025

Google's control of the web could be coming to an end

It's been hard to avoid the US government's antitrust case against Meta lately, since CEO Mark Zuckerberg spent three days in front of the cameras in Congress, testifying about his company's alleged anti-competitive tactics. But another equall…

via The Torment Nexus April 24, 2025

$5 million in tokens stolen from ZKsync

An attacker compromised an admin account belonging to the ZKsync Ethereum layer-2 project, which is built by Matter Labs. By doing so, they were able to steal approximately $5 million worth of the ZK token, which the project said wer…

via Web3 is Going Just Great April 24, 2025

Generated by openring