Compare commits
No commits in common. "e0450de6d9649db52848cf0fabb68787786287eb" and "7f269901c540b17ce4ece9fa3f6d6acaa725e612" have entirely different histories.
e0450de6d9
...
7f269901c5
@ -137,8 +137,6 @@ add_executable(redmine-cli
|
|||||||
src/Redmine-CLI/Command/IssueStatus.cpp
|
src/Redmine-CLI/Command/IssueStatus.cpp
|
||||||
src/Redmine-CLI/Command/Issue.hpp
|
src/Redmine-CLI/Command/Issue.hpp
|
||||||
src/Redmine-CLI/Command/Issue.cpp
|
src/Redmine-CLI/Command/Issue.cpp
|
||||||
src/Redmine-CLI/Command/Upload.hpp
|
|
||||||
src/Redmine-CLI/Command/Upload.cpp
|
|
||||||
)
|
)
|
||||||
target_link_libraries(redmine-cli redmine-api-cpp-static loguru CLI11 tableprinter::tableprinter)
|
target_link_libraries(redmine-cli redmine-api-cpp-static loguru CLI11 tableprinter::tableprinter)
|
||||||
target_include_directories(redmine-cli
|
target_include_directories(redmine-cli
|
||||||
|
@ -60,7 +60,15 @@ namespace Redmine
|
|||||||
void post(const std::string &path, const nlohmann::json &data) const;
|
void post(const std::string &path, const nlohmann::json &data) const;
|
||||||
void processGenericErrors_(httplib::Result &res) const;
|
void processGenericErrors_(httplib::Result &res) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief upload a file to the redmine server
|
||||||
|
*
|
||||||
|
* @param file - the file to upload
|
||||||
|
* @param filename - the filename used inside redmine
|
||||||
|
* @return std::string - the redmine internal token (reference) for the uploaded file
|
||||||
|
*/
|
||||||
|
std::string upload_(const std::filesystem::path &file, const std::string &filename) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -132,15 +140,6 @@ namespace Redmine
|
|||||||
* @return std::vector<Redmine::Issue>
|
* @return std::vector<Redmine::Issue>
|
||||||
*/
|
*/
|
||||||
std::vector<Redmine::Issue> getIssues(const Redmine::Filter& filter = {}) const;
|
std::vector<Redmine::Issue> getIssues(const Redmine::Filter& filter = {}) const;
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief upload a file to the redmine server
|
|
||||||
*
|
|
||||||
* @param file - the file to upload
|
|
||||||
* @param filename - the filename used inside redmine
|
|
||||||
* @return std::string - the redmine internal token (reference) for the uploaded file
|
|
||||||
*/
|
|
||||||
std::string upload(const std::filesystem::path &file, const std::string &filename) const;
|
|
||||||
|
|
||||||
|
|
||||||
/*@}*/
|
/*@}*/
|
||||||
|
@ -1,45 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2024 Dominik Meyer
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU 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 General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <Redmine-CLI/Command/Upload.hpp>
|
|
||||||
#include <Redmine-CLI/Redmine.hpp>
|
|
||||||
#include "Redmine/API.hpp"
|
|
||||||
#include <string>
|
|
||||||
#include <tableprinter/tableprinter.hpp>
|
|
||||||
|
|
||||||
Command::Upload::Upload(RedmineCLI::Redmine *r)
|
|
||||||
:
|
|
||||||
redmine_(r),
|
|
||||||
output_(TEXT)
|
|
||||||
{
|
|
||||||
|
|
||||||
upload_ = redmine_->getCLI().add_subcommand("upload", "raw file upload");
|
|
||||||
upload_->add_option("-f,--file", filePath_, "the file to upload")->required();
|
|
||||||
upload_->add_option("-n,--name", fileName_, "the filename within redmine")->required();
|
|
||||||
upload_->callback([&](){uploadFile_();});
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Command::Upload::uploadFile_() const
|
|
||||||
{
|
|
||||||
Redmine::API client{redmine_->getUrl(), redmine_->getToken()};
|
|
||||||
|
|
||||||
std::string token = client.upload(filePath_, fileName_);
|
|
||||||
|
|
||||||
std::cout << token << std::endl;
|
|
||||||
}
|
|
||||||
|
|
@ -1,80 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
/*
|
|
||||||
* Copyright (C) 2024 Dominik Meyer
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU 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 General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
#include <CLI/App.hpp>
|
|
||||||
#include <Redmine/API.hpp>
|
|
||||||
#include <cstdint>
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#define LOGURU_WITH_STREAMS 1
|
|
||||||
#include <loguru.hpp>
|
|
||||||
#include <CLI/CLI.hpp>
|
|
||||||
|
|
||||||
|
|
||||||
// forward declaration
|
|
||||||
namespace RedmineCLI
|
|
||||||
{
|
|
||||||
class Redmine;
|
|
||||||
};
|
|
||||||
|
|
||||||
namespace Command
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief class for processing the CLI11 parsed command lines
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
class Upload
|
|
||||||
{
|
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
/// the main redmine cli application context
|
|
||||||
RedmineCLI::Redmine *redmine_;
|
|
||||||
|
|
||||||
/// enum for identifying supported output types
|
|
||||||
enum outputType : std::uint16_t
|
|
||||||
{
|
|
||||||
/// output is just text
|
|
||||||
TEXT,
|
|
||||||
/// output is json
|
|
||||||
JSON
|
|
||||||
};
|
|
||||||
|
|
||||||
/// requested output type
|
|
||||||
outputType output_;
|
|
||||||
|
|
||||||
std::map<std::string, outputType> outputMap{{"text", TEXT}, {"json", JSON}};
|
|
||||||
|
|
||||||
/// the file path for uploading files
|
|
||||||
std::string filePath_;
|
|
||||||
|
|
||||||
/// the filename for uploading files
|
|
||||||
std::string fileName_;
|
|
||||||
|
|
||||||
CLI::App* upload_;
|
|
||||||
|
|
||||||
void uploadFile_() const;
|
|
||||||
public:
|
|
||||||
/**
|
|
||||||
* @brief Construct a new CLIProcessor object
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
explicit Upload(RedmineCLI::Redmine *r);
|
|
||||||
|
|
||||||
}; // class Upload
|
|
||||||
}; // namespace Command
|
|
@ -41,5 +41,4 @@ version_(nullptr)
|
|||||||
project_ = std::make_unique<Command::Project>(this);
|
project_ = std::make_unique<Command::Project>(this);
|
||||||
issueStatus_ = std::make_unique<Command::IssueStatus>(this);
|
issueStatus_ = std::make_unique<Command::IssueStatus>(this);
|
||||||
issue_ = std::make_unique<Command::Issue>(this);
|
issue_ = std::make_unique<Command::Issue>(this);
|
||||||
upload_ = std::make_unique<Command::Upload>(this);
|
|
||||||
}
|
}
|
@ -19,7 +19,6 @@
|
|||||||
#include "Redmine-CLI/Command/IssueStatus.hpp"
|
#include "Redmine-CLI/Command/IssueStatus.hpp"
|
||||||
#include "Redmine-CLI/Command/MyAccount.hpp"
|
#include "Redmine-CLI/Command/MyAccount.hpp"
|
||||||
#include "Redmine-CLI/Command/Project.hpp"
|
#include "Redmine-CLI/Command/Project.hpp"
|
||||||
#include "Redmine-CLI/Command/Upload.hpp"
|
|
||||||
#include "Redmine-CLI/Command/Version.hpp"
|
#include "Redmine-CLI/Command/Version.hpp"
|
||||||
#include <CLI/App.hpp>
|
#include <CLI/App.hpp>
|
||||||
#include <CLI/Option.hpp>
|
#include <CLI/Option.hpp>
|
||||||
@ -69,9 +68,6 @@ namespace RedmineCLI
|
|||||||
/// pointer to the issue subcommand
|
/// pointer to the issue subcommand
|
||||||
std::unique_ptr<Command::Issue> issue_;
|
std::unique_ptr<Command::Issue> issue_;
|
||||||
|
|
||||||
/// pointer to the upload subcommand
|
|
||||||
std::unique_ptr<Command::Upload> upload_;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -145,7 +145,7 @@ void Redmine::API::put(const std::string &path, const nlohmann::json &data) con
|
|||||||
DLOG_S(INFO) << "post successful";
|
DLOG_S(INFO) << "post successful";
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Redmine::API::upload(const std::filesystem::path &file, const std::string &filename) const
|
std::string Redmine::API::upload_(const std::filesystem::path &file, const std::string &filename) const
|
||||||
{
|
{
|
||||||
httplib::Client client{redmineApiURL_};
|
httplib::Client client{redmineApiURL_};
|
||||||
client.set_basic_auth(authToken_, "");
|
client.set_basic_auth(authToken_, "");
|
||||||
@ -234,7 +234,7 @@ bool Redmine::API::ready() const
|
|||||||
void Redmine::API::uploadFileToProject(const std::uint64_t projectId, const std::string &filePath, const std::string &fileName, const std::string &description, const std::uint32_t version) const
|
void Redmine::API::uploadFileToProject(const std::uint64_t projectId, const std::string &filePath, const std::string &fileName, const std::string &description, const std::uint32_t version) const
|
||||||
{
|
{
|
||||||
|
|
||||||
std::string token = upload(filePath, fileName);
|
std::string token = upload_(filePath, fileName);
|
||||||
|
|
||||||
nlohmann::json file;
|
nlohmann::json file;
|
||||||
file["token"] = token;
|
file["token"] = token;
|
||||||
|
Loading…
Reference in New Issue
Block a user