/usr/include/boinc/backend_lib.h is in boinc-dev 7.0.24+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 | // This file is part of BOINC.
// http://boinc.berkeley.edu
// Copyright (C) 2008 University of California
//
// BOINC is free software; you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License
// as published by the Free Software Foundation,
// either version 3 of the License, or (at your option) any later version.
//
// BOINC is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
// See the GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
#ifndef H_BACKEND_LIB
#define H_BACKEND_LIB
#include <limits.h>
#include "crypt.h"
#include "sched_config.h"
#include "boinc_db.h"
extern int add_signatures(char*, R_RSA_PRIVATE_KEY&);
extern int remove_signatures(char*);
extern int process_result_template(
char* result_template,
R_RSA_PRIVATE_KEY& key,
char* base_filename,
SCHED_CONFIG&
);
extern int read_file(FILE*, char* buf);
extern int read_filename(const char* path, char* buf, int len);
extern void initialize_result(DB_RESULT&, DB_WORKUNIT&);
extern int create_result(
WORKUNIT&,
char* result_template_filename,
char* suffix,
R_RSA_PRIVATE_KEY& key,
SCHED_CONFIG& config,
char* query_string=0,
int priority_increase=0
);
extern int create_result_ti(
TRANSITIONER_ITEM&,
char* result_template_filename,
char* suffix,
R_RSA_PRIVATE_KEY& key,
SCHED_CONFIG& config,
char* query_string=0,
int priority_increase=0
);
extern int create_work(
DB_WORKUNIT& wu,
const char* wu_template,
const char* result_template_filename,
const char* result_template_filepath,
const char** infiles,
int ninfiles,
SCHED_CONFIG&,
const char* command_line = NULL,
const char* additional_xml = NULL
);
extern int stage_file(const char*, bool);
// the following functions return XML that can be put in
// scheduler replies to do file operations
//
extern int put_file_xml(
const char* file_name, vector<const char*> urls,
const char* md5, double nbytes, double report_deadline,
char* buf
);
extern int get_file_xml(
const char* file_name, vector<const char*> urls,
double max_nbytes,
double report_deadline,
bool generate_upload_certificate,
R_RSA_PRIVATE_KEY& key,
char* buf
);
extern int delete_file_xml(
const char* file_name,
char* buf
);
// the following 3 functions are for programs other than the scheduler
// to do file operations.
// They work by creating MSG_TO_HOST records in the DB,
// containing the needed XML
//
extern int create_put_file_msg(
int host_id, const char* file_name, vector<const char*> urls,
const char* md5, double nbytes, double report_deadline
);
extern int create_get_file_msg(
int host_id, const char* file_name, vector<const char*> urls,
double max_nbytes,
double report_deadline,
bool generate_upload_certificate,
R_RSA_PRIVATE_KEY& key
);
extern int create_delete_file_msg(
int host_id,
const char* file_name
);
// cancel jobs from min_id to max_id inclusive
//
extern int cancel_jobs(int min_id, int max_id);
#endif
|