add unsupportedMediaTypeException
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
#include <cocoatweet/api/media/upload.h>
|
#include <cocoatweet/api/media/upload.h>
|
||||||
#include <cocoatweet/api/model/mediaStore.h>
|
#include <cocoatweet/api/model/mediaStore.h>
|
||||||
|
#include <cocoatweet/exception/unsupportedMediaTypeException.h>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
@@ -21,6 +22,12 @@ void Upload::mediaId(const std::string& _mediaId) {}
|
|||||||
|
|
||||||
CocoaTweet::API::Model::MediaStore Upload::process(
|
CocoaTweet::API::Model::MediaStore Upload::process(
|
||||||
std::weak_ptr<CocoaTweet::OAuth::OAuth1> _oauth) {
|
std::weak_ptr<CocoaTweet::OAuth::OAuth1> _oauth) {
|
||||||
|
auto extension = std::filesystem::path(media_).extension().string<char>();
|
||||||
|
if (mimeType.count(extension) == 0) {
|
||||||
|
throw new CocoaTweet::Exception::UnsupportedMediaTypeException(
|
||||||
|
std::string("media type \"" + extension + "\" is not supported media type"));
|
||||||
|
}
|
||||||
|
|
||||||
auto backup = bodyParam_;
|
auto backup = bodyParam_;
|
||||||
CocoaTweet::API::Model::MediaStore media;
|
CocoaTweet::API::Model::MediaStore media;
|
||||||
std::ifstream ifs(media_, std::ios::binary);
|
std::ifstream ifs(media_, std::ios::binary);
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
#include <cocoatweet/api/model/mediaStore.h>
|
#include <cocoatweet/api/model/mediaStore.h>
|
||||||
#include <cocoatweet/exception/tweetNotFoundException.h>
|
#include <cocoatweet/exception/exception.h>
|
||||||
#include <cocoatweet/exception/authenticateException.h>
|
|
||||||
#include <cocoatweet/exception/tweetDuplicateException.h>
|
|
||||||
#include <cocoatweet/exception/tweetTooLongException.h>
|
|
||||||
#include <cocoatweet/exception/rateLimitException.h>
|
|
||||||
#include "nlohmann/json.hpp"
|
#include "nlohmann/json.hpp"
|
||||||
|
|
||||||
namespace CocoaTweet::API::Model {
|
namespace CocoaTweet::API::Model {
|
||||||
@@ -31,6 +27,7 @@ MediaStore MediaStore::parse(const unsigned int _responseCode, const std::string
|
|||||||
media.remain(j["processing_info"]["check_after_secs"].get<unsigned int>());
|
media.remain(j["processing_info"]["check_after_secs"].get<unsigned int>());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
throw new CocoaTweet::Exception::Exception(j["error"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return media;
|
return media;
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ namespace CocoaTweet::Exception {
|
|||||||
class Exception : public std::exception {
|
class Exception : public std::exception {
|
||||||
public:
|
public:
|
||||||
Exception(const char* _msg) : msg_(std::string(_msg)) {}
|
Exception(const char* _msg) : msg_(std::string(_msg)) {}
|
||||||
|
Exception(const std::string& _msg) : msg_(std::string(_msg)) {}
|
||||||
const std::string& what() {
|
const std::string& what() {
|
||||||
return msg_;
|
return msg_;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,12 @@
|
|||||||
|
#ifndef COCOATWEET_EXCEPTION_UNSUPPORTEDMEDIATYPEEXCEPTION_H_
|
||||||
|
#define COCOATWEET_EXCEPTION_UNSUPPORTEDMEDIATYPEEXCEPTION_H_
|
||||||
|
|
||||||
|
#include <cocoatweet/exception/exception.h>
|
||||||
|
|
||||||
|
namespace CocoaTweet::Exception {
|
||||||
|
class UnsupportedMediaTypeException final : Exception {
|
||||||
|
using Exception::Exception;
|
||||||
|
};
|
||||||
|
} // namespace CocoaTweet::Exception
|
||||||
|
|
||||||
|
#endif
|
||||||
Reference in New Issue
Block a user