| Age | Commit message (Collapse) | Author | 
|---|
|  | This commit updates all usages of Network::ErrorResponse to specify at
least method name if not precise reason why operation failed. | 
|  |  | 
|  | Added prefixes, used debug(9). | 
|  |  | 
|  | We need a way to reopen DumpFile if we want DownloadRequest to support
restarting. | 
|  | I knew there were some, but I wanted to fix them once, instead of doing
it all the time. | 
|  | Nothing really major. | 
|  | Now NetworkReadStream, which is used in DownloadRequest, which is used
in FolderDownloadRequest, returns progress information provided by
libcurl. | 
|  | It now uses a dynamically allocated 1 MB buffer. | 
|  |  | 
|  |  | 
|  | Id should be used everywhere. | 
|  | Added ErrorResponse and ErrorCallback. Each Request now has an
ErrorCallback, which should be called instead of usual callback in case
of failure. | 
|  |  | 
|  | ConnectionManager now storages Request * (not generates ids for it),
Requests have control on their RequestState, RequestIdPair is now called
Response and storages Request * with some response together.
All related classes are changed to use it in more clean and
understandable way.
Request, RequestState and Response are carefully commented/documented. | 
|  | Well, it takes two API calls instead of one now, but there are no
problems with expired token because of it.
This commit changes Storage::streamFile() to pass NetworkReadStream *
through callback. | 
|  | With new ConnectionManager upgrade Requests indicate that they are
finished with RequestInfo.state. No need to use handle() return value
anymore. | 
|  | Can be used with Callback<T> (means it's still type safe). It's used to
pass not only Request id to user's callback, but also a value user
wanted.
void *data field is removed from RequestInfo. | 
|  | ConnectionManager upgrade: it now contains a special struct for each
request, so you can access request status and data by request id. | 
|  | Knows how to OAuth already.
This commit also adds CloudManager::addStorage(), so OneDriveStorage can
add newly created Storage and CloudManager can save it in the
configuration file. | 
|  | Tested with .jpg file. Transfer complete, CRC-32 is the same. | 
|  | It reads the passed NetworkReadStream and prints its contents onto
console (for now). It would be writing contents into file.
To simplify work with raw NetworkReadStream there is a new CurlRequest.
It basically does nothing, but as ConnMan handles transfers only if
there is an active Request, you need some Request to get
NetworkReadStream working. Thus, there is a CurlRequest, which is active
until NetworkReadStream is completely read. CurlRequest also has useful
addHeader() and addPostField() methods in order to customize the request
easily. Use execute() method to get its NetworkReadStream.
DropboxStorage implements streamFile() and download() API methods. As
DownloadRequest is incomplete, it is not actually downloading a file,
though. |