~ubuntu-branches/ubuntu/utopic/samba/utopic

« back to all changes in this revision

Viewing changes to libcli/cldap/cldap.c

  • Committer: Package Import Robot
  • Author(s): Chuck Short
  • Date: 2012-02-21 09:06:34 UTC
  • mfrom: (0.39.23 sid)
  • Revision ID: package-import@ubuntu.com-20120221090634-svd7q7m33pfz0847
Tags: 2:3.6.3-1ubuntu1
* Merge from Debian testing.  Remaining changes:
  + debian/patches/VERSION.patch:
    - set SAMBA_VERSION_SUFFIX to Ubuntu.
  + debian/patches/error-trans.fix-276472:
    - Add the translation of Unix Error code -ENOTSUP to NT Error Code
    - NT_STATUS_NOT_SUPPORTED to prevent the Permission denied error.
  + debian/smb.conf:
    - add "(Samba, Ubuntu)" to server string.
    - comment out the default [homes] share, and add a comment about
      "valid users = %S" to show users how to restrict access to
      \\server\username to only username.
    - Set 'usershare allow guests', so that usershare admins are 
      allowed to create public shares in addition to authenticated
      ones.
    - add map to guest = Bad user, maps bad username to guest access.
  + debian/samba-common.config:
    - Do not change priority to high if dhclient3 is installed.
    - Use priority medium instead of high for the workgroup question.
  + debian/control:
    - Don't build against or suggest ctdb.
    - Add dependency on samba-common-bin to samba.
  + Add ufw integration:
    - Created debian/samba.ufw.profile
    - debian/rules, debian/samba.dirs, debian/samba.files: install
      profile
    - debian/control: have samba suggest ufw
  + Add apport hook:
    - Created debian/source_samba.py.
    - debian/rules, debian/samba.dirs, debian/samba-common-bin.files: install
  + Switch to upstart:
    - Add debian/samba.{nmbd,smbd}.upstart.
  + debian/samba.logrotate, debian/samba-common.dhcp, debian/samba.if-up:
    - Make them upstart compatible
  + debian/samba.postinst: 
    - Avoid scary pdbedit warnings on first import.
  + debian/samba-common.postinst: Add more informative error message for
    the case where smb.conf was manually deleted
  + debian/patches/fix-debuglevel-name-conflict.patch: don't use 'debug_level'
    as a global variable name in an NSS module.
* Dropped:
  - debian/patches/fix-samba-printer-browsing.patch: No longer needed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
273
273
 
274
274
        DLIST_REMOVE(c->searches.list, search);
275
275
 
276
 
        if (!cldap_recvfrom_setup(c)) {
277
 
                goto nomem;
278
 
        }
 
276
        cldap_recvfrom_setup(c);
279
277
 
280
278
        tevent_req_done(search->req);
281
 
        talloc_free(in);
282
279
        return true;
283
280
 
284
281
nomem:
286
283
error:
287
284
        status = map_nt_error_from_unix(in->recv_errno);
288
285
nterror:
 
286
        TALLOC_FREE(in);
289
287
        /* in connected mode the first pending search gets the error */
290
288
        if (!c->connected) {
291
289
                /* otherwise we just ignore the error */
294
292
        if (!c->searches.list) {
295
293
                goto done;
296
294
        }
 
295
        cldap_recvfrom_setup(c);
297
296
        tevent_req_nterror(c->searches.list->req, status);
 
297
        return true;
298
298
done:
299
 
        talloc_free(in);
 
299
        TALLOC_FREE(in);
300
300
        return false;
301
301
}
302
302
 
313
313
        struct tsocket_address *any = NULL;
314
314
        NTSTATUS status;
315
315
        int ret;
 
316
        const char *fam = NULL;
 
317
 
 
318
        if (local_addr == NULL && remote_addr == NULL) {
 
319
                return NT_STATUS_INVALID_PARAMETER_MIX;
 
320
        }
 
321
 
 
322
        if (remote_addr) {
 
323
                bool is_ipv4;
 
324
                bool is_ipv6;
 
325
 
 
326
                is_ipv4 = tsocket_address_is_inet(remote_addr, "ipv4");
 
327
                is_ipv6 = tsocket_address_is_inet(remote_addr, "ipv6");
 
328
 
 
329
                if (is_ipv4) {
 
330
                        fam = "ipv4";
 
331
                } else if (is_ipv6) {
 
332
                        fam = "ipv6";
 
333
                } else {
 
334
                        return NT_STATUS_INVALID_ADDRESS;
 
335
                }
 
336
        }
316
337
 
317
338
        c = talloc_zero(mem_ctx, struct cldap_socket);
318
339
        if (!c) {
329
350
        c->event.ctx = ev;
330
351
 
331
352
        if (!local_addr) {
332
 
                /* we use ipv4 here instead of ip, as otherwise we end
333
 
                   up with a PF_INET6 socket, and sendto() for ipv4
334
 
                   addresses will fail. That breaks cldap name
335
 
                   resolution for winbind to IPv4 hosts. */
336
 
                ret = tsocket_address_inet_from_strings(c, "ipv4",
 
353
                /*
 
354
                 * Here we know the address family of the remote address.
 
355
                 */
 
356
                if (fam == NULL) {
 
357
                        return NT_STATUS_INVALID_PARAMETER_MIX;
 
358
                }
 
359
 
 
360
                ret = tsocket_address_inet_from_strings(c, fam,
337
361
                                                        NULL, 0,
338
362
                                                        &any);
339
363
                if (ret != 0) {