Compare commits
No commits in common. "master" and "async-post-fix" have entirely different histories.
master
...
async-post
@ -1,27 +1,6 @@
|
||||
cmake_minimum_required(VERSION 3.5)
|
||||
project(mmcs-quotes-bridge LANGUAGES CXX)
|
||||
|
||||
option(BUILD_SHARED_LIBS "Build shared libraries by default" NO)
|
||||
if(CMAKE_COMPILER_IS_GNUCXX)
|
||||
set(CMAKE_EXE_LINKER_FLAGS "-static-libgcc -static-libstdc++")
|
||||
endif()
|
||||
|
||||
set(CURL_DISABLE_AWS ON)
|
||||
set(CURL_DISABLE_DICT ON)
|
||||
set(CURL_DISABLE_FILE ON)
|
||||
set(CURL_DISABLE_FTP ON)
|
||||
set(CURL_DISABLE_GOPHER ON)
|
||||
set(CURL_DISABLE_IMAP ON)
|
||||
set(CURL_DISABLE_LDAP ON)
|
||||
set(CURL_DISABLE_LDAPS ON)
|
||||
set(CURL_DISABLE_MQTT ON)
|
||||
set(CURL_DISABLE_NTLM ON)
|
||||
set(CURL_DISABLE_POP3 ON)
|
||||
set(CURL_DISABLE_RTSP ON)
|
||||
set(CURL_DISABLE_SMB ON)
|
||||
set(CURL_DISABLE_TFTP ON)
|
||||
set(CURL_DISABLE_WEBSOCKETS ON)
|
||||
|
||||
add_subdirectory(curl)
|
||||
add_subdirectory(json)
|
||||
add_subdirectory(libuv)
|
||||
@ -30,6 +9,6 @@ add_subdirectory(td)
|
||||
|
||||
add_executable(${PROJECT_NAME} main.cpp config.cpp http.cpp manager.cpp posts.cpp state.cpp tg.cpp vk.cpp)
|
||||
|
||||
target_compile_options(${PROJECT_NAME} PRIVATE -std=c++2a)
|
||||
target_compile_options(${PROJECT_NAME} PRIVATE -std=c++2b)
|
||||
|
||||
target_link_libraries(${PROJECT_NAME} PRIVATE CURL::libcurl nlohmann_json::nlohmann_json uv_a spdlog::spdlog Td::TdStatic $<$<BOOL:${MINGW}>:ws2_32>)
|
||||
target_link_libraries(${PROJECT_NAME} PRIVATE CURL::libcurl nlohmann_json::nlohmann_json uv spdlog::spdlog Td::TdStatic $<$<BOOL:${MINGW}>:ws2_32>)
|
||||
|
23
README.md
23
README.md
@ -1,23 +0,0 @@
|
||||
# MMCS Quotes Bridge
|
||||
> Текущее название является рабочим вариантом, имеет мало общего с сутью проекта, все совпадения аббревиатур с реальными случайны и не несут никакой смысловой нагрузки.
|
||||
>
|
||||
> *P.S. кто знает тот знает короче :DDD*
|
||||
|
||||
Этот проект - реализация бота, предназначенного для репоста текстовых постов из источников в VK и Telegram в один выходной Telegram-канал. Изначальная цель - репостить цитаты из разных цитатников в один канал, но в принципе вы можете придумать своё применение.
|
||||
|
||||
## Платформа
|
||||
**Операционная система.** Предполагается работа на Linux, но теоретически можно заставить бота работать и на других системах.
|
||||
|
||||
**Компилятор.** Проект написан на C++20 и соответственно требует более-менее современный компилятор.
|
||||
|
||||
## Зависимости
|
||||
Большая часть необходимых библиотек присутствует в репозитории, однако для того, чтобы скачать их вместе с проектом, при клонировании требуется указать --recursive.
|
||||
CMakeLists настроен на максимально портативный билд, однако всё же не все библиотеки встраиваются в исполняемый файл.
|
||||
Для работы бота достаточно установленной библиотеки curl.
|
||||
Для сборки (помимо CMake) нужны следующие дополнительные пакеты:
|
||||
- gperf
|
||||
- заголовочные файлы для OpenSSL, zlib
|
||||
По вопросам сборки можно писать в issues.
|
||||
|
||||
## Конфигурация
|
||||
Для настройки используется файл `bridge_config.json`. В качестве примера настройки оставлен `bridge_config.example.json`, который нужно отредактировать под себя.
|
@ -1,11 +0,0 @@
|
||||
{
|
||||
"vk_service_key": "service_key_service_key_service_key_service_key_service_key_service_key",
|
||||
|
||||
"tg_api_id": 1234567,
|
||||
"tg_api_hash": "53a513d108f2c7d9edc67dadd3ce4185",
|
||||
"tg_phone_number": "+79528125252",
|
||||
|
||||
"vk_sources": [{"id": "source1"}, {"id":123451234, "link": "source2"}],
|
||||
"tg_sources": [{"id": -1002282282280, "link": "tgsource"}],
|
||||
"tg_destination_id": -1005252525252
|
||||
}
|
@ -470,8 +470,7 @@ bool RepostManager::drop_posts_older_than(std::vector<AbstractPost> &posts, long
|
||||
}
|
||||
|
||||
std::optional<AbstractPost> RepostManager::to_abstract_post(const vk::Post &post, int sourceIndex) {
|
||||
if (post.text.empty()) return {};
|
||||
else return { AbstractPost(posts::SRC_VK, sourceIndex, post.id, post.date, post.text) };
|
||||
return { AbstractPost(posts::SRC_VK, sourceIndex, post.id, post.date, post.text) };
|
||||
}
|
||||
|
||||
std::optional<AbstractPost> RepostManager::to_abstract_post(const td_api::message &post, int sourceIndex) {
|
||||
@ -487,7 +486,6 @@ std::vector<AbstractPost> RepostManager::to_abstract_posts(std::vector<vk::Post>
|
||||
std::vector<AbstractPost> result;
|
||||
result.reserve(posts.size());
|
||||
for (auto &post : posts) {
|
||||
if (post.text.empty()) continue;
|
||||
result.emplace_back(posts::SRC_VK, sourceIndex, post.id, post.date, post.text);
|
||||
}
|
||||
return result;
|
||||
@ -557,10 +555,6 @@ bool RepostManager::recheck_vk_posts(std::function<void()> onDone) {
|
||||
}
|
||||
|
||||
void RepostManager::repost(AbstractPost &post) {
|
||||
if (post.text.length() == 0) {
|
||||
spdlog::error("repost(): zero post length (post id {} date {})", post.id, post.date);
|
||||
return;
|
||||
}
|
||||
spdlog::debug("reposting (post length {})", post.text.length());
|
||||
std::string_view signature = posts::add_signature(post, m_appConfig);
|
||||
int signatureStart = post.text.length() - signature.length();
|
||||
|
Loading…
Reference in New Issue
Block a user