// The contents of this file are subject to the Mozilla Public License // Version 1.0 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License at // http://www.mozilla.org/MPL/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations // under the License. // // The Original Code is the Berkeley Open Infrastructure for Network Computing. // // The Initial Developer of the Original Code is the SETI@home project. // Portions created by the SETI@home project are Copyright (C) 2002 // University of California at Berkeley. All Rights Reserved. // // Contributor(s): // // functions relating to file transfer // #include "windows_cpp.h" #ifdef _WIN32 #include #endif #include #include #include "md5_file.h" #include "crypt.h" #include "file_xfer.h" #include "file_names.h" #include "client_types.h" #include "log_flags.h" #include "client_state.h" #include "error_numbers.h" // Decide whether to start a new file transfer // bool CLIENT_STATE::start_new_file_xfer() { // TODO: limit the number of file xfers in some way return true; } // Make a directory for each of the projects present // in the client state // int CLIENT_STATE::make_project_dirs() { unsigned int i; for (i=0; icode_sign_key, verified ); if (retval) { fprintf(stderr, "error: verify_file2: internal error\n"); return ERR_RSA_FAILED; } if (!verified) { fprintf(stderr, "error: verify_file2: file not verified\n"); return ERR_RSA_FAILED; } } else if (file_info.md5_cksum) { md5_file(pathname, cksum, file_info.nbytes); if (strcmp(cksum, file_info.md5_cksum)) { fprintf(stderr, "error: verify_file2: MD5 check failed\n"); return ERR_MD5_FAILED; } } return 0; } // scan all FILE_INFOs and PERS_FILE_XFERs. // start and finish downloads and uploads as needed. // bool CLIENT_STATE::handle_pers_file_xfers() { unsigned int i; FILE_INFO* fip; PERS_FILE_XFER *pfx; bool action = false; int retval; for (i=0; ipers_file_xfer; if (pfx) continue; if (!fip->generated_locally && fip->status == FILE_NOT_PRESENT) { // Set up the persistent file transfer object. // This will start the download when there is available bandwidth // pfx = new PERS_FILE_XFER; pfx->init(fip, false); fip->pers_file_xfer = pfx; retval = pers_xfers->insert(fip->pers_file_xfer); //if (retval) gstate.report_project_error( *fip->result, retval, "" ); // ******* action = true; } else if (fip->upload_when_present && fip->status == FILE_PRESENT && !fip->uploaded) { // Set up the persistent file transfer object. // This will start the upload when there is available bandwidth // pfx = new PERS_FILE_XFER; pfx->init(fip, true); fip->pers_file_xfer = pfx; retval = pers_xfers->insert(fip->pers_file_xfer); action = true; } } for (i=0; ipers_file_xfers.size(); i++) { pfx = pers_xfers->pers_file_xfers[i]; // If the transfer finished, remove the PERS_FILE_XFER object // from the set and delete it // if (pfx->xfer_done) { pfx->fip->pers_file_xfer = NULL; pers_xfers->remove(pfx); delete pfx; i--; action = true; } } return action; }