-delegate void ReturnIdentityCallback (IdentityRequest request);
+/*
+ * Copyright (c) 2011-2014, JANET(UK)
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * 3. Neither the name of JANET(UK) nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+*/
+public delegate void ReturnIdentityCallback(IdentityRequest request);
-class IdentityRequest : Object {
+public class IdentityRequest : Object {
public IdCard? id_card = null;
public bool complete = false;
+ public bool select_default = false;
- private MainWindow main_window;
- private string nai;
- private string password;
- private string certificate;
+ private IdentityManagerApp parent_app;
+ public string nai;
+ public string password;
+ public string service;
+ public SList<IdCard> candidates;
- // Only one of these is used, we must support two types for
- // the DBus and MSRPC servers.
- ReturnIdentityCallback return_identity_cb = null;
- SourceFunc source_func_cb = null;
+ ReturnIdentityCallback callback = null;
- public IdentityRequest (MainWindow main_window,
- string nai,
- string password,
- string certificate)
+ public IdentityRequest(IdentityManagerApp app,
+ string nai,
+ string password,
+ string service)
{
- this.main_window = main_window;
+ this.parent_app = app;
this.nai = nai;
this.password = password;
- this.certificate = certificate;
+ this.service = service;
}
- public void set_return_identity_callback (owned ReturnIdentityCallback cb)
+ public IdentityRequest.default(IdentityManagerApp app)
{
-#if VALA_0_12
- this.return_identity_cb = ((owned) cb);
-#else
- this.return_identity_cb = (() => cb ());
-#endif
+ this.parent_app = app;
+ this.select_default = true;
}
- public void set_source_func_callback (owned SourceFunc cb)
+ public void set_callback(owned ReturnIdentityCallback cb)
{
-#if VALA_0_12
- this.source_func_cb = ((owned) cb);
-#else
- this.source_func_cb = (() => cb ());
-#endif
+ #if VALA_0_12
+ this.callback = ((owned) cb);
+ #else
+ this.callback = ((IdCard) => cb(IdCard));
+ #endif
}
- public void execute () {
- main_window.select_identity (this);
+ public bool execute() {
+ parent_app.select_identity(this);
+
+ /* This function works as a GSourceFunc, so it can be passed to
+ * the main loop from other threads
+ */
+ return false;
}
- public void return_identity (IdCard? id_card) {
+ public void return_identity(IdCard? id_card) {
this.id_card = id_card;
this.complete = true;
- if (return_identity_cb != null)
- return_identity_cb (this);
- else if (source_func_cb != null)
- source_func_cb ();
- else
- warn_if_reached ();
+ /* update id_card service list */
+ if (id_card != null && this.service != null && this.service != "")
+ {
+ bool duplicate_service = false;
+
+ foreach (string service in id_card.services)
+ {
+ if (service == this.service)
+ duplicate_service = true;
+ }
+ if (duplicate_service == false)
+ {
+ string[] services = new string[id_card.services.length + 1];
+
+ for (int i = 0; i < id_card.services.length; i++)
+ services[i] = id_card.services[i];
+
+ services[id_card.services.length] = this.service;
+ id_card.services = services;
+
+ this.id_card = this.parent_app.model.update_card(id_card);
+ }
+ }
+
+ return_if_fail(callback != null);
+ callback(this);
}
+
+#if OS_WIN32
+ /* For synchronisation between RPC thread and main loop. Because
+ * these objects are not refcounted, it's best to tie them to the
+ * lifecycle of the IdentityRequest object.
+ */
+ public Mutex mutex;
+ public Cond cond;
+#endif
}