aboutsummaryrefslogtreecommitdiff
path: root/plugins/http-files/src/upload_stream_module.vala
diff options
context:
space:
mode:
authorfiaxh <git@mx.ax.lt>2017-10-16 00:23:51 +0200
committerfiaxh <git@mx.ax.lt>2017-10-22 18:26:31 +0200
commit9ea16b6d8568cb383eb1f469d1dc54bfcad4f188 (patch)
tree27da8705fc99f2407af5e60083e34ddeeff39630 /plugins/http-files/src/upload_stream_module.vala
parent8b43df8ec3f92477f857280668a9f29f0b9d6229 (diff)
downloaddino-9ea16b6d8568cb383eb1f469d1dc54bfcad4f188.tar.gz
dino-9ea16b6d8568cb383eb1f469d1dc54bfcad4f188.zip
PGP encrypted file transfers
Diffstat (limited to 'plugins/http-files/src/upload_stream_module.vala')
-rw-r--r--plugins/http-files/src/upload_stream_module.vala17
1 files changed, 10 insertions, 7 deletions
diff --git a/plugins/http-files/src/upload_stream_module.vala b/plugins/http-files/src/upload_stream_module.vala
index c4fa3d2f..ee70e49d 100644
--- a/plugins/http-files/src/upload_stream_module.vala
+++ b/plugins/http-files/src/upload_stream_module.vala
@@ -14,16 +14,19 @@ public class UploadStreamModule : XmppStreamModule {
public delegate void OnUploadOk(XmppStream stream, string url_down);
public delegate void OnError(XmppStream stream, string error);
- public void upload(XmppStream stream, string file_uri, owned OnUploadOk listener, owned OnError error_listener) {
- File file = File.new_for_path(file_uri);
- FileInfo file_info = file.query_info("*", FileQueryInfoFlags.NONE);
- request_slot(stream, file.get_basename(), (int)file_info.get_size(), file_info.get_content_type(),
+ public void upload(XmppStream stream, InputStream input_stream, string file_name, int file_size, string file_content_type, owned OnUploadOk listener, owned OnError error_listener) {
+ request_slot(stream, file_name, file_size, file_content_type,
(stream, url_down, url_up) => {
- uint8[] data;
- FileUtils.get_data(file_uri, out data);
+ uint8[] buf = new uint8[256];
+ Array<uint8> data = new Array<uint8>(false, true, 0);
+ size_t len = -1;
+ do {
+ len = input_stream.read(buf);
+ data.append_vals(buf, (uint) len);
+ } while(len > 0);
Soup.Message message = new Soup.Message("PUT", url_up);
- message.set_request(file_info.get_content_type(), Soup.MemoryUse.COPY, data);
+ message.set_request(file_content_type, Soup.MemoryUse.COPY, data.data);
Soup.Session session = new Soup.Session();
session.send_async.begin(message, null, (obj, res) => {
try {