On Wed, Jul 20, 2016 at 03:00:14PM +0200, Jakub Hrozek wrote:
> On Tue, Jul 19, 2016 at 12:20:16PM +0200, Pavel Březina wrote:
> > On 07/18/2016 03:23 PM, Jakub Hrozek wrote:
> > > On Thu, Jul 14, 2016 at 11:39:40AM +0200, Pavel Březina wrote:
> > > >  From 6af064012844f3e61b9fa5b502bebe44e4620ffd Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Tue, 28 Jun 2016 11:40:16 +0200
> > > > Subject: [PATCH 1/7] rdp: add ability to forward reply to the client 
> > > > request
> > > 
> > > LGTM, but I didn't test yet.
> > > 
> > > >  From 2ad0b97f9e435ac5f57caf37479304c16d0424c9 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Tue, 28 Jun 2016 15:29:39 +0200
> > > > Subject: [PATCH 2/7] sbus: add sbus_request_reply_error()
> > > 
> > > OK, but what is the plan on the other calls? I wouldn't like us to end
> > > up with two competing implementations of the same (again)..
> > 
> > It is sometimes desirable to pass DBusError as an argument but in much more
> > cases it is simpler to just use this call. The plan is to change the calls
> > where it is desirable, I'll send separate patch later for this. Here I
> > changed it only for sssctl related code.
> > 
> > > >  From 0f508095599b3e04573a21a600b4f42e172cc304 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Wed, 29 Jun 2016 12:35:59 +0200
> > > > Subject: [PATCH 3/7] sbus: add utility function to simplify message and 
> > > > reply
> > > >   handling
> > > > 
> > > > This patch adds the ability to hook DBusMessage to a talloc context
> > > > to remove the need of calling dbus_message_unref(). It also provides
> > > > an automatical way to detect error in a reply so the caller does
> > > > not need to parse it manually and the whole code around DBusError
> > > > can be avoided.
> > > 
> > > One code readability nitpick..
> > > 
> > > > +errno_t sbus_check_reply(DBusMessage *reply)
> > > > +{
> > > > +    dbus_bool_t bret;
> > > > +    DBusError error;
> > > > +    errno_t ret;
> > > > +
> > > > +    dbus_error_init(&error);
> > > > +
> > > > +    switch (dbus_message_get_type(reply)) {
> > > > +    case DBUS_MESSAGE_TYPE_METHOD_RETURN:
> > > > +        ret = EOK;
> > > > +        goto done;
> > > 
> > > Can you use break in the non-failure cases? I would say this would be
> > > more readable..
> > 
> > Done.
> > 
> > > > +
> > > > +    case DBUS_MESSAGE_TYPE_ERROR:
> > > > +        bret = dbus_set_error_from_message(&error, reply);
> > > > +        if (bret == false) {
> > > > +            DEBUG(SSSDBG_CRIT_FAILURE, "Unable to read error from 
> > > > message\n");
> > > > +            ret = EIO;
> > > > +            goto done;
> > > > +        }
> > > > +
> > > > +        DEBUG(SSSDBG_CRIT_FAILURE, "D-Bus error [%s]: %s\n",
> > > > +              error.name, (error.message == NULL ? "(null)" : 
> > > > error.message));
> > > > +        ret = sbus_error_to_errno(&error);
> > > > +        goto done;
> > > > +    default:
> > > > +        DEBUG(SSSDBG_CRIT_FAILURE, "Unexpected D-Bus message type?\n");
> > > > +        ret = ERR_INTERNAL;
> > > > +        goto done;
> > > > +    }
> > > > +
> > > > +done:
> > > > +    dbus_error_free(&error);
> > > > +
> > > > +    return ret;
> > > > +}
> > > 
> > > The rest looks good to me.
> > > 
> > > >  From 93b4f2e9077f1959d563ba8e4d3f41a9764cc8c6 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Wed, 29 Jun 2016 14:03:38 +0200
> > > > Subject: [PATCH 4/7] sssctl: use talloc with sifp
> > > 
> > > LGTM
> > > 
> > > >  From 33f5fd436a0fc3d5d1eac970b66c174bb2da6189 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Wed, 29 Jun 2016 14:58:37 +0200
> > > > Subject: [PATCH 5/7] failover: mark subdomain service with sd_ prefix
> > > 
> > > Did you test the failover with subdomain? I wonder if we rely on the
> > > service name somewhere, but I can't remember.
> > 
> > Yes. The name is generated and stored in service context. We do not rely on
> > precise name anywhere, but in these patches... it's not a nice thing to do
> > but I didn't come up with anything better.
> > 
> > > But more importantly, also related to the next patch, you noted we don't
> > > actually use the GC service for AD subdomains, if that's true shouldn't
> > > we remove it completely?
> > 
> > We use it with IPA provider. But it is doable to remove it from AD provider
> > completely, but I didn't want to touch fo service code with those patches.
> > 
> > > >  From e4c6e829a1942290d441cec618d477782bbe4c08 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Mon, 27 Jun 2016 13:56:13 +0200
> > > > Subject: [PATCH 6/7] ssctl: print active server and server list
> > > > +    count = 0;
> > > > +    DLIST_FOR_EACH(svc, be_ctx->be_fo->svcs) {
> > > > +        /* Drop each sd_gc_* since this service is not used with AD at 
> > > > all,
> > > > +         * we only connect to AD_GC for global catalog. */
> > > > +        if (strncasecmp(svc->name, "sd_gc_", strlen("sd_gc_")) == 0) {
> > > > +            continue;
> > > 
> > > I asked this in the previous patch, shouldn't we drop the GC service if
> > > it's not used? Also, what does "we only connect to AD_GC for global
> > > catalog." mean?
> > 
> > There is service called AD_GC. We resolve this service when we want to
> > connect to GC whether we search in subdomain or not when using AD provider.
> > 
> > > 
> > > 
> > > > +        }
> > > > +
> > > > +        /* Drop all subdomain services for different domain. */
> > > > +        if (strncasecmp(svc->name, "sd_", strlen("sd_")) == 0) {
> > > > +            if (!IS_SUBDOMAIN(domain)) {
> > > > +                continue;
> > > 
> > > Why would we see sd_ services for non-subdomin?
> > 
> > Because the failover context is shared across all domains in backend, so
> > there's always everything.
> > 
> > > > +            }
> > > > +
> > > > +            if (strcasecmp(svc->name, fo_svc_name) != 0) {
> > > > +                continue;
> > > > +            }
> > > > +        }
> > > > +
> > > > +        if (IS_SUBDOMAIN(domain)) {
> > > > +            /* Drop AD since we connect to subdomain.com for LDAP. */
> > > > +            if (strcasecmp(svc->name, "AD") == 0) {
> > > > +                continue;
> > > > +            }
> > > > +        }
> > > 
> > > >  From e74a27309b8a49c0f524bb9d3d66385dd1d33bc1 Mon Sep 17 00:00:00 2001
> > > > From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <[email protected]>
> > > > Date: Thu, 14 Jul 2016 10:49:37 +0200
> > > > Subject: [PATCH 7/7] sifp: fix coverity warning
> > > 
> > > ACK
> > 
> > New patches attached.
> > 
> > 
> 
> OK, one more question and I'm not sure if failover is at fault here..I
> tested on an IPA server connected to an AD domain where I switched off
> one of the DCs. Now the domain reports like this:
> 
> $ sudo sssctl domain-status subdom.win.trust.test
> Online status: Offline
> 
> Active servers:
> AD Domain Controller: child.subdom.win.trust.test
> IPA: unidirect.ipa.test
> 
> Discovered AD Domain Controller servers:
> - child.subdom.win.trust.test
> 
> Discovered IPA servers:
> - unidirect.ipa.test
> 
> So sssctl correctly reports the domain is offline, but still prints an
> active server..why?

also, there is a warning:
Error: COMPILER_WARNING:
sssd-1.14.1/src/providers/data_provider/dp_iface_failover.c: scope_hint: In 
function 'dp_failover_list_services'
sssd-1.14.1/src/providers/data_provider/dp_iface_failover.c:248:8: warning: 
'ret' may be used uninitialized in this function [-Wmaybe-uninitialized]
#     if (ret != EOK) {
#        ^
#  246|       }
#  247|   
#  248|->     if (ret != EOK) {
#  249|           DEBUG(SSSDBG_CRIT_FAILURE, "Unable to create service list 
[%d]: %s\n",
#  250|                 ret, sss_strerror(ret));
_______________________________________________
sssd-devel mailing list
[email protected]
https://lists.fedorahosted.org/admin/lists/[email protected]

Reply via email to