/mandos/release

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/release

« back to all changes in this revision

Viewing changes to plugins.d/mandos-client.c

  • Committer: Björn Påhlsson
  • Date: 2011-06-19 20:25:38 UTC
  • mto: (237.7.33 trunk)
  • mto: This revision was merged to the branch mainline in revision 284.
  • Revision ID: belorn@fukt.bsnet.se-20110619202538-0js072v8fso12u07
prepended mandos plugin to error messages in each plugin. Added a better way in TODO.

Show diffs side-by-side

added added

removed removed

Lines of Context:
9
9
 * "browse_callback", and parts of "main".
10
10
 * 
11
11
 * Everything else is
12
 
 * Copyright © 2008-2010 Teddy Hogeborn
13
 
 * Copyright © 2008-2010 Björn Påhlsson
 
12
 * Copyright © 2008-2011 Teddy Hogeborn
 
13
 * Copyright © 2008-2011 Björn Påhlsson
14
14
 * 
15
15
 * This program is free software: you can redistribute it and/or
16
16
 * modify it under the terms of the GNU General Public License as
741
741
    errno = EINTR;
742
742
    goto mandos_end;
743
743
  }
744
 
  
 
744
 
 
745
  /* Spurious warnings from -Wint-to-pointer-cast */
745
746
  gnutls_transport_set_ptr(session, (gnutls_transport_ptr_t) tcp_sd);
746
747
  
747
748
  if(quit_now){
1032
1033
int good_interface(const struct dirent *if_entry){
1033
1034
  ssize_t ssret;
1034
1035
  char *flagname = NULL;
 
1036
  if(if_entry->d_name[0] == '.'){
 
1037
    return 0;
 
1038
  }
1035
1039
  int ret = asprintf(&flagname, "%s/%s/flags", sys_class_net,
1036
1040
                     if_entry->d_name);
1037
1041
  if(ret < 0){
1038
1042
    perror("asprintf");
1039
1043
    return 0;
1040
1044
  }
1041
 
  if(if_entry->d_name[0] == '.'){
1042
 
    return 0;
1043
 
  }
1044
1045
  int flags_fd = (int)TEMP_FAILURE_RETRY(open(flagname, O_RDONLY));
1045
1046
  if(flags_fd == -1){
1046
1047
    perror("open");
 
1048
    free(flagname);
1047
1049
    return 0;
1048
1050
  }
 
1051
  free(flagname);
1049
1052
  typedef short ifreq_flags;    /* ifreq.ifr_flags in netdevice(7) */
1050
1053
  /* read line from flags_fd */
1051
1054
  ssize_t to_read = (sizeof(ifreq_flags)*2)+3; /* "0x1003\n" */
1111
1114
    }
1112
1115
    return 0;
1113
1116
  }
 
1117
  /* Reject non-ARP interfaces (including dummy interfaces) */
 
1118
  if(flags & IFF_NOARP){
 
1119
    if(debug){
 
1120
      fprintf(stderr, "Rejecting non-ARP interface \"%s\"\n",
 
1121
              if_entry->d_name);
 
1122
    }
 
1123
    return 0;
 
1124
  }
1114
1125
  /* Accept this device */
1115
1126
  if(debug){
1116
1127
    fprintf(stderr, "Interface \"%s\" is acceptable\n",
1119
1130
  return 1;
1120
1131
}
1121
1132
 
 
1133
int notdotentries(const struct dirent *direntry){
 
1134
  /* Skip "." and ".." */
 
1135
  if(direntry->d_name[0] == '.'
 
1136
     and (direntry->d_name[1] == '\0'
 
1137
          or (direntry->d_name[1] == '.'
 
1138
              and direntry->d_name[2] == '\0'))){
 
1139
    return 0;
 
1140
  }
 
1141
  return 1;
 
1142
}
 
1143
 
1122
1144
int main(int argc, char *argv[]){
1123
1145
  AvahiSServiceBrowser *sb = NULL;
1124
1146
  int error;
1555
1577
    goto end;
1556
1578
  }
1557
1579
  
1558
 
  tempdir_created = true;
1559
1580
  if(mkdtemp(tempdir) == NULL){
1560
 
    tempdir_created = false;
1561
1581
    perror("mkdtemp");
1562
1582
    goto end;
1563
1583
  }
 
1584
  tempdir_created = true;
1564
1585
  
1565
1586
  if(quit_now){
1566
1587
    goto end;
1751
1772
    }
1752
1773
  }
1753
1774
  
1754
 
  /* Removes the temp directory used by GPGME */
 
1775
  /* Removes the GPGME temp directory and all files inside */
1755
1776
  if(tempdir_created){
1756
 
    DIR *d;
1757
 
    struct dirent *direntry;
1758
 
    d = opendir(tempdir);
1759
 
    if(d == NULL){
1760
 
      if(errno != ENOENT){
1761
 
        perror("opendir");
1762
 
      }
1763
 
    } else {
1764
 
      while(true){
1765
 
        direntry = readdir(d);
1766
 
        if(direntry == NULL){
1767
 
          break;
1768
 
        }
1769
 
        /* Skip "." and ".." */
1770
 
        if(direntry->d_name[0] == '.'
1771
 
           and (direntry->d_name[1] == '\0'
1772
 
                or (direntry->d_name[1] == '.'
1773
 
                    and direntry->d_name[2] == '\0'))){
1774
 
          continue;
1775
 
        }
 
1777
    struct dirent **direntries = NULL;
 
1778
    struct dirent *direntry = NULL;
 
1779
    ret = scandir(tempdir, &direntries, notdotentries, alphasort);
 
1780
    if (ret > 0){
 
1781
      for(int i = 0; i < ret; i++){
 
1782
        direntry = direntries[i];
1776
1783
        char *fullname = NULL;
1777
1784
        ret = asprintf(&fullname, "%s/%s", tempdir,
1778
1785
                       direntry->d_name);
1787
1794
        }
1788
1795
        free(fullname);
1789
1796
      }
1790
 
      closedir(d);
 
1797
    }
 
1798
 
 
1799
    /* need to be cleaned even if ret == 0 because man page dont specify */
 
1800
    free(direntries);
 
1801
    if (ret == -1){
 
1802
      perror("scandir");
1791
1803
    }
1792
1804
    ret = rmdir(tempdir);
1793
1805
    if(ret == -1 and errno != ENOENT){