* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
+
+using Gee;
using Gtk;
class IdentityDialog : Dialog
{
+ private static Gdk.Color white = make_color(65535, 65535, 65535);
+ private static Gdk.Color selected_color = make_color(0xd9 << 8, 0xf7 << 8, 65535);
+
private static MoonshotLogger logger = get_logger("IdentityDialog");
static const string displayname_labeltext = _("Display Name");
- static const string issuer_labeltext = _("Issuer");
+ static const string realm_labeltext = _("Realm");
static const string username_labeltext = _("Username");
static const string password_labeltext = _("Password");
- private IdentityManagerView parent;
private Entry displayname_entry;
private Label displayname_label;
- private Entry issuer_entry;
- private Label issuer_label;
+ private Entry realm_entry;
+ private Label realm_label;
private Entry username_entry;
private Label username_label;
private Entry password_entry;
private CheckButton remember_checkbutton;
private Label message_label;
public bool complete;
-
+ private IdCard card;
+
+ private Label selected_item = null;
+
+ // Whether to clear the card's TrustAnchor after the user selects OK
+ internal bool clear_trust_anchor = false;
+
public string display_name {
get { return displayname_entry.get_text(); }
}
public string issuer {
- get { return issuer_entry.get_text(); }
+ get { return realm_entry.get_text(); }
}
public string username {
get { return remember_checkbutton.active; }
}
+ internal ArrayList<string> get_services()
+ {
+ return card.services;
+ }
+
public IdentityDialog(IdentityManagerView parent)
{
this.with_idcard(null, _("Add ID Card"), parent);
is_new_card = true;
}
- IdCard card = a_card ?? new IdCard();
+ card = a_card ?? new IdCard();
this.set_title(title);
this.set_modal(true);
this.set_transient_for(parent);
- this.parent = parent;
this.add_buttons(_("OK"), ResponseType.OK, CANCEL, ResponseType.CANCEL);
- var content_area = this.get_content_area();
- ((Box) content_area).set_spacing(12);
-
+ Box content_area = (Box) this.get_content_area();
+
displayname_label = new Label(@"$displayname_labeltext:");
- displayname_label.set_alignment(1,(float) 0.5);
+ displayname_label.set_alignment(0, (float) 0.5);
displayname_entry = new Entry();
displayname_entry.set_text(card.display_name);
+ displayname_entry.set_width_chars(40);
- issuer_label = new Label(@"$issuer_labeltext:");
- issuer_label.set_alignment(1,(float) 0.5);
- this.issuer_entry = new Entry();
- this.issuer_entry.set_text(card.issuer);
+ realm_label = new Label(@"$realm_labeltext:");
+ realm_label.set_alignment(0, (float) 0.5);
+ realm_entry = new Entry();
+ realm_entry.set_text(card.issuer);
+ realm_entry.set_width_chars(60);
username_label = new Label(@"$username_labeltext:");
- username_label.set_alignment(1,(float) 0.5);
- this.username_entry = new Entry();
- this.username_entry.set_text(card.username);
+ username_label.set_alignment(0, (float) 0.5);
+ username_entry = new Entry();
+ username_entry.set_text(card.username);
+ username_entry.set_width_chars(40);
password_label = new Label(@"$password_labeltext:");
- password_label.set_alignment(1,(float) 0.5);
- this.password_entry = new Entry();
+ password_label.set_alignment(0, (float) 0.5);
+
+ remember_checkbutton = new CheckButton.with_label(_("Remember password"));
+ remember_checkbutton.active = card.store_password;
+
+ password_entry = new Entry();
password_entry.set_invisible_char('*');
password_entry.set_visibility(false);
+ password_entry.set_width_chars(40);
password_entry.set_text(card.password);
- this.remember_checkbutton = new CheckButton.with_label(_("Remember password"));
- this.message_label = new Label("");
+ message_label = new Label("");
message_label.set_visible(false);
set_atk_relation(displayname_label, displayname_entry, Atk.RelationType.LABEL_FOR);
- set_atk_relation(issuer_label, issuer_entry, Atk.RelationType.LABEL_FOR);
+ set_atk_relation(realm_label, realm_entry, Atk.RelationType.LABEL_FOR);
set_atk_relation(username_label, username_entry, Atk.RelationType.LABEL_FOR);
- set_atk_relation(password_entry, password_entry, Atk.RelationType.LABEL_FOR);
-
- var table = new Table(6, 2, false);
- table.set_col_spacings(10);
- table.set_row_spacings(10);
-
- table.attach_defaults(message_label, 0, 2, 0, 1);
- table.attach_defaults(displayname_label, 0, 1, 1, 2);
- table.attach_defaults(displayname_entry, 1, 2, 1, 2);
- table.attach_defaults(issuer_label, 0, 1, 2, 3);
- table.attach_defaults(issuer_entry, 1, 2, 2, 3);
- table.attach_defaults(username_label, 0, 1, 3, 4);
- table.attach_defaults(username_entry, 1, 2, 3, 4);
- table.attach_defaults(password_label, 0, 1, 4, 5);
- table.attach_defaults(password_entry, 1, 2, 4, 5);
- table.attach_defaults(remember_checkbutton, 1, 2, 5, 6);
+ set_atk_relation(password_label, password_entry, Atk.RelationType.LABEL_FOR);
+
+ content_area.pack_start(message_label, false, false, 6);
+ add_as_vbox(content_area, displayname_label, displayname_entry);
+ add_as_vbox(content_area, username_label, username_entry);
+ add_as_vbox(content_area, realm_label, realm_entry);
+ add_as_vbox(content_area, password_label, password_entry);
+
+ // var entries = new VBox(false, 6);
+ // add_as_vbox(entries, displayname_label, displayname_entry);
+ // add_as_vbox(entries, realm_label, realm_entry);
+ // add_as_vbox(entries, username_label, username_entry);
+ // add_as_vbox(entries, password_label, password_entry);
+ // content_area.pack_start(entries, false, false, 0);
+
+ var remember_hbox = new HBox(false, 40);
+ remember_hbox.pack_start(new HBox(false, 0), false, false, 0);
+ remember_hbox.pack_start(remember_checkbutton, false, false, 0);
+ content_area.pack_start(remember_hbox, false, false, 2);
+ // content_area.pack_start(remember_checkbutton, false, false, 2);
this.response.connect(on_response);
- var vbox = new VBox(false, 0);
- vbox.set_border_width(6);
- vbox.pack_start(table, false, false, 0);
+ content_area.set_border_width(6);
+ if (!is_new_card)
+ {
+ Widget trust_anchor_box = make_trust_anchor_box(card);
+ content_area.pack_start(trust_anchor_box, false, false, 15);
- var services_vbox_title = new Label(_("Services:"));
- label_make_bold(services_vbox_title);
- services_vbox_title.set_alignment(0, (float) 0.5);
-
- var services_internal_vbox = new VBox(true, 6);
-
- var services_vbox_alignment = new Alignment(0, 0, 0, 1);
- services_vbox_alignment.set_padding(6, 6, 6, 6);
- services_vbox_alignment.add(services_internal_vbox);
- var services_vscroll = new ScrolledWindow(null, null);
- services_vscroll.set_policy(PolicyType.NEVER, PolicyType.AUTOMATIC);
- services_vscroll.set_shadow_type(ShadowType.IN);
- services_vscroll.add_with_viewport(services_vbox_alignment);
-
- var services_vbox = new VBox(false, 6);
- services_vbox.pack_start(services_vbox_title, false, false, 0);
- services_vbox.pack_start(services_vscroll, true, true, 0);
-
+ var services_vbox = make_services_vbox();
+ content_area.pack_start(services_vbox);
+ }
- ((Container) content_area).add(vbox);
+ if (card.is_no_identity())
+ {
+ displayname_entry.set_sensitive(false);
+ realm_entry.set_sensitive(false);
+ username_entry.set_sensitive(false);
+ password_entry.set_sensitive(false);
+ remember_checkbutton.set_sensitive(false);
+ }
this.set_border_width(6);
this.set_resizable(false);
+ this.modify_bg(StateType.NORMAL, white);
this.show_all();
}
+ private Widget make_trust_anchor_box(IdCard id)
+ {
+
+ Label ta_label = new Label(_("Trust anchor: ")
+ + (id.trust_anchor.is_empty() ? _("None") : _("Enterprise provisioned")));
+ ta_label.set_alignment(0, 0.5f);
+
+ if (id.trust_anchor.is_empty()) {
+ return ta_label;
+ }
+
+
+ AttachOptions opts = AttachOptions.EXPAND | AttachOptions.FILL;
+ AttachOptions fill = AttachOptions.FILL;
+
+ Table ta_table = new Table(6, 2, false);
+ int row = 0;
+
+ var ta_clear_button = new Button.with_label(_("Clear Trust Anchor"));
+ ta_clear_button.clicked.connect((w) => {
+ clear_trust_anchor = true;
+ ta_table.set_sensitive(false);
+ }
+ );
+
+ ta_table.attach(ta_label, 0, 1, row, row + 1, opts, opts, 0, 0);
+ ta_table.attach(ta_clear_button, 1, 2, row, row + 1, fill, fill, 0, 0);
+ row++;
+
+ //!!TODO
+ Label added_label = new Label(_("Added on: N/A"));
+ added_label.set_alignment(0, 0.5f);
+ ta_table.attach(added_label, 0, 1, row, row + 1, opts, opts, 20, 5);
+ row++;
+
+ if (id.trust_anchor.get_anchor_type() == TrustAnchor.TrustAnchorType.SERVER_CERT) {
+ Widget fingerprint = make_ta_fingerprint_widget(id.trust_anchor);
+ ta_table.attach(fingerprint, 0, 2, row, row + 2, opts, opts, 20, 5);
+ }
+ else {
+ Label ca_cert_label = new Label(_("CA Certificate:"));
+ ca_cert_label.set_alignment(0, 0.5f);
+ var export_button = new Button.with_label(_("Export Certificate"));
+ //!!TODO!
+ export_button.clicked.connect((w) => {/* !!TODO! */});
+
+ ta_table.attach(ca_cert_label, 0, 1, row, row + 1, opts, opts, 20, 0);
+ ta_table.attach(export_button, 1, 2, row, row + 1, fill, fill, 0, 0);
+ row++;
+
+ //!!TODO: When to show Subject, and when (if ever) show Subject-Altname here?
+ Label subject_label = new Label(_("Subject: ") + id.trust_anchor.subject);
+ subject_label.set_alignment(0, 0.5f);
+ ta_table.attach(subject_label, 0, 1, row, row + 1, opts, opts, 40, 5);
+ row++;
+
+ Label expiration_label = new Label(_("Expiration date: ") + id.trust_anchor.get_expiration_date());
+ expiration_label.set_alignment(0, 0.5f);
+ ta_table.attach(expiration_label, 0, 1, row, row + 1, opts, opts, 40, 5);
+ row++;
+
+ //!!TODO: What *is* this?
+ Label constraint_label = new Label(_("Constraint: "));
+ constraint_label.set_alignment(0, 0.5f);
+ ta_table.attach(constraint_label, 0, 1, row, row + 1, opts, opts, 20, 0);
+ row++;
+ }
+
+ return ta_table;
+
+ }
+
+ private static void add_as_vbox(Box content_area, Label label, Entry entry)
+ {
+ VBox vbox = new VBox(false, 2);
+
+ vbox.pack_start(label, false, false, 0);
+ vbox.pack_start(entry, false, false, 0);
+
+ // Hack to prevent the text entries from stretching horizontally
+ HBox hbox = new HBox(false, 0);
+ hbox.pack_start(vbox, false, false, 0);
+ content_area.pack_start(hbox, false, false, 6);
+ }
+
private static string update_preamble(string preamble)
{
if (preamble == "")
string preamble = "";
string message = "";
string password_test = store_password ? password : "not required";
- check_field(display_name, displayname_label, displayname_labeltext, ref preamble, ref message);
- check_field(issuer, issuer_label, issuer_labeltext, ref preamble, ref message);
- check_field(username, username_label, username_labeltext, ref preamble, ref message);
- check_field(password_test, password_label, password_labeltext, ref preamble, ref message);
+ if (!card.is_no_identity())
+ {
+ check_field(display_name, displayname_label, displayname_labeltext, ref preamble, ref message);
+ check_field(username, username_label, username_labeltext, ref preamble, ref message);
+ check_field(issuer, realm_label, realm_labeltext, ref preamble, ref message);
+ check_field(password_test, password_label, password_labeltext, ref preamble, ref message);
+ }
if (message != "") {
message_label.set_visible(true);
message_label.set_markup(@"<span foreground=\"red\">$preamble$message</span>");
}
}
- private void set_atk_relation(Widget widget, Widget target_widget, Atk.RelationType relationship)
- {
- var atk_widget = widget.get_accessible();
- var atk_target_widget = target_widget.get_accessible();
-
- atk_widget.add_relationship(relationship, atk_target_widget);
- }
-
private static void label_make_bold(Label label)
{
var font_desc = new Pango.FontDescription();
label.modify_font(font_desc);
}
- private void fill_services_vbox(IdCard id_card, VBox services_internal_vbox)
+ private VBox make_services_vbox()
{
- logger.trace("fill_services_vbox");
+ logger.trace("make_services_vbox");
- // var children = services_internal_vbox.get_children();
- // foreach (var widget in children) {
- // services_internal_vbox.remove(widget);
- // }
+ var services_vbox_alignment = new Alignment(0, 0, 1, 0);
+ var services_vscroll = new ScrolledWindow(null, null);
+ services_vscroll.set_policy(PolicyType.NEVER, PolicyType.AUTOMATIC);
+ services_vscroll.set_shadow_type(ShadowType.IN);
+ services_vscroll.set_size_request(0, 60);
+ services_vscroll.add_with_viewport(services_vbox_alignment);
- int i = 0;
- var n_rows = id_card.services.length;
-
- var services_table = new Table(n_rows, 2, false);
- services_table.set_col_spacings(10);
- services_table.set_row_spacings(10);
- services_internal_vbox.pack_start(services_table, true, false, 0);
-
- foreach (string service in id_card.services)
- {
- var label = new Label(service);
- label.set_alignment(0, (float) 0.5);
#if VALA_0_12
- var remove_button = new Button.from_stock(Stock.REMOVE);
+ var remove_button = new Button.from_stock(Stock.REMOVE);
#else
- var remove_button = new Button.from_stock(STOCK_REMOVE);
+ var remove_button = new Button.from_stock(STOCK_REMOVE);
#endif
+ remove_button.set_sensitive(false);
+
+
+ var services_table = new Table(card.services.size, 1, false);
+ services_table.set_row_spacings(1);
+ services_table.set_col_spacings(0);
+ services_table.modify_bg(StateType.NORMAL, white);
+
+ var table_button_hbox = new HBox(false, 6);
+ table_button_hbox.pack_start(services_vscroll, true, true, 6);
+
+ // Hack to prevent the button from growing vertically
+ VBox fixed_height = new VBox(false, 0);
+ fixed_height.pack_start(remove_button, false, false, 0);
+ table_button_hbox.pack_start(fixed_height, false, false, 0);
- remove_button.clicked.connect((remove_button) =>
+ // A table doesn't have a background color, so put it in an EventBox, and
+ // set the EventBox's background color instead.
+ EventBox table_bg = new EventBox();
+ table_bg.modify_bg(StateType.NORMAL, white);
+ table_bg.add(services_table);
+ services_vbox_alignment.add(table_bg);
+
+ var services_vbox_title = new Label(_("Services:"));
+ label_make_bold(services_vbox_title);
+ services_vbox_title.set_alignment(0, 0.5f);
+
+ var services_vbox = new VBox(false, 6);
+ services_vbox.pack_start(services_vbox_title, false, false, 0);
+ services_vbox.pack_start(table_button_hbox, true, true, 0);
+
+ int i = 0;
+ foreach (string service in card.services)
+ {
+ var label = new Label(service);
+ label.set_alignment((float) 0, (float) 0);
+ label.xpad = 3;
+
+ EventBox event_box = new EventBox();
+ event_box.modify_bg(StateType.NORMAL, white);
+ event_box.add(label);
+ event_box.button_press_event.connect(() =>
{
- var dialog = new Gtk.MessageDialog(this,
- Gtk.DialogFlags.DESTROY_WITH_PARENT,
- Gtk.MessageType.QUESTION,
- Gtk.ButtonsType.YES_NO,
- _("Are you sure you want to stop '%s' ID Card from being used with %s?"),
- id_card.display_name,
- service);
- var ret = dialog.run();
- dialog.hide();
-
- if (ret == Gtk.ResponseType.YES)
+ var state = label.get_state();
+ logger.trace("button_press_callback: Label state=" + state.to_string() + " setting bg to " + white.to_string());
+
+ if (selected_item == label)
+ {
+ // Deselect
+ selected_item.parent.modify_bg(state, white);
+ selected_item = null;
+ remove_button.set_sensitive(false);
+ }
+ else
{
- if (id_card != null) {
- SList<string> services = new SList<string>();
-
- foreach (string srv in id_card.services)
- {
- //if (srv == candidate) //!!TODO: If srv is the service to be removed
- // continue;
- services.append(srv);
- }
-
- id_card.services = new string[services.length()];
- for (int j = 0; j < id_card.services.length; j++)
- {
- id_card.services[j] = services.nth_data(j);
- }
-
- parent.identities_manager.update_card(id_card);
+ if (selected_item != null)
+ {
+ // Deselect
+ selected_item.parent.modify_bg(state, white);
+ selected_item = null;
}
+
+ // Select
+ selected_item = label;
+ selected_item.parent.modify_bg(state, selected_color);
+ remove_button.set_sensitive(true);
}
-
+ return false;
});
- services_table.attach_defaults(label, 0, 1, i, i+1);
- services_table.attach_defaults(remove_button, 1, 2, i, i+1);
+
+ services_table.attach_defaults(event_box, 0, 1, i, i+1);
i++;
}
- // services_vbox.show_all();
- }
+ remove_button.clicked.connect((remove_button) =>
+ {
+ var result = WarningDialog.confirm(this,
+ Markup.printf_escaped(
+ "<span font-weight='heavy'>You are about to remove the service '%s'.</span>",
+ selected_item.label)
+ + "\n\nAre you sure you want to do this?",
+ "delete_service");
+ if (result)
+ {
+ if (card != null) {
+ card.services.remove(selected_item.label);
+ services_table.remove(selected_item.parent);
+ selected_item = null;
+ remove_button.set_sensitive(false);
+ }
+ }
+ });
+
+ return services_vbox;
+ }
}