Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/heedrox/abbreviame
Get an abbreviated description made by an AI of you based on your latest tweets. What do other users perceive from what you tweet?
https://github.com/heedrox/abbreviame
gpt-3 gpt-35-turbo twitter
Last synced: about 1 month ago
JSON representation
Get an abbreviated description made by an AI of you based on your latest tweets. What do other users perceive from what you tweet?
- Host: GitHub
- URL: https://github.com/heedrox/abbreviame
- Owner: heedrox
- License: mit
- Created: 2023-03-12T14:47:36.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-05-14T14:32:16.000Z (over 1 year ago)
- Last Synced: 2024-02-15T15:31:44.261Z (11 months ago)
- Topics: gpt-3, gpt-35-turbo, twitter
- Language: JavaScript
- Homepage: https://abbrevia.me
- Size: 223 KB
- Stars: 152
- Watchers: 2
- Forks: 21
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
Originally: A proof of concept to know if an AI can answer any question about any user reading all their timeline.
At the end: Get an abbreviated description made by an AI of you based on your latest tweets. What do other users perceive from what you tweet?
# What you can do with this
You can do several things, like:
- Replicate original abbrevia.me service.
- Pivot original abbrevia.me for other use cases, e.g. a service for corporates.
- Use it for other questions. Actually, the code was prepared to accept other questions, beyond the original one.
It was never used in production, but you can send an "anotherQuestion" parameter in your query :scream:
Be creative! For example, you can say: "Specify 10 keywords that match this user."Some limits you must be aware of:
- Twitter apps have a rate limit. Check what does this mean for your use case.
- OpenAI has a max quota of 120 $. If you expect to spend more, fill the form you will find in their site soon.# Installation & local execution
If you have any question or you find a bug, please, let me know. If you want to contribute, go ahead and do it.
If you want to do something similar with that code, DM me for help; especially if you belong to an
underrepresented group in technology. I might not answer, but if I have time, I am willing to help.You can adapt this code to use any database or server. In my case, I use firebase,
so this is a guide to make it work in firebase.- Create a firebase project in https://console.firebase.google.com
- Add it as default in your project:
```shell
firebase use --add
```- Inside functions folder
```shell
cd functions
```- Copy .env-example file to .env
```shell
cp .env-example .env
```- Edit ".env" file and add your own API keys (from twitter and openAI)
- Use node 16. I usually use NVM in order to use different node versions.
```shell
nvm use
```- Install dependencies
```shell
npm install
```- Change the ROLE_SYSTEM and the prompt, in following files:
- functions/app/gpt/query-gpt-chat.js (ROLE_SYSTEM_INSTRUCTIONS variable)
- functions/app/prompt.js (PROMPTS variable)- In your root folder again
```shell
cd ..
```- Add a "service-account.json" for firebase database connection.
- Run an emulator
```shell
firebase emulators:start
```The rest of this, I leave it to you!
# License
MIT License. Read [LICENSE.md](LICENSE.md)
It is not mandatory to notify me if you use this code, but it would be great to know that you use it.
# Recognition & Contribution
Thanks [@dianait_](https://twitter.com/dianait_) for the abbreviame logo.