41 int *bucketList,
int agent_pk,
int nomosagent_pk,
int bucketpool_pk)
43 char *fcnName =
"writeBuckets";
48 if (
debug) printf(
"debug: %s:%s() pfile: %d, uploadtree_pk: %d\n", __FILE__, fcnName, pfile_pk, uploadtree_pk);
58 if (
processed(pgConn, agent_pk, nomosagent_pk, pfile_pk, uploadtree_pk, bucketpool_pk, *bucketList))
60 snprintf(sql,
sizeof(sql),
61 "UPDATE bucket_file set bucket_fk = %d from bucket_def where pfile_fk = %d and \ 62 bucket_fk= bucket_pk and bucket_def.bucketpool_fk = %d;",
63 *bucketList, pfile_pk, bucketpool_pk);
67 snprintf(sql,
sizeof(sql),
68 "insert into bucket_file (bucket_fk, pfile_fk, agent_fk, nomosagent_fk) values(%d,%d,%d,%d)",
69 *bucketList, pfile_pk, agent_pk, nomosagent_pk);
72 printf(
"%s(%d): %s\n", __FILE__, __LINE__, sql);
73 result = PQexec(pgConn, sql);
75 if ((result==0) || ((PQresultStatus(result) != PGRES_COMMAND_OK) &&
76 (strncmp(
"23505", PQresultErrorField(result, PG_DIAG_SQLSTATE),5))))
78 printf(
"ERROR: %s.%s().%d: Failed to add bucket to bucket_file.\n",
79 __FILE__,fcnName, __LINE__);
88 snprintf(sql,
sizeof(sql),
89 "insert into bucket_container (bucket_fk, uploadtree_fk, agent_fk, nomosagent_fk) \ 90 values(%d,%d,%d,%d)", *bucketList, uploadtree_pk, agent_pk, nomosagent_pk);
92 printf(
"%s(%d): %s\n", __FILE__, __LINE__, sql);
94 result = PQexec(pgConn, sql);
95 if ((PQresultStatus(result) != PGRES_COMMAND_OK) &&
96 (strncmp(
"23505", PQresultErrorField(result, PG_DIAG_SQLSTATE),5)))
99 printf(
"ERROR: %s.%s().%d: Failed to add bucket to bucket_file. %s\n: %s\n",
100 __FILE__,fcnName, __LINE__,
101 PQresultErrorMessage(result), sql);
107 if (result) PQclear(result);
112 if (
debug) printf(
"%s:%s() returning rv=%d\n", __FILE__, fcnName, rv);
int fo_checkPQresult(PGconn *pgConn, PGresult *result, char *sql, char *FileID, int LineNumb)
Check the result status of a postgres SELECT.
PGconn * pgConn
Database connection.
FUNCTION int writeBuckets(PGconn *pgConn, int pfile_pk, int uploadtree_pk, int *bucketList, int agent_pk, int nomosagent_pk, int bucketpool_pk)
Write bucket results to either db (bucket_file, bucket_container) or stdout.
void fo_scheduler_heart(int i)
This function must be called by agents to let the scheduler know they are alive and how many items th...
FUNCTION int processed(PGconn *pgConn, int agent_pk, int nomos_agent_pk, int pfile_pk, int uploadtree_pk, int bucketpool_pk, int bucket_pk)
Has this pfile or uploadtree_pk already been bucket processed? This only works if the bucket has been...