diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/api.cpp | 108 | ||||
-rw-r--r-- | src/curl_wrapper.cpp | 18 |
2 files changed, 92 insertions, 34 deletions
diff --git a/src/api.cpp b/src/api.cpp index 66e963b..e15dd73 100644 --- a/src/api.cpp +++ b/src/api.cpp @@ -150,7 +150,7 @@ const map<API::endpoint_type,string_view> API::_endpoint_map {v1::admin_accounts, "/api/v1/admin/accounts"}, {v1::admin_accounts_id, "/api/v1/admin/accounts/<ID>"}, {v1::admin_accounts_account_id_action, - "/api/v1/admin/accounts/<ACCOUNT_ID>/action"}, + "/api/v1/admin/accounts/<ACCOUNT_ID>/action"}, {v1::admin_accounts_id_approve, "/api/v1/admin/accounts/<ID>/approve"}, {v1::admin_accounts_id_reject, "/api/v1/admin/accounts/<ID>/reject"}, {v1::admin_accounts_id_enable, "/api/v1/admin/accounts/<ID>/enable"}, @@ -159,33 +159,39 @@ const map<API::endpoint_type,string_view> API::_endpoint_map {v1::admin_reports, "/api/v1/admin/reports"}, {v1::admin_reports_id, "/api/v1/admin/reports/<ID>"}, {v1::admin_reports_id_assign_to_self, - "/api/v1/admin/reports/<ID>/assign_to_self"}, + "/api/v1/admin/reports/<ID>/assign_to_self"}, {v1::admin_reports_id_unassign, "/api/v1/admin/reports/<ID>/unassign"}, {v1::admin_reports_id_resolve, "/api/v1/admin/reports/<ID>/resolve"}, {v1::admin_reports_id_reopen, "/api/v1/admin/reports/<ID>/reopen"}, {v1::pleroma_notifications_read, " /api/v1/pleroma/notifications/read"}, - {v1::pleroma_accounts_id_subscribe, - "/api/v1/pleroma/accounts/<ID>/subscribe"}, + "/api/v1/pleroma/accounts/<ID>/subscribe"}, {v1::pleroma_accounts_id_unsubscribe, - "/api/v1/pleroma/accounts/<ID>/unsubscribe"}, + "/api/v1/pleroma/accounts/<ID>/unsubscribe"}, {v1::pleroma_accounts_id_favourites, - "/api/v1/pleroma/accounts/<ID>/favourites"}, + "/api/v1/pleroma/accounts/<ID>/favourites"}, {v1::pleroma_accounts_update_avatar, - "/api/v1/pleroma/accounts/update_avatar"}, + "/api/v1/pleroma/accounts/update_avatar"}, {v1::pleroma_accounts_update_banner, - "/api/v1/pleroma/accounts/update_banner"}, + "/api/v1/pleroma/accounts/update_banner"}, {v1::pleroma_accounts_update_background, - "/api/v1/pleroma/accounts/update_background"}, + "/api/v1/pleroma/accounts/update_background"}, {v1::pleroma_accounts_confirmation_resend, - "/api/v1/pleroma/accounts/confirmation_resend"}, - + "/api/v1/pleroma/accounts/confirmation_resend"}, {v1::pleroma_mascot, "/api/v1/pleroma/mascot"}, - {v1::pleroma_conversations_id_statuses, - "/api/v1/pleroma/conversations/<ID>/statuses"}, + "/api/v1/pleroma/conversations/<ID>/statuses"}, {v1::pleroma_conversations_id, "/api/v1/pleroma/conversations/<ID>"}, + {v1::pleroma_conversations_id_read, + "/api/v1/pleroma/conversations/<ID>/read"}, + {v1::pleroma_accounts_id_scrobbles, + "/api/v1/pleroma/accounts/<ID>/scrobbles"}, + {v1::pleroma_scrobble, "/api/v1/pleroma/scrobble"}, + {v1::pleroma_statuses_id_reactions_emoji, + "/api/v1/pleroma/statuses/<ID>/reactions/<EMOJI>"}, + {v1::pleroma_statuses_id_reactions, + "/api/v1/pleroma/statuses/<ID>/reactions"}, {v2::search, "/api/v2/search"}, @@ -199,49 +205,89 @@ const map<API::endpoint_type,string_view> API::_endpoint_map {pleroma::admin_users, "/api/pleroma/admin/users"}, {pleroma::admin_users_follow, "/api/pleroma/admin/users/follow"}, {pleroma::admin_users_unfollow, "/api/pleroma/admin/users/unfollow"}, - {pleroma::admin_users_nickname, "/api/pleroma/admin/users/<NICKNAME>"}, + {pleroma::admin_users_nickname_toggle_activation, + "/api/pleroma/admin/users/<NICKNAME>/toggle_activation"}, {pleroma::admin_users_tag, "/api/pleroma/admin/users/tag"}, {pleroma::admin_users_nickname_permission_group, - "/api/pleroma/admin/users/<NICKNAME>/permission_group"}, + "/api/pleroma/admin/users/<NICKNAME>/permission_group"}, {pleroma::admin_users_nickname_permission_group_permission_group, - "/api/pleroma/admin/users/<NICKNAME>/permission_group/<PERMISSION_GROUP>"}, - {pleroma::admin_users_nickname_activation_status, - "/api/pleroma/admin/users/<NICKNAME>/activation_status"}, + "/api/pleroma/admin/users/<NICKNAME>" + "/permission_group/<PERMISSION_GROUP>"}, + {pleroma::admin_users_permission_group_permission_group, + "/api/pleroma/admin/users/permission_group/<PERMISSION_GROUP>"}, + {pleroma::admin_users_activate, "/api/pleroma/admin/users/activate"}, + {pleroma::admin_users_deactivate, "/api/pleroma/admin/users/deactivate"}, {pleroma::admin_users_nickname_or_id, - "/api/pleroma/admin/users/<NICKNAME_OR_ID>"}, + "/api/pleroma/admin/users/<NICKNAME_OR_ID>"}, {pleroma::admin_users_nickname_or_id_statuses, - "/api/pleroma/admin/users/<NICKNAME_OR_ID>/statuses"}, + "/api/pleroma/admin/users/<NICKNAME_OR_ID>/statuses"}, + {pleroma::admin_instances_instance_statuses, + "/api/pleroma/admin/instances/<INSTANCE>/statuses"}, + {pleroma::admin_statuses, "/api/pleroma/admin/statuses"}, {pleroma::admin_relay, "/api/pleroma/admin/relay"}, {pleroma::admin_users_invite_token, - "/api/pleroma/admin/users/invite_token"}, + "/api/pleroma/admin/users/invite_token"}, {pleroma::admin_users_invites, "/api/pleroma/admin/users/invites"}, {pleroma::admin_users_revoke_invite, - "/api/pleroma/admin/users/revoke_invite"}, + "/api/pleroma/admin/users/revoke_invite"}, {pleroma::admin_users_email_invite, - "/api/pleroma/admin/users/email_invite"}, + "/api/pleroma/admin/users/email_invite"}, {pleroma::admin_users_nickname_password_reset, - "/api/pleroma/admin/users/<NICKNAME>/password_reset"}, + "/api/pleroma/admin/users/<NICKNAME>/password_reset"}, + {pleroma::admin_users_force_password_reset, + "/api/pleroma/admin/users/force_password_reset"}, {pleroma::admin_reports, "/api/pleroma/admin/reports"}, + {pleroma::admin_grouped_reports, "/api/pleroma/admin/grouped_reports"}, {pleroma::admin_reports_id, "/api/pleroma/admin/reports/<ID>"}, - {pleroma::admin_reports_id_respond, - "/api/pleroma/admin/reports/<ID>/respond"}, + {pleroma::admin_reports_id_notes, "/api/pleroma/admin/reports/<ID>/notes"}, + {pleroma::admin_reports_report_id_notes_id, + "/api/pleroma/admin/reports/<REPORT_ID>/notes/<ID>"}, {pleroma::admin_statuses_id, "/api/pleroma/admin/statuses/<ID>"}, + {pleroma::admin_restart, "/api/pleroma/admin/restart"}, + {pleroma::admin_config, "/api/pleroma/admin/config"}, + {pleroma::admin_config_descriptions, + "/api/pleroma/admin/config/descriptions"}, + {pleroma::admin_moderation_log, "/api/pleroma/admin/moderation_log"}, + {pleroma::admin_reload_emoji, "/api/pleroma/admin/reload_emoji"}, + {pleroma::admin_users_confirm_email, + "/api/pleroma/admin/users/confirm_email"}, + {pleroma::admin_users_resend_confirm_email, + "/api/pleroma/admin/users/resend_confirm_email"}, + {pleroma::admin_stats, "/api/pleroma/admin/stats"}, + + {pleroma::admin_users_nickname, "/api/pleroma/admin/users/<NICKNAME>"}, + {pleroma::admin_users_nickname_activation_status, + "/api/pleroma/admin/users/<NICKNAME>/activation_status"}, + {pleroma::admin_reports_id_respond, + "/api/pleroma/admin/reports/<ID>/respond"}, {pleroma::admin_config_migrate_to_db, - "/api/pleroma/admin/config/migrate_to_db"}, + "/api/pleroma/admin/config/migrate_to_db"}, {pleroma::admin_config_migrate_from_db, - "/api/pleroma/admin/config/migrate_from_db"}, - {pleroma::admin_config, "/api/pleroma/admin/config"}, + "/api/pleroma/admin/config/migrate_from_db"}, {pleroma::emoji, "/api/pleroma/emoji"}, {pleroma::follow_import, "/api/pleroma/follow_import"}, {pleroma::captcha, "/api/pleroma/captcha,"}, {pleroma::delete_account, "/api/pleroma/delete_account"}, {pleroma::disable_account, "/api/pleroma/disable_account"}, - {pleroma::account_register, "/api/pleroma/account/register"}, - {pleroma::notification_settings, "/api/pleroma/notification_settings"}, {pleroma::healthcheck, "/api/pleroma/healthcheck"}, {pleroma::change_email, "/api/pleroma/change_email"}, + {pleroma::emoji_packs, "/api/pleroma/emoji/packs"}, + {pleroma::emoji_packs_name, "/api/pleroma/emoji/packs/<NAME>"}, + {pleroma::emoji_packs_name_update_file, + "/api/pleroma/emoji/packs/<NAME>/update_file"}, + {pleroma::emoji_packs_name_update_metadata, + "/api/pleroma/emoji/packs/<NAME>/update_metadata"}, + {pleroma::emoji_packs_download_from, + "/api/pleroma/emoji/packs/download_from"}, + {pleroma::emoji_packs_list_from, + "/api/pleroma/emoji/packs/list_from"}, + {pleroma::emoji_packs_name_download_shared, + "/api/pleroma/emoji/packs/<NAME>/download_shared"}, + + {pleroma::account_register, "/api/pleroma/account/register"}, + }; } // namespace mastodonpp diff --git a/src/curl_wrapper.cpp b/src/curl_wrapper.cpp index bfa59ee..9341069 100644 --- a/src/curl_wrapper.cpp +++ b/src/curl_wrapper.cpp @@ -22,6 +22,7 @@ #include <algorithm> #include <array> #include <atomic> +#include <cctype> #include <cstdint> namespace mastodonpp @@ -30,8 +31,10 @@ namespace mastodonpp using std::get; using std::holds_alternative; using std::any_of; +using std::transform; using std::array; // NOLINT(misc-unused-using-decls) using std::atomic; +using std::toupper; using std::uint8_t; using std::uint16_t; @@ -355,13 +358,22 @@ bool CURLWrapper::replace_parameter_in_uri(string &uri, { static constexpr array replace { - "id", "nickname", "nickname_or_id", "account_id", - "list_id", "hashtag", "permission_group" + "id", "nickname", "nickname_or_id", "account_id", "list_id", + "hashtag", "permission_group", "instance", "report_id", "name", + "emoji" }; if (any_of(replace.begin(), replace.end(), [¶meter](const auto &s) { return s == parameter.first; })) { - const auto pos{uri.find('<')}; + const string searchstring{[¶meter] + { + string s{"<"}; + s += parameter.first; + transform(s.begin(), s.end(), s.begin(), + [](const unsigned char c){ return toupper(c); }); + return s; + }()}; + const auto pos{uri.find(searchstring)}; if (pos != string::npos) { uri.replace(pos, parameter.first.size() + 2, |