1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
/* ============================================================
*
* This file is a part of kipi-plugins project
* http://www.kipi-plugins.org
*
* Date : 2010-02-04
* Description : a tool to export images to imgur.com
*
* Copyright (C) 2010-2012 by Marius Orcsik <marius at habarnam dot ro>
*
* 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 2, 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.
*
* ============================================================ */
#ifndef IMGURTALKER_COMMON_H
#define IMGURTALKER_COMMON_H
// API key from imgur
#define _IMGUR_API_ANONYMOUS_KEY "2da1cc4923f33dc72885aa32adede5c3";
#ifdef OAUTH_ENABLED
#define _IMGUR_API_CONSUMER_KEY "9ad9d48124b7137d9cc9e0397219f52004fcba12a";
#define _IMGUR_API_CONSUMER_SECRET "26b83f19f6d045006d769869b9c623e0";
#endif //OAUTH_ENABLED
// Qt includes
#include <QDateTime>
#include <QString>
// KDE includes
#include <kurl.h>
namespace KIPIImgurExportPlugin
{
class ImgurConnection
{
public:
static QString APIuploadURL() {return QString ("https://api.imgur.com/2/upload.json");}
static QString APIdeleteURL() {return QString ("https://api.imgur.com/2/delete.json");}
static QString OAuthTokenEndPoint() {return QString ("https://api.imgur.com/oauth/request_token");}
static QString OAuthAccessEndPoint() {return QString ("https://api.imgur.com/oauth/access_token");}
static QString OAuthAuthorizationEndPoint() {return QString ("https://api.imgur.com/oauth/authorize");}
static KUrl originalURL(QString imageHash) { return KUrl ("http://i.imgur.com/" + imageHash + ".jpg"); } // this is wrong
static KUrl pageURL(QString imageHash) { return KUrl ("http://imgur.com/" + imageHash);}
static KUrl deleteURL(QString deleteHash) { return KUrl ("http://imgur.com/delete/" + deleteHash);}
};
/*
QString ImgurConnection::uploadURL = QString ("https://api.imgur.com/2/upload.json");
QString ImgurConnection::deleteURL = QString ("https://api.imgur.com/2/delete.json");
QString ImgurConnection::OAuthTokenEndPoint = QString ("https://api.imgur.com/oauth/request_token");
QString ImgurConnection::OAuthAccessEndPoint = QString ("https://api.imgur.com/oauth/access_token");
QString ImgurConnection::OAuthAuthorizationEndPoint = QString ("https://api.imgur.com/oauth/authorize");
*/
struct ImgurError
{
enum ImgurMethod
{
POST = 0,
GET,
HEAD
} method;
enum ImgurFormat
{
XML = 0,
JSON
} format;
QString message;
QString request;
QVariant parameters;
};
// -----------------------------------------------------------------------------
struct ImgurUploadData
{
QString title;
QString caption;
KUrl fileUrl;
};
// -----------------------------------------------------------------------------
struct ImgurSuccess
{
struct ImgurImage
{
QString name;
QString title;
QString caption;
QString hash;
QString deletehash;
QDateTime datetime;
QString type; // maybe enum
bool animated;
uint width;
uint height;
uint size;
uint views;
qulonglong bandwidth;
} image;
struct ImgurLinks
{
KUrl original;
KUrl imgur_page;
KUrl delete_page;
KUrl small_square;
KUrl large_thumbnail;
} links;
};
} // namespace KIPIImgurExportPlugin
#endif // IMGURTALKER_COMMON_H
|