void *smb_getdir(void *value) { int err, dh1, dsize, dirc, i, count; char dirbuf[2048] = {0}; struct smbc_dirent *dirp; char url[MAX_NAME_LEN] = {0}; char buf[MAX_NAME_LEN] = {0}; char tmpdirname[MAX_NAME_LEN] = {0}; char dir_path[MAX_NAME_LEN] = {0}; int ret, mount_ok_num, mount_fail_num; char *p = NULL; struct smbserverinfo_t *psmbserverinfo = NULL; struct smbEventProxyCmd *pevent = NULL; if(value == NULL) return NULL; psmbserverinfo = (struct smbserverinfo_t *)value; printf("%s[%d], name = [%s], ip = [%s], user = [%s], passwd = [%s], cmd_id = [%d]\n", __FILE__, __LINE__, psmbserverinfo->name, psmbserverinfo->ip, psmbserverinfo->user, psmbserverinfo->passwd, psmbserverinfo->cmd_id); memset(smb_username, 0, sizeof(smb_username)); memset(smb_passwd, 0, sizeof(smb_passwd)); if(psmbserverinfo->user != NULL) { strncpy(smb_username, psmbserverinfo->user, strlen(psmbserverinfo->user)); smb_username[strlen(psmbserverinfo->user)] = '\0'; } if(psmbserverinfo->passwd != NULL) { strncpy(smb_passwd, psmbserverinfo->passwd, strlen(psmbserverinfo->passwd)); smb_passwd[strlen(psmbserverinfo->passwd)] = '\0'; } printf("%s[%d], smb_username = [%s], smb_passwd = [%s]\n", __FILE__, __LINE__, smb_username, smb_passwd); snprintf(url, sizeof(url), "smb://%s:%s@%s", smb_username, smb_passwd, psmbserverinfo->name); err = smbc_init(get_static_auth_data_fn, 0); /* Initialize things */ if (err < 0) { printf("%s[%d], Initializing the smbclient library ...: %s\n", __FILE__, __LINE__, strerror(errno)); SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNT_FAILED, psmbserverinfo->cmd_id, NULL); SMBTREE_free_smbserverinfo(psmbserverinfo); return NULL; } if ((dh1 = smbc_opendir(url))<1) { printf("%s[%d], Could not open directory: %s: %s\n", __FILE__, __LINE__, url, strerror(errno)); SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNT_FAILED, psmbserverinfo->cmd_id, NULL); SMBTREE_free_smbserverinfo(psmbserverinfo); return NULL; } snprintf(dir_path, sizeof(dir_path), "%s/%s", CONF_SAMBA_MOUNT_POINT, psmbserverinfo->name); smb_umount(dir_path); /* Now, list those directories, but in funny ways ... */ /* keep call smbc_getdents() until there is no share folder to fix Device only can browse less than 8 root folder.*/ while(0 != (dirc = smbc_getdents(dh1, (struct smbc_dirent *)dirbuf, sizeof(dirbuf)))) { if(dirc < 0) { fprintf(stderr, "Problems getting directory entries: %s\n", strerror(errno)); smbc_closedir(dh1); SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNT_FAILED, psmbserverinfo->cmd_id, NULL); SMBTREE_free_smbserverinfo(psmbserverinfo); return NULL; } /* Now, process the list of names ... */ fprintf(stdout, "Directory listing, size = %u\n", dirc); dirp = (struct smbc_dirent *)dirbuf; count = 0; mount_ok_num = 0; mount_fail_num = 0; while (dirc > 0) { dsize = dirp->dirlen; switch (dirp->smbc_type) { case SMBC_DIR: case SMBC_FILE: case SMBC_FILE_SHARE: snprintf(buf, sizeof(buf), "%s\\%s\\%s", psmbserverinfo->name, psmbserverinfo->ip, dirp->name); fprintf(stdout, "Shared Dir Type: %u, Name: %s\n", dirp->smbc_type, dirp->name); /*if share-folder-name is end of $, system doesn't mount it*/ if((p=strrchr(buf, '$')) != NULL && strlen(p) == 1) { printf("%s[%d], ##### %s not match ####\n", __FILE__, __LINE__, buf); break; } memset(tmpdirname, '\0', sizeof(tmpdirname)); smb_replace_special_char(dirp->name, tmpdirname); ret = smb_mount(psmbserverinfo->user, psmbserverinfo->passwd, psmbserverinfo->name, psmbserverinfo->ip, tmpdirname); if (ret == 0) { #ifdef ENABLE_PTHREAD pevent = malloc(sizeof(struct smbEventProxyCmd)); pevent->cmd = SMB_CMD_BROWSE_RESPONSE; pevent->status = SMB_MOUNTING; pevent->id = psmbserverinfo->cmd_id; pevent->datalen = strlen(buf) + 1; strcpy((char *)pevent->data, buf); XLinkedList_Lock(sharefolderlist); XLinkedList_AddTail(sharefolderlist, (void *)pevent); XLinkedList_UnLock(sharefolderlist); #else SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNTING, psmbserverinfo->cmd_id, buf); #endif mount_ok_num++; } else { mount_fail_num++; } break; default: break; } i = dsize % 4 == 0 ? 0 : (4 - dsize % 4); dsize += i; count += dsize; dirp = (struct smbc_dirent *)(dirbuf + count); dirc -= dsize; } memset(dirbuf, 0, sizeof(dirbuf)); } smbc_closedir(dh1); if(mount_fail_num > 0 && mount_ok_num == 0) { SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNT_FAILED, psmbserverinfo->cmd_id, NULL); } else { SMBTREE_send_event_to_OSD(SMB_CMD_BROWSE_RESPONSE, SMB_MOUNT_OK, psmbserverinfo->cmd_id, NULL); } SMBTREE_free_smbserverinfo(psmbserverinfo); return NULL; }
int main(int argc, char** argv) { int err = -1; int fd = 0; int dh = 0; int entry_num = 0; int i = 0; int j = 0; char *file_name; char *tmp_file_ptr; int direntsize = 0; int diramount = 0; struct smbc_dirent *dirptr; char buff[MAX_BUFF_SIZE]; char url[MAX_BUFF_SIZE]; char file_url[MAX_BUFF_SIZE]; char dir_url[MAX_BUFF_SIZE]; char dirbuff[MAX_BUFF_SIZE]; bzero(g_workgroup,MAX_BUFF_SIZE); bzero(url,MAX_BUFF_SIZE); bzero(file_url,MAX_BUFF_SIZE); bzero(dir_url,MAX_BUFF_SIZE); bzero(buff,MAX_BUFF_SIZE); if ( argc == 6 ) { dirptr = (struct smbc_dirent *) dirbuff; strncpy(g_workgroup,argv[1],strlen(argv[1])); strncpy(g_username,argv[2],strlen(argv[2])); strncpy(g_password,argv[3],strlen(argv[3])); strncpy(url,argv[4],strlen(argv[4])); smbc_init(auth_fn, 0); strncpy(file_url,"tempfile-",9); tmp_file_ptr = file_url; tmp_file_ptr += 9; smbc_rmdir(url); smbc_mkdir(url,0666); entry_num = atoi(argv[5]); strcat(dir_url,url); strcat(dir_url,"/"); file_name = dir_url; file_name += strlen(dir_url); for ( i = 0; i < entry_num; i++ ) { sprintf(buff,"%d",i); memcpy(tmp_file_ptr,buff,strlen(buff)+4); strncat(tmp_file_ptr,".txt",4); strcpy(file_name,file_url); fd = smbc_open(dir_url,O_RDWR | O_CREAT, 0666); smbc_close(fd); } dh = smbc_opendir(url); diramount = smbc_getdents( dh, dirptr, sizeof(dirbuff)); err = 0; i = 0; bzero(buff,MAX_BUFF_SIZE); bzero(tmp_file_ptr,MAX_BUFF_SIZE-9); while ( diramount > 0 ) { direntsize = dirptr->dirlen; /* printf("Name: %s\n",dirptr->name); */ if ( j == 0 ) { if ( !(( strncmp(dirptr->name,".",1) == 0 )) ) { break; err = 1; } } else if ( j == 1 ) { if ( !(( strncmp(dirptr->name,"..",2) == 0 )) ) { break; err = 1; } } else if ( j > 1 ) { sprintf(buff,"%d",i); memcpy(tmp_file_ptr,buff,strlen(buff)+4); strncat(tmp_file_ptr,".txt",4); if ( !((strcmp(dirptr->name,file_url) == 0 )) ) /* make sure entries match */ { err = 1; break; } i++; } (char *)dirptr += direntsize; (char *)diramount -= direntsize; j++; } if ( ! err ) { if ( (j - 2) != entry_num ) /* Make sure that all entries created are counted and returned - minus . and .. */ err = 1; } } return err; }
int Spider::ScanSMBDir(const std::string &dir) { int directory_handler = 0, dirc = 0, dsize = 0; char *dirp = NULL; struct smbc_dirent *entry = NULL; char buf[BUF_SIZE]; // Open given smb directory. if (UNLIKELY((directory_handler = smbc_opendir(dir.c_str())) < 0)) { DetectError(); MSS_ERROR(("smbc_opendir " + dir).c_str(), error_); return -1; } // Getting content of the directory. // smbc_getdents() returns the readen size. // When no more content in the directory smbc_getdents() returns 0. // Use smbc_getdents() while returned value not equal 0. while (true) { dirp = static_cast<char *>(buf); // Get dir content which can placed in buf. if (UNLIKELY((dirc = smbc_getdents( static_cast<unsigned int>(directory_handler), reinterpret_cast<struct smbc_dirent *>(dirp), sizeof(buf)))) < 0) { DetectError(); MSS_ERROR("smbc_getdents", error_); return -1; } // Break the cycle if no more content in this directory. if (dirc == 0) break; // Put readen content in list while (dirc > 0) { entry = reinterpret_cast<struct smbc_dirent *>(dirp); dsize = static_cast<int>(entry->dirlen); // Ignoring "." and ".." if ((strcmp(entry->name, ".") == 0) || (strcmp(entry->name, "..") == 0)) { dirp += dsize; // Use char * to promote pointer exactly on dsize dirc -= dsize; // Decrease size continue; } switch (reinterpret_cast<struct smbc_dirent *>(dirp)->smbc_type) { case SMBC_WORKGROUP: case SMBC_SERVER: case SMBC_FILE_SHARE: case SMBC_DIR: ScanSMBDir(dir + "/" + entry->name); break; case SMBC_FILE: AddSMBFile(dir + "/" + entry->name); break; case SMBC_PRINTER_SHARE: case SMBC_COMMS_SHARE: case SMBC_IPC_SHARE: case SMBC_LINK: // Do nothing break; default: MSS_FATAL_MESSAGE("Unknown smb entry type"); assert(0); // This can't happen } dirp += dsize; // Use char * to promote pointer exactly on dsize dirc -= dsize; // Decrease size } } // Close given smb directory if (UNLIKELY(smbc_closedir(directory_handler) < 0)) { DetectError(); MSS_ERROR(("smbc_closedir " + dir).c_str(), error_); } return 0; }
int main(int argc, char *argv[]) { int err, fd, dh1, dsize, dirc; const char *file = "smb://samba/public/testfile.txt"; const char *file2 = "smb://samba/public/testfile2.txt"; char buff[256]; char dirbuf[512]; char *dirp; struct stat st1, st2; err = smbc_init(get_auth_data_fn, 10); /* Initialize things */ if (err < 0) { fprintf(stderr, "Initializing the smbclient library ...: %s\n", strerror(errno)); } if (argc > 1) { if ((dh1 = smbc_opendir(argv[1]))<1) { fprintf(stderr, "Could not open directory: %s: %s\n", argv[1], strerror(errno)); exit(1); } fprintf(stdout, "Directory handle: %u\n", dh1); /* Now, list those directories, but in funny ways ... */ dirp = (char *)dirbuf; if ((dirc = smbc_getdents(dh1, (struct smbc_dirent *)dirp, sizeof(dirbuf))) < 0) { fprintf(stderr, "Problems getting directory entries: %s\n", strerror(errno)); exit(1); } /* Now, process the list of names ... */ fprintf(stdout, "Directory listing, size = %u\n", dirc); while (dirc > 0) { dsize = ((struct smbc_dirent *)dirp)->dirlen; fprintf(stdout, "Dir Ent, Type: %u, Name: %s, Comment: %s\n", ((struct smbc_dirent *)dirp)->smbc_type, ((struct smbc_dirent *)dirp)->name, ((struct smbc_dirent *)dirp)->comment); dirp += dsize; dirc -= dsize; } dirp = (char *)dirbuf; exit(1); } /* For now, open a file on a server that is hard coded ... later will * read from the command line ... */ fd = smbc_open(file, O_RDWR | O_CREAT | O_TRUNC, 0666); if (fd < 0) { fprintf(stderr, "Creating file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Opened or created file: %s\n", file); /* Now, write some date to the file ... */ memset(buff, '\0', sizeof(buff)); snprintf(buff, sizeof(buff), "%s", "Some test data for the moment ..."); err = smbc_write(fd, buff, sizeof(buff)); if (err < 0) { fprintf(stderr, "writing file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Wrote %lu bytes to file: %s\n", (unsigned long) sizeof(buff), buff); /* Now, seek the file back to offset 0 */ err = smbc_lseek(fd, SEEK_SET, 0); if (err < 0) { fprintf(stderr, "Seeking file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Completed lseek on file: %s\n", file); /* Now, read the file contents back ... */ err = smbc_read(fd, buff, sizeof(buff)); if (err < 0) { fprintf(stderr, "Reading file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Read file: %s\n", buff); /* Should check the contents */ fprintf(stdout, "Now fstat'ing file: %s\n", file); err = smbc_fstat(fd, &st1); if (err < 0) { fprintf(stderr, "Fstat'ing file: %s: %s\n", file, strerror(errno)); exit(0); } /* Now, close the file ... */ err = smbc_close(fd); if (err < 0) { fprintf(stderr, "Closing file: %s: %s\n", file, strerror(errno)); } /* Now, rename the file ... */ err = smbc_rename(file, file2); if (err < 0) { fprintf(stderr, "Renaming file: %s to %s: %s\n", file, file2, strerror(errno)); } fprintf(stdout, "Renamed file %s to %s\n", file, file2); /* Now, create a file and delete it ... */ fprintf(stdout, "Now, creating file: %s so we can delete it.\n", file); fd = smbc_open(file, O_RDWR | O_CREAT, 0666); if (fd < 0) { fprintf(stderr, "Creating file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Opened or created file: %s\n", file); err = smbc_close(fd); if (err < 0) { fprintf(stderr, "Closing file: %s: %s\n", file, strerror(errno)); exit(0); } /* Now, delete the file ... */ fprintf(stdout, "File %s created, now deleting ...\n", file); err = smbc_unlink(file); if (err < 0) { fprintf(stderr, "Deleting file: %s: %s\n", file, strerror(errno)); exit(0); } /* Now, stat the file, file 2 ... */ fprintf(stdout, "Now stat'ing file: %s\n", file); err = smbc_stat(file2, &st2); if (err < 0) { fprintf(stderr, "Stat'ing file: %s: %s\n", file, strerror(errno)); exit(0); } fprintf(stdout, "Stat'ed file: %s. Size = %d, mode = %04X\n", file2, (int)st2.st_size, (unsigned int)st2.st_mode); fprintf(stdout, " time: %s\n", ctime(&st2.st_atime)); fprintf(stdout, "Earlier stat: %s, Size = %d, mode = %04X\n", file, (int)st1.st_size, (unsigned int)st1.st_mode); fprintf(stdout, " time: %s\n", ctime(&st1.st_atime)); /* Now, make a directory ... */ fprintf(stdout, "Making directory smb://samba/public/make-dir\n"); if (smbc_mkdir("smb://samba/public/make-dir", 0666) < 0) { fprintf(stderr, "Error making directory: smb://samba/public/make-dir: %s\n", strerror(errno)); if (errno == EEXIST) { /* Try to delete the directory */ fprintf(stdout, "Trying to delete directory: smb://samba/public/make-dir\n"); if (smbc_rmdir("smb://samba/public/make-dir") < 0) { /* Error */ fprintf(stderr, "Error removing directory: smb://samba/public/make-dir: %s\n", strerror(errno)); exit(0); } fprintf(stdout, "Making directory: smb://samba/public/make-dir\n"); if (smbc_mkdir("smb://samba/public/make-dir", 666) < 0) { fprintf(stderr, "Error making directory: smb://samba/public/make-dir: %s\n", strerror(errno)); fprintf(stderr, "I give up!\n"); exit(1); } } exit(0); } fprintf(stdout, "Made dir: make-dir\n"); return 0; }
int main(int argc, char** argv) { int err = -1; int fd = 0; int dh = 0; int entry_num = 0; int i = 0; char *file_name; char *tmp_file_ptr; int diramount = 0; struct smbc_dirent *dirptr; char buff[MAX_BUFF_SIZE]; char url[MAX_BUFF_SIZE]; char file_url[MAX_BUFF_SIZE]; char dir_url[MAX_BUFF_SIZE]; char dirbuff[MAX_BUFF_SIZE]; bzero(g_workgroup,MAX_BUFF_SIZE); bzero(url,MAX_BUFF_SIZE); bzero(file_url,MAX_BUFF_SIZE); bzero(dir_url,MAX_BUFF_SIZE); bzero(buff,MAX_BUFF_SIZE); if ( argc == 6 ) { dirptr = (struct smbc_dirent *) dirbuff; strncpy(g_workgroup,argv[1],strlen(argv[1])); strncpy(g_username,argv[2],strlen(argv[2])); strncpy(g_password,argv[3],strlen(argv[3])); strncpy(url,argv[4],strlen(argv[4])); smbc_init(auth_fn, 0); strncpy(file_url,"tempfile-",9); tmp_file_ptr = file_url; tmp_file_ptr += 9; smbc_rmdir(url); smbc_mkdir(url,0666); entry_num = atoi(argv[5]); strcat(dir_url,url); strcat(dir_url,"/"); file_name = dir_url; file_name += strlen(dir_url); for ( i = 0; i < entry_num; i++ ) { sprintf(buff,"%d",i); memcpy(tmp_file_ptr,buff,strlen(buff)+4); strncat(tmp_file_ptr,".txt",4); strcpy(file_name,file_url); fd = smbc_open(dir_url,O_RDWR | O_CREAT, 0666); smbc_close(fd); } dh = smbc_opendir(url); diramount = smbc_getdents( dh, dirptr, 20 /* sizeof(dirbuff)*/); if ( diramount < 0 ) err = 1; else err = 0; } return err; }