2018-03-07 17:17:26 +01:00
|
|
|
**mastodon-cpp** is a C++ wrapper for the Mastodon API.
|
2018-04-03 00:52:23 +02:00
|
|
|
The library takes care of the network stuff. You submit a query and get the raw
|
|
|
|
JSON. You can then put that JSON into easy to use classes.
|
2018-01-06 21:33:52 +01:00
|
|
|
|
2018-06-04 21:06:05 +02:00
|
|
|
[TODO-list](https://schlomp.space/tastytea/mastodon-cpp/milestones)
|
2018-03-18 14:02:53 +01:00
|
|
|
|
2018-10-09 23:43:44 +02:00
|
|
|
**The ABI will be unstable in versions < 1.0.0**
|
|
|
|
|
2019-01-27 04:23:49 +01:00
|
|
|
**Beginning with 0.30.0, all IDs are `const string` instead of
|
|
|
|
`uint_fast64_t` as required by the Mastodon API. Sorry for the inconvenience.**
|
|
|
|
|
2019-02-22 08:07:55 +01:00
|
|
|
# Breaking API changes
|
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
I'm currently rewriting key parts of this library. The new API will be
|
|
|
|
incompatible with the old one. The new code will start with the version number
|
|
|
|
`0.100.0`. The old code is archived in the branch `pre-0.100.0` and will get
|
|
|
|
bugfixes for a while.
|
2019-02-22 08:07:55 +01:00
|
|
|
|
2019-02-22 08:34:37 +01:00
|
|
|
**The code on the `master`-branch is not usable at the moment, stick to the
|
|
|
|
releases, please.**
|
|
|
|
|
2018-03-18 01:43:09 +01:00
|
|
|
# Usage
|
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
The HTML reference can be generated with `build_doc.sh`, if doxygen is
|
|
|
|
installed. It is also available at [doc.schlomp.space/mastodon-cpp/](https://doc.schlomp.space/mastodon-cpp/annotated.html).
|
|
|
|
There are [examples](https://schlomp.space/tastytea/mastodon-cpp/src/branch/master/examples)
|
|
|
|
in `examples/`.
|
2018-03-18 01:43:09 +01:00
|
|
|
|
|
|
|
## Most basic example
|
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
```c++
|
2018-03-18 01:43:09 +01:00
|
|
|
#include <iostream>
|
2018-03-21 17:08:33 +01:00
|
|
|
#include <mastodon-cpp/mastodon-cpp.hpp>
|
2018-03-18 01:43:09 +01:00
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
Mastodon::API masto("social.example.com", "auth_token");
|
2019-03-03 11:22:11 +01:00
|
|
|
std::cout << masto.get(Mastodon::API::v1::accounts_verify_credentials);
|
|
|
|
std::cout << std::endl;
|
2018-03-18 01:43:09 +01:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2018-04-01 05:03:35 +02:00
|
|
|
## Another simple example
|
|
|
|
|
2018-04-02 01:47:44 +02:00
|
|
|
Using the `Easy`-class.
|
2018-04-01 05:03:35 +02:00
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
```c++
|
2018-04-01 05:03:35 +02:00
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
|
|
|
#include <mastodon-cpp/mastodon-cpp.hpp>
|
|
|
|
#include <mastodon-cpp/easy/all.hpp>
|
|
|
|
|
|
|
|
using Mastodon::Easy;
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
Easy masto("social.example", "");
|
2019-03-03 11:22:11 +01:00
|
|
|
return_call ret = masto.get(Mastodon::API::v1::timelines_public);
|
2018-04-01 05:03:35 +02:00
|
|
|
|
2019-03-03 11:22:11 +01:00
|
|
|
for (const std::string &str : Easy::json_array_to_vector(ret.answer))
|
2018-04-01 05:03:35 +02:00
|
|
|
{
|
|
|
|
Easy::Status status(str);
|
|
|
|
std::cout << " " << status.account().acct() << " wrote:\n";
|
|
|
|
std::cout << status.content() << '\n';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2018-03-18 01:43:09 +01:00
|
|
|
## Compiling your project
|
|
|
|
|
2018-03-26 01:14:59 +02:00
|
|
|
A project consisting of one file can be compiled as follows:
|
2018-03-18 01:43:09 +01:00
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
``` shellsession
|
2018-06-08 00:44:11 +02:00
|
|
|
g++ -std=c++14 -lmastodon-cpp example.cpp
|
|
|
|
```
|
2018-03-18 01:43:09 +01:00
|
|
|
|
|
|
|
## Error codes
|
|
|
|
|
2019-02-22 12:14:15 +01:00
|
|
|
| Code | Explanation |
|
|
|
|
| --------: |:-------------------------------------------|
|
|
|
|
| 0 | No error |
|
|
|
|
| 22 | Invalid argument |
|
|
|
|
| 78 | URL changed (HTTP 301 or 308) |
|
|
|
|
| 110 | Connection timed out |
|
|
|
|
| 111 | Connection refused (check http_error_code) |
|
2019-02-28 15:47:25 +01:00
|
|
|
| 192 | curlpp runtime error |
|
|
|
|
| 193 | curlpp logic error |
|
2019-02-22 12:14:15 +01:00
|
|
|
| 255 | Unknown error |
|
2018-04-10 10:44:46 +02:00
|
|
|
|
2018-08-15 07:36:49 +02:00
|
|
|
If you use a debug build, you get more verbose error messages.
|
2018-03-18 01:43:09 +01:00
|
|
|
|
|
|
|
## Useful links
|
|
|
|
|
2018-12-04 12:27:35 +01:00
|
|
|
* [Mastodon documentation](https://docs.joinmastodon.org/)
|
2018-03-18 01:43:09 +01:00
|
|
|
|
2018-01-06 21:33:52 +01:00
|
|
|
# Install
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
## Packages
|
|
|
|
|
2018-06-07 23:01:27 +02:00
|
|
|
Every [release](https://schlomp.space/tastytea/mastodon-cpp/releases) includes
|
2018-10-08 18:36:13 +02:00
|
|
|
packages for the package managers of Debian and Red Hat. Gentoo packages are
|
|
|
|
available in an overlay.
|
2018-03-18 01:32:54 +01:00
|
|
|
|
|
|
|
### Gentoo
|
|
|
|
|
2018-06-20 11:05:49 +02:00
|
|
|
Add my [repository](https://schlomp.space/tastytea/overlay) and
|
2018-05-08 07:51:50 +02:00
|
|
|
install it from there.
|
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
```shellsession
|
2018-06-20 11:05:49 +02:00
|
|
|
eselect repository enable tastytea
|
2018-06-07 23:11:08 +02:00
|
|
|
echo 'dev-cpp/mastodon-cpp ~amd64' >> /etc/portage/package.keywords/mastodon-cpp
|
|
|
|
emaint sync -r tastytea
|
|
|
|
emerge -a dev-cpp/mastodon-cpp
|
|
|
|
```
|
2018-05-08 07:51:50 +02:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
### DEB and RPM
|
|
|
|
|
|
|
|
Prebuilt DEB and RPM packages for x86_64(amd64) are provided with each release.
|
2019-04-08 21:24:08 +02:00
|
|
|
`.deb` packages are built on Debian stretch and `.rpm` packages are built on
|
|
|
|
CentOS 7. These packages are automatically built and not tested. Install with
|
|
|
|
`dpkg -i` or `rpm -i`, respectively.
|
2018-03-18 01:32:54 +01:00
|
|
|
|
2019-04-08 21:24:08 +02:00
|
|
|
To use the DEB package on Debian stretch, you will need
|
|
|
|
[libcurlpp0](https://packages.debian.org/libcurlpp0) from sid.
|
2018-03-18 01:32:54 +01:00
|
|
|
|
|
|
|
## From source
|
|
|
|
|
|
|
|
### Dependencies
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2018-03-26 01:14:59 +02:00
|
|
|
* Tested OS: Linux
|
2019-03-03 11:34:09 +01:00
|
|
|
* C++ compiler (tested: gcc 6 / 7 / 8)
|
2018-10-08 22:41:28 +02:00
|
|
|
* [cmake](https://cmake.org/) (tested: 3.9 / 3.12)
|
2018-06-13 05:25:13 +02:00
|
|
|
* [pkgconfig](https://pkgconfig.freedesktop.org/wiki/) (tested: 0.29)
|
2018-08-15 07:36:49 +02:00
|
|
|
* [curlpp](http://www.curlpp.org/) (tested: 0.8)
|
2018-03-08 11:07:41 +01:00
|
|
|
* Optional
|
2018-06-13 05:25:13 +02:00
|
|
|
* Easy interface & Examples: [jsoncpp](https://github.com/open-source-parsers/jsoncpp) (tested: 1.8 / 1.7)
|
|
|
|
* Documentation: [doxygen](https://www.stack.nl/~dimitri/doxygen/) (tested: 1.8)
|
2018-10-08 22:41:28 +02:00
|
|
|
* DEB package: [dpkg](https://packages.qa.debian.org/dpkg) (tested: 1.19 / 1.18)
|
|
|
|
* RPM package: [rpm](http://www.rpm.org) (tested: 4.14 / 4.12)
|
2018-01-06 21:33:52 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
### Get sourcecode
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
#### Release
|
2018-01-13 21:12:07 +01:00
|
|
|
|
2018-06-07 23:01:27 +02:00
|
|
|
Download the current release at [schlomp.space](https://schlomp.space/tastytea/mastodon-cpp/releases).
|
2018-01-13 21:12:07 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
#### Development version
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
```shellsession
|
2018-06-07 23:23:39 +02:00
|
|
|
git clone https://schlomp.space/tastytea/mastodon-cpp.git
|
|
|
|
```
|
2018-01-06 21:33:52 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
### Compile
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
```shellsession
|
2018-06-07 23:11:08 +02:00
|
|
|
mkdir build
|
|
|
|
cd build/
|
|
|
|
cmake ..
|
|
|
|
make
|
|
|
|
```
|
2018-01-06 21:33:52 +01:00
|
|
|
|
2018-01-13 21:12:07 +01:00
|
|
|
cmake options:
|
|
|
|
|
|
|
|
* `-DCMAKE_BUILD_TYPE=Debug` for a debug build
|
2019-04-04 12:47:40 +02:00
|
|
|
* `-DWITH_EASY=NO` to not build the Easy abstractions and to get rid of the jsoncpp-dependency (not recommended)
|
|
|
|
* `-DWITH_EXAMPLES=YES` if you want to compile the examples
|
|
|
|
* `-DWITH_TESTS=YES` if you want to compile the tests
|
2019-04-04 12:58:49 +02:00
|
|
|
* `-DWITH_DOC=NO` if you don't want to compile the HTML reference
|
2019-03-03 12:28:14 +01:00
|
|
|
* One of:
|
2019-04-04 12:47:40 +02:00
|
|
|
* `-DWITH_DEB=YES` if you want to be able to generate a deb-package
|
|
|
|
* `-DWITH_RPM=YES` if you want to be able to generate an rpm-package
|
2018-01-13 21:12:07 +01:00
|
|
|
|
|
|
|
You can run the tests with `ctest ..` inside the build directory.
|
2018-03-26 01:14:59 +02:00
|
|
|
To install, run `make install`.
|
2018-03-08 11:07:41 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
### Packages
|
2018-03-08 11:07:41 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
#### DEB and RPM
|
2018-03-08 11:07:41 +01:00
|
|
|
|
|
|
|
Compile with `-DWITH_DEB=ON` or `-DWITH_RPM=ON`.
|
|
|
|
Run `make package` from the build directory to generate a DEB/RPM package.
|
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
#### Other
|
2018-03-08 11:07:41 +01:00
|
|
|
|
2018-03-18 01:32:54 +01:00
|
|
|
Run `make package` from the build directory to generate a tar.gz archive.
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2018-03-08 11:07:41 +01:00
|
|
|
# Status of implementation
|
2018-01-13 15:49:46 +01:00
|
|
|
|
2019-03-03 10:29:43 +01:00
|
|
|
~~Feature complete as of Mastodon 2.6.1~~
|
2018-03-05 12:12:58 +01:00
|
|
|
|
2018-01-09 22:12:11 +01:00
|
|
|
* [x] GET /api/v1/accounts/:id
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] POST /api/v1/accounts
|
2018-01-09 22:12:11 +01:00
|
|
|
* [x] GET /api/v1/accounts/verify_credentials
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] PATCH /api/v1/accounts/update_credentials
|
2018-01-09 22:12:11 +01:00
|
|
|
* [x] GET /api/v1/accounts/:id/followers
|
|
|
|
* [x] GET /api/v1/accounts/:id/following
|
|
|
|
* [x] GET /api/v1/accounts/:id/statuses
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/accounts/:id/follow
|
|
|
|
* [x] POST /api/v1/accounts/:id/unfollow
|
2018-01-09 22:12:11 +01:00
|
|
|
* [x] GET /api/v1/accounts/relationships
|
|
|
|
* [x] GET /api/v1/accounts/search
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/apps
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/apps/verify_credentials
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/blocks
|
2019-03-03 10:29:43 +01:00
|
|
|
* [x] POST /api/v1/accounts/:id/block
|
|
|
|
* [x] POST /api/v1/accounts/:id/unblock
|
|
|
|
* [x] GET /api/v1/custom_emojis
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/domain_blocks
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/domain_blocks
|
2018-01-24 18:52:24 +01:00
|
|
|
* [x] DELETE /api/v1/domain_blocks
|
2018-11-17 21:05:07 +01:00
|
|
|
* [x] GET /api/v1/endorsements
|
|
|
|
* [x] POST /api/v1/accounts/:id/pin
|
|
|
|
* [x] POST /api/v1/accounts/:id/unpin
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/favourites
|
2019-03-03 10:29:43 +01:00
|
|
|
* [x] POST /api/v1/statuses/:id/favourite
|
|
|
|
* [x] POST /api/v1/statuses/:id/unfavourite
|
|
|
|
* [ ] GET /api/v1/filters
|
|
|
|
* [ ] POST /api/v1/filters
|
|
|
|
* [ ] GET /api/v1/filters/:id
|
|
|
|
* [ ] DELETE /api/v1/filters/:id
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/follow_requests
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/follow_requests/:id/authorize
|
|
|
|
* [x] POST /api/v1/follow_requests/:id/reject
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/suggestions
|
|
|
|
* [ ] DELETE /api/v1/suggestions/:account_id
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/instance
|
|
|
|
* [x] GET /api/v1/lists
|
|
|
|
* [x] GET /api/v1/accounts/:id/lists
|
|
|
|
* [x] GET /api/v1/lists/:id/accounts
|
|
|
|
* [x] GET /api/v1/lists/:id
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/lists
|
2018-01-24 18:52:24 +01:00
|
|
|
* [x] PUT /api/v1/lists/:id
|
|
|
|
* [x] DELETE /api/v1/lists/:id
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/lists/:id/accounts
|
2018-01-24 18:52:24 +01:00
|
|
|
* [x] DELETE /api/v1/lists/:id/accounts
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/media
|
2018-04-19 01:27:22 +02:00
|
|
|
* [x] PUT /api/v1/media/:id
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/mutes
|
2019-03-03 10:29:43 +01:00
|
|
|
* [x] POST /api/v1/accounts/:id/mute
|
|
|
|
* [x] POST /api/v1/accounts/:id/unmute
|
|
|
|
* [x] POST /api/v1/statuses/:id/mute
|
|
|
|
* [x] POST /api/v1/statuses/:id/unmute
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/notifications
|
|
|
|
* [x] GET /api/v1/notifications/:id
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/notifications/clear
|
|
|
|
* [x] POST /api/v1/notifications/dismiss
|
2019-03-03 10:29:43 +01:00
|
|
|
* [x] POST /api/v1/push/subscription
|
|
|
|
* [x] GET /api/v1/push/subscription
|
|
|
|
* [x] PUT /api/v1/push/subscription
|
|
|
|
* [x] DELETE /api/v1/push/subscription
|
|
|
|
* [x] ~~GET /api/v1/reports~~ (Deprecated)
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/reports
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/scheduled_statuses
|
|
|
|
* [ ] GET /api/v1/scheduled_statuses/:id
|
|
|
|
* [ ] PUT /api/v1/scheduled_statuses/:id
|
|
|
|
* [ ] DELETE /api/v1/scheduled_statuses/:id
|
|
|
|
* [x] ~~GET /api/v1/search~~ (Deprecated)
|
|
|
|
* [x] GET /api/v2/search
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/statuses/:id
|
|
|
|
* [x] GET /api/v1/statuses/:id/context
|
|
|
|
* [x] GET /api/v1/statuses/:id/card
|
|
|
|
* [x] GET /api/v1/statuses/:id/reblogged_by
|
|
|
|
* [x] GET /api/v1/statuses/:id/favourited_by
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/statuses
|
2018-01-24 18:52:24 +01:00
|
|
|
* [x] DELETE /api/v1/statuses/:id
|
2018-01-22 02:09:44 +01:00
|
|
|
* [x] POST /api/v1/statuses/:id/reblog
|
|
|
|
* [x] POST /api/v1/statuses/:id/unreblog
|
|
|
|
* [x] POST /api/v1/statuses/:id/pin
|
|
|
|
* [x] POST /api/v1/statuses/:id/unpin
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/timelines/home
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/conversations
|
2018-01-12 20:49:15 +01:00
|
|
|
* [x] GET /api/v1/timelines/public
|
|
|
|
* [x] GET /api/v1/timelines/tag/:hashtag
|
|
|
|
* [x] GET /api/v1/timelines/list/:list_id
|
2018-02-26 07:57:30 +01:00
|
|
|
* [x] GET /api/v1/streaming/user
|
|
|
|
* [x] GET /api/v1/streaming/public
|
|
|
|
* [x] GET /api/v1/streaming/public/local
|
|
|
|
* [x] GET /api/v1/streaming/hashtag
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/streaming/hashtag/local
|
2018-02-26 07:57:30 +01:00
|
|
|
* [x] GET /api/v1/streaming/list
|
2019-03-03 10:29:43 +01:00
|
|
|
* [ ] GET /api/v1/streaming/direct
|
2018-02-11 22:41:47 +01:00
|
|
|
|
2018-12-04 10:04:54 +01:00
|
|
|
## Glitch-Soc support
|
|
|
|
|
|
|
|
* [x] max_toot_chars in /api/v1/instance
|
2018-12-04 10:34:51 +01:00
|
|
|
* [x] GET /api/v1/bookmarks
|
|
|
|
* [x] POST /api/v1/statuses/:id/bookmark
|
|
|
|
* [x] POST /api/v1/statuses/:id/unbookmark
|
2018-12-04 10:04:54 +01:00
|
|
|
|
2018-01-06 21:33:52 +01:00
|
|
|
# Copyright
|
2018-01-13 00:34:16 +01:00
|
|
|
|
2019-04-02 11:28:53 +02:00
|
|
|
``` text
|
2019-03-03 10:29:43 +01:00
|
|
|
Copyright © 2018, 2019 tastytea <tastytea@tastytea.de>.
|
2018-06-07 23:11:08 +02:00
|
|
|
License GPLv3: GNU GPL version 3 <https://www.gnu.org/licenses/gpl-3.0.html>.
|
|
|
|
This program comes with ABSOLUTELY NO WARRANTY. This is free software,
|
|
|
|
and you are welcome to redistribute it under certain conditions.
|
|
|
|
```
|