Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Imgur upload functionality #311

Open
wants to merge 53 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
0c4eeb4
Add libsoup and json-glib pkgs
gort818 Apr 13, 2018
d962cf3
Update CMakeLists.txt
gort818 Apr 13, 2018
c5ba2fb
Add new files to cmake
gort818 Apr 29, 2018
ea6c9a9
Add ui for share dialog
gort818 Apr 29, 2018
1328aa4
Add code for share dialog window
gort818 Apr 29, 2018
83fd79b
Add share dialog instance
gort818 Apr 29, 2018
1deb39c
Add share dialog ui to resources
gort818 Apr 29, 2018
9465011
Rename share dialog file
gort818 Apr 29, 2018
ea3ee1c
Change required gtk version to 3.14
gort818 May 1, 2018
87128ee
Destroy file chooser dialog after confirming save location
gort818 May 1, 2018
62d5030
Add error handling, code formatting
gort818 May 1, 2018
6e0bba7
Small ui changes
gort818 May 1, 2018
59625f4
Add preprocesser for gtk 3.22
gort818 May 2, 2018
d5b1bf7
Pass file extention to share dialog
gort818 May 2, 2018
c6768e5
Check for file format
gort818 May 2, 2018
853d91d
Wrong file
gort818 May 2, 2018
9495360
wrong file
gort818 May 2, 2018
e9576c6
Check for file format
gort818 May 2, 2018
5e96ae5
Check for file format
gort818 May 2, 2018
686d640
add debug message.
gort818 May 2, 2018
465e5ce
Change positon of share dialog window
gort818 May 2, 2018
dd0fee9
Close the share dialog after uploading image.
gort818 May 2, 2018
97c3253
Fix selection boxes
gort818 May 4, 2018
d07328f
Imgur upload and share Dialog changes
gort818 Jul 20, 2018
f790dfd
Add libsoup and json-glib pkgs
gort818 Apr 13, 2018
0eaa85c
Update CMakeLists.txt
gort818 Apr 13, 2018
37bbc01
Add new files to cmake
gort818 Apr 29, 2018
c738a54
Add ui for share dialog
gort818 Apr 29, 2018
f888bca
Add code for share dialog window
gort818 Apr 29, 2018
81ce285
Add share dialog instance
gort818 Apr 29, 2018
74fd725
Add share dialog ui to resources
gort818 Apr 29, 2018
c1d169b
Rename share dialog file
gort818 Apr 29, 2018
3cbbd4e
Change required gtk version to 3.14
gort818 May 1, 2018
625701b
Destroy file chooser dialog after confirming save location
gort818 May 1, 2018
e3db2c5
Add error handling, code formatting
gort818 May 1, 2018
5a63323
Small ui changes
gort818 May 1, 2018
f9bf8d2
Add preprocesser for gtk 3.22
gort818 May 2, 2018
2da5d2f
Pass file extention to share dialog
gort818 May 2, 2018
bedf997
Check for file format
gort818 May 2, 2018
979fb47
Wrong file
gort818 May 2, 2018
d650a43
wrong file
gort818 May 2, 2018
4aa0242
Check for file format
gort818 May 2, 2018
0e0fd6b
Check for file format
gort818 May 2, 2018
a5ecf1d
add debug message.
gort818 May 2, 2018
f2771e3
Change positon of share dialog window
gort818 May 2, 2018
abfc727
Close the share dialog after uploading image.
gort818 May 2, 2018
4265d33
Fix selection boxes
gort818 May 4, 2018
da7f7f5
Imgur upload and share Dialog changes
gort818 Jul 20, 2018
fb49937
Merge branch 'imgur' of https://github.com/gort818/peek into imgur
gort818 Sep 22, 2018
e5c43b7
Add dependencies to meson build system
gort818 Sep 22, 2018
aacdc10
Added whitelist for supported upload formats
gort818 Oct 25, 2018
22908f9
Merge https://github.com/phw/peek into imgur
gort818 Sep 7, 2019
ef0480e
fix merge conflicts
gort818 Sep 7, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 10 additions & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -61,12 +61,17 @@ pkg_check_modules(GIO REQUIRED gio-2.0>=2.42)
pkg_check_modules(GLIB2 REQUIRED glib-2.0>=2.38)
pkg_check_modules(GMODULE REQUIRED gmodule-2.0)
pkg_check_modules(KEYBINDER keybinder-3.0)
pkg_check_modules(LIBSOUP libsoup-2.4)
pkg_check_modules(JSON_GLIB json-glib-1.0)

add_definitions(${GTK_CFLAGS} ${GTK_CFLAGS_OTHER})
link_libraries(${GTK_LIBRARIES})
link_libraries(${KEYBINDER_LIBRARIES})
link_directories(${GTK_LIBRARY_DIRS})

include_directories(${LIBSOUP_INCLUDE_DIRS})
include_directories(${JSON_GLIB_INCLUDE_DIRS})
link_libraries(${LIBSOUP_LDFLAGS})
link_libraries(${JSON_GLIB_LDFLAGS})
# compile glib resource files to c code
configure_file (
"${PROJECT_SOURCE_DIR}/ui/about.ui.in"
Expand Down Expand Up @@ -160,9 +165,12 @@ vala_precompile(VALA_C
src/ui/error-dialog.vala
src/ui/preferences-dialog.vala
src/ui/shortcut-label.vala
src/ui/share-dialog.vala
PACKAGES
gtk+-3.0
posix
libsoup-2.4
json-glib-1.0
DEFINITIONS
${VALA_DEFINITIONS}
CUSTOM_VAPIS
Expand Down Expand Up @@ -226,3 +234,4 @@ set(CPACK_DEBIAN_PACKAGE_ARCHITECTURE "amd64")
set(CPACK_DEBIAN_PACKAGE_SECTION "video")

include(CPack)

14 changes: 14 additions & 0 deletions src/ui/application-window.vala
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ namespace Peek.Ui {
public string default_file_name_format { get; set; }

public string save_folder { get; set; }
// public string get_file {get; set;}

[GtkChild]
private HeaderBar headerbar;
Expand Down Expand Up @@ -193,6 +194,10 @@ namespace Peek.Ui {
this.set_close_button_position ();
}

public string get_file(){
return out_file.get_uri();
}


public void hide_headerbar () {
this.get_style_context ().add_class ("headerbar-hidden");
Expand Down Expand Up @@ -708,6 +713,8 @@ namespace Peek.Ui {
// Close the FileChooserDialog:
chooser.close ();
#endif

chooser.destroy();
}

private void try_save_file () {
Expand Down Expand Up @@ -749,6 +756,13 @@ namespace Peek.Ui {

private void handle_saved_file (File file) {
save_preferred_save_folder (file);
string out_file=get_file();
string out_file_ext = Utils.get_file_extension_for_format (
recorder.config.output_format);
ShareDialog.get_file_ext(out_file_ext);
ShareDialog.filename(out_file);
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would probably be easier and more flexible to pass the File object to the ShareDialog instead of just the URI. Also use File.get_path() instead of file.get_uri(), see my comment below.

ShareDialog.present_single_instance(this);


#if ! DISABLE_OPEN_FILE_MANAGER
if (this.visible && open_file_manager) {
Expand Down
123 changes: 123 additions & 0 deletions src/ui/share-dialog.vala
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@

using Gtk;
using Soup;

namespace Peek.Ui {

[GtkTemplate (ui = "/com/uploadedlobster/peek/share-dialog.ui")]
class ShareDialog : Window {
private static Gtk.Window? instance;

public static Gtk.Window present_single_instance (Gtk.Window main_window) {
if (instance == null) {
instance = new ShareDialog ();
instance.delete_event.connect ((event) => {
instance = null;
main_window.set_keep_above (true);
return false;
});
}

instance.transient_for = main_window;
main_window.set_keep_above (false);
instance.present ();
return instance;
}

public static string file { get; set; }
public static string file_type { get; set; }

public static void filename (string out_file) {
file=out_file;
}

public static void get_file_ext (string file_ext) {
file_type=file_ext;
}

[GtkChild]
private Gtk.Image check_1;

[GtkChild]
private Gtk.Image check_2;

[GtkChild]
private Gtk.ListBox options_list;

[GtkChild]
private Gtk.ListBoxRow row_1;

[GtkChild]
private Gtk.ListBoxRow row_2;

[GtkCallback]
private void on_options_list_row_selected () {
var selection = options_list.get_selected_row ();
if(file_type == "webm" || file_type == "mp4"){
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it is better to completely hide the row if it's not available for other formats. It was not completely clear to me why the Imgur option was not selectable. Also it might be better to whitelist formats, since this avoids breaking things if new formats are added to Peek.

row_1.set_selectable(false);
check_2.show();
check_1.hide();
options_list.select_row(row_2);
debug("WebM and Mp4 files are not supported with in imgur upload api");
}else {
row_1.set_selectable(true);
check_1.show();
if (selection == row_1) {
check_2.hide();
}else if (selection == row_2 ){
check_2.show();
check_1.hide();
}
}


}
[GtkCallback]
private void on_confirm_option_clicked() {
if (options_list.get_selected_row () == row_1) {
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Better to give the rows descriptive names, e.g. "imgur_row". Both here in the code and in the .ui file.

Also I would put the entire Imgur specific code into a separate function like do_imgur_upload(), same for the open in file manager option. This will leave only the if ... else if selectoin in this callback, making the code easier to read and easier to extend with additional options. Later we can probably refactor it to put the different handlers (imgur upload, open in file manager etc.) into separate classes with a common interface.

string image_uri = file;
string image=image_uri.replace("%20"," ");
debug(image);
uint8[] data;

try {
GLib.FileUtils.get_data(image.split("://")[1], out data);
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you use File.get_path() instead of File.get_uri() you can avoid this string manipulation. Also the %20 replacement above and likely some other url encoded things that could sneak into the URI part.

} catch (GLib.FileError e) {
warning(e.message);
}

string image_test =GLib.Base64.encode(data);
var mpart = new Multipart(FORM_MIME_TYPE_MULTIPART);
var session = new Soup.Session ();
mpart.append_form_string("image", image_test);
var message = Soup.Form.request_new_from_multipart("https://api.imgur.com/3/image",mpart);
message.request_headers.append("Authorization", "Client-ID bfb3ac58837a0d0");
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would put the client ID into a constant IMGUR_CLIENT_ID

session.send_message(message);
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider using Soup.Session.queue_message for asynchroneously sending the message and not block here. You will need to put the rest of this function into the callback.

var response = (string) message.response_body.data;
debug(response);
try {
var parser = new Json.Parser ();
parser.load_from_data (response, -1);
var root_object = parser.get_root ().get_object ();
string link = root_object.get_object_member ("data")
.get_string_member ("link");
debug(link);
#if HAS_GTK_SHOW_URI_ON_WINDOW
Gtk.show_uri_on_window(instance, link, Gdk.CURRENT_TIME);
#else
Gtk.show_uri(null, link, Gdk.CURRENT_TIME);
#endif


this.close();
}catch(Error e) {
error("%s", e.message);
}
}
}
[GtkCallback]
private void on_sharing_cancel_clicked() {
this.close ();
}
}
}
2 changes: 2 additions & 0 deletions ui/peek.gresource.xml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
<file preprocess="xml-stripblanks">preferences.ui</file>
<file preprocess="xml-stripblanks">about.ui</file>
<file preprocess="xml-stripblanks">gtk/menus.ui</file>
<file preprocess="xml-stripblanks">share-dialog.ui</file>


<!-- Stylesheets -->
<file>css/peek.css</file>
Expand Down
153 changes: 153 additions & 0 deletions ui/share-dialog.ui
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
<?xml version="1.0" encoding="UTF-8"?>
<!-- Generated with glade 3.22.1 -->
<interface>
<requires lib="gtk+" version="3.14"/>
<template class="PeekUiShareDialog" parent="GtkWindow">
<property name="can_focus">False</property>
<property name="border_width">0</property>
<property name="modal">True</property>
<property name="window_position">center-on-parent</property>
<property name="gravity">center</property>
<child type="titlebar">
<object class="GtkHeaderBar" id="headerbar1">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="hexpand">True</property>
<property name="spacing">4</property>
<child type="title">
<object class="GtkLabel">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="label" translatable="yes">Peek Sharing</property>
</object>
</child>
<child>
<object class="GtkButton" id="confirm_option">
<property name="label" translatable="yes">OK</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="hexpand">False</property>
<signal name="clicked" handler="on_confirm_option_clicked" swapped="no"/>
</object>
<packing>
<property name="pack_type">end</property>
</packing>
</child>
<child>
<object class="GtkButton" id="sharing_cancel">
<property name="label">gtk-cancel</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="use_stock">True</property>
<signal name="clicked" handler="on_sharing_cancel_clicked" swapped="no"/>
</object>
<packing>
<property name="pack_type">end</property>
<property name="position">1</property>
</packing>
</child>
</object>
</child>
<child>
<object class="GtkListBox" id="options_list">
<property name="width_request">500</property>
<property name="height_request">100</property>
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="margin_left">6</property>
<property name="margin_right">6</property>
<property name="margin_top">6</property>
<property name="margin_bottom">6</property>
<signal name="row-selected" handler="on_options_list_row_selected" swapped="no"/>
<child>
<object class="GtkListBoxRow" id="row_1">
<property name="width_request">100</property>
<property name="height_request">80</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="activatable">False</property>
<child>
<object class="GtkBox">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="border_width">5</property>
<child>
<object class="GtkLabel">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="label" translatable="yes">&lt;b&gt;Upload to Imgur&lt;/b&gt;
&lt;span size='small'&gt;Upload to imgur for easy sharing&lt;/span&gt;</property>
<property name="use_markup">True</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">0</property>
</packing>
</child>
<child>
<object class="GtkImage" id="check_1">
<property name="can_focus">False</property>
<property name="halign">end</property>
<property name="hexpand">True</property>
<property name="icon_name">object-select-symbolic</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
</child>
</object>
</child>
<child>
<object class="GtkListBoxRow" id="row_2">
<property name="width_request">100</property>
<property name="height_request">80</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="activatable">False</property>
<child>
<object class="GtkBox">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="border_width">5</property>
<child>
<object class="GtkLabel">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="label" translatable="yes">&lt;b&gt;Open in File Manger&lt;/b&gt;
&lt;span size='small'&gt;Open the saved file in your file manager.&lt;/span&gt;</property>
<property name="use_markup">True</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">0</property>
</packing>
</child>
<child>
<object class="GtkImage" id="check_2">
<property name="can_focus">False</property>
<property name="halign">end</property>
<property name="hexpand">True</property>
<property name="icon_name">object-select-symbolic</property>
</object>
<packing>
<property name="expand">False</property>
<property name="fill">True</property>
<property name="position">1</property>
</packing>
</child>
</object>
</child>
</object>
</child>
</object>
</child>
</template>
</interface>