/* * Treebird - Lightweight frontend for Pleroma * Copyright (C) 2022 Nekobit * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ #ifndef STATUS_H #define STATUS_H #include #include #include "l10n.h" #include "path.h" #include "session.h" #include "global_perl.h" // Flags #define STATUS_NOOP 0 #define STATUS_REPLY (1<<0) #define STATUS_FOCUSED (1<<1) #define STATUS_EMOJI_PICKER (1<<2) #define STATUS_NO_LIKEBOOST (1<<3) #define STATUS_NO_DOPAMEME (1<<4) #define STATUS_NO_QUICKREPLY (1<<5) struct construct_statuses_args { char* highlight_word; }; struct interact_profile_args { struct mstdnt_account* reblogs; struct mstdnt_account* favourites; size_t reblogs_len; size_t favourites_len; }; int try_post_status(struct session* ssn, mastodont_t* api); int try_interact_status(struct session* ssn, mastodont_t* api, char* id); void content_status_create(PATH_ARGS); void content_status_react(PATH_ARGS); // HTML Builders // Reply to /** Deprecated: May be used in the future for Mastodon only */ char* get_in_reply_to(mastodont_t* api, struct session* ssn, struct mstdnt_status* status, size_t* size); void status_view_reblogs(PATH_ARGS); void status_view_favourites(PATH_ARGS); void content_status_interactions(FCGX_Request* req, struct session* ssn, mastodont_t* api, char* label, struct mstdnt_account* accts, size_t accts_len); // Status frontends void status_view(PATH_ARGS); void status_reply(PATH_ARGS); void status_interact(PATH_ARGS); void status_emoji(PATH_ARGS); // Above wraps to the below function void content_status(PATH_ARGS, uint8_t flags); // Cleanup void cleanup_media_ids(struct session* ssn, char** media_ids); // Redirects void notice_redirect(PATH_ARGS); // API void api_status_interact(PATH_ARGS); // Perl HV* perlify_status_pleroma(const struct mstdnt_status_pleroma* pleroma); HV* perlify_status(const struct mstdnt_status* status); AV* perlify_statuses(const struct mstdnt_status* statuses, size_t len); #endif // STATUS_H