Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tweetback/tweetback
Take ownership of your Twitter data and get your tweets back
https://github.com/tweetback/tweetback
11ty indieweb twitter
Last synced: 3 days ago
JSON representation
Take ownership of your Twitter data and get your tweets back
- Host: GitHub
- URL: https://github.com/tweetback/tweetback
- Owner: tweetback
- License: mit
- Created: 2022-11-02T15:30:41.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-11-13T21:47:41.000Z (about 1 year ago)
- Last Synced: 2025-01-15T12:55:11.357Z (11 days ago)
- Topics: 11ty, indieweb, twitter
- Language: JavaScript
- Homepage:
- Size: 76.2 KB
- Stars: 646
- Watchers: 10
- Forks: 94
- Open Issues: 62
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - tweetback/tweetback - Take ownership of your Twitter data and get your tweets back (twitter)
README
# `tweetback` Twitter Archive
Take ownership of your Twitter data. First talked about at [Jamstack Conf 2019](https://www.zachleat.com/web/own-your-content/) and in [this blog post](https://www.zachleat.com/web/own-my-tweets/).
* _Referenced on [Delete Twitter](https://deletetwitter.com/)!_
## Demos
* https://www.zachleat.com/twitter/
* https://twitter.11ty.dev/## Features
* Built with [Eleventy](https://www.11ty.dev/)
* Each tweet has its own independent URL (with backwards/forwards threading!)
* Uses [`@tweetback/canonical`](https://github.com/tweetback/tweetback-canonical) to resolve other Twitter archives URLs (internal links stay in the archive and don’t link out to Twitter).
* `t.co` links are bypassed and original hyperlinks URLs are used.
* Links to users, tweets, non-truncated URLs.
* Nicer link formatting for links-to-tweets: @username/:id.
* Support some markdown: I sometimes use `backtick` markdown notation for code in my tweet text. This translates to `` properly.
* Analytics:
* See your most popular tweets
* Who you retweet the most
* Who you reply to the most
* Frequently used swear words
* Top emoji
* Top hashtags## Usage
* Clone/download this repository
* In your terminal, `cd` to the folder of the project
* Install [Node.js](https://nodejs.org/)
* Run `npm install`### Populate the database from your Twitter Archive zip
1. Copy `./data/tweets.js` from your [Twitter Archive](https://help.twitter.com/en/managing-your-account/how-to-download-your-twitter-archive) `zip` file into the `./database` directory of this project.
* Rename `window.YTD.tweet.part0` in `tweets.js` to `module.exports`
1. If you want to exclude Twitter Circles tweets (these are included in the archive, why 😭): copy `./data/twitter-circle-tweet.js` from your Twitter Archive `zip` file into the `./database` directory of this project.
* Rename `window.YTD.tweet.part0` in `twitter-circle-tweet.js` to `module.exports`
1. Run `npm run import` or `npm run import-without-circles`### Build the web site
1. Edit the `_data/metadata.js` file to add metadata information.
1. Run `npm run build` (will just create the proper files) or `npm start` (will run a server to look at them in your browser).
* _Optional:_ If you want the web site to live in a subdirectory (e.g. `/twitter/`), use [Eleventy’s Path Prefix feature](https://www.11ty.dev/docs/config/#deploy-to-a-subdirectory-with-a-path-prefix) via the command line `--pathprefix=twitter` or via a return object in your configuration file. Careful: this is an option to Eleventy and not npm, so it needs to live after a `--` separator (for instance, `npm run build -- --pathprefix=twitter`).⚠️ _Warning_: the first build may take quite a long time (depending on the size of your archive), as remote media is fetched/downloaded into your project locally. Repeat builds will be much faster.
### Fetch additional tweets from the API (optional)
If you want to fetch additional tweets from the API and put them into your sqlite database:
1. You will need a twitter developer token an a `TWITTER_BEARER_TOKEN` environment variable (from the Twitter API v2). Read more about [App-only Bearer Tokens](https://developer.twitter.com/en/docs/authentication/oauth-2-0/bearer-tokens).
1. Run `npm run fetch-new-data`### Add your production URL to `@tweetback/canonical` (optional)
https://github.com/tweetback/tweetback-canonical has a `mapping.js` file that stores the existing twitter username => canonical URL mappings. These will be transformed automatically to point to other archives in all `tweetback` instances.
### Publish your archive (optional)
- To [GitHub Pages](docs/deploy-with-github-pages.md)