2010-11-14 15:13:57 +11:00
|
|
|
/*
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
copy of this software and associated documentation files (the "Software"), to
|
|
|
|
deal in the Software without restriction, including without limitation the
|
|
|
|
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
|
|
sell copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
2013-07-18 23:59:14 +10:00
|
|
|
SOFTWARE.
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2014-06-20 22:51:18 +10:00
|
|
|
Original idea International Business Machines redook "Using ADSM to Back Up
|
|
|
|
Databases", published 1998.
|
|
|
|
|
|
|
|
Some adaption from HPC2N, Umeå University, Sweden, 2006/7
|
|
|
|
|
|
|
|
This version Copyright (c) 2012-2014 by Deon George
|
2013-07-16 09:58:53 +10:00
|
|
|
*/
|
2010-11-14 15:13:57 +11:00
|
|
|
|
|
|
|
/* Enable Large File Support stuff */
|
|
|
|
#define _FILE_OFFSET_BITS 64
|
|
|
|
#define _LARGEFILE_SOURCE 1
|
|
|
|
#define _LARGE_FILES 1
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <limits.h>
|
|
|
|
|
|
|
|
#include "dsmrc.h"
|
|
|
|
#include "dsmapitd.h"
|
|
|
|
#include "dsmapifp.h"
|
2013-11-05 16:11:45 +11:00
|
|
|
#include "tsmpipe.h"
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
int verbose=0;
|
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
int copy_env(const char *from, const char *to) {
|
|
|
|
char *e;
|
|
|
|
char n[PATH_MAX+1];
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
e = getenv(from);
|
|
|
|
if (!e) {
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: Environment variable %s not set\n",__func__,from);
|
2013-07-18 23:59:14 +10:00
|
|
|
return 0;
|
|
|
|
}
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
n[PATH_MAX] = '\0';
|
|
|
|
snprintf(n, PATH_MAX, "%s=%s", to, e);
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
if (putenv(strdup(n))) {
|
|
|
|
perror("tsmpipe: Setting up environment");
|
|
|
|
return 0;
|
|
|
|
}
|
2010-11-14 15:13:57 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
return 1;
|
2010-11-14 15:13:57 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
void usage(void) {
|
2013-07-18 23:59:14 +10:00
|
|
|
fprintf(stderr,
|
2018-03-21 00:13:36 +11:00
|
|
|
"tsmpipe %d.%d.%d.%d, usage:\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
"\n"
|
2016-07-07 15:00:21 +10:00
|
|
|
"tsmpipe [-i|-p]|[[-A|-B|-U] [-c|-x|-d|-g|-t] -s fsname -f filepath [-l len] ...]\n"
|
2016-06-23 15:10:58 +10:00
|
|
|
" -i Show session information\n"
|
|
|
|
" -p Set Password\n"
|
2014-06-20 22:51:18 +10:00
|
|
|
" -A, -B and -U are mutually exclusive:\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -A Use Archive objects\n"
|
|
|
|
" -B Use Backup objects\n"
|
2014-06-20 22:51:18 +10:00
|
|
|
" -U Update FS with utilisation info\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -c, -x, -d and -t are mutually exclusive:\n"
|
|
|
|
" -c Create: Read from stdin and store in TSM\n"
|
|
|
|
" -x eXtract: Recall from TSM and write to stdout\n"
|
|
|
|
" -d Delete: Delete object from TSM\n"
|
2016-07-07 15:00:21 +10:00
|
|
|
" -g purGe: Active Delete object from TSM\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -t lisT: Print filelist to stdout\n"
|
|
|
|
" -s and -f are required arguments for (-A/ -B operations):\n"
|
2014-06-20 22:51:18 +10:00
|
|
|
" -s fsname Name of filespace in TSM\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -f filepath Path to file within filesystem in TSM\n"
|
2015-09-23 15:07:22 +10:00
|
|
|
" -F Friendly output, only valid for -t\n"
|
2014-01-24 16:49:50 +11:00
|
|
|
" -l length Length of object to store. If guesstimating, too large\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" is better than too small\n"
|
2014-06-20 22:51:18 +10:00
|
|
|
" -L length Length of object to store. But also update the FS with\n"
|
|
|
|
" the size of the object sent\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -D desc Description of archive object\n"
|
2013-11-07 15:10:18 +11:00
|
|
|
" -P pitdate PITDate (mmddYYYY[:HHMMSS]) (BACKUP Objects)\n"
|
|
|
|
" -n insdate Insert Date lower bound (mmddYYYY[:HHMMSS]) (ARCHIVE Objects)\n"
|
|
|
|
" -N insdate Insert Date upper bound (mmddYYYY[:HHMMSS]) (ARCHIVE Objects)\n"
|
|
|
|
" -e expdate Expire Date lower bound (mmddYYYY[:HHMMSS]) (ARCHIVE Objects)\n"
|
|
|
|
" -E expdate Expire Date upper bound (mmddYYYY[:HHMMSS]) (ARCHIVE Objects)\n"
|
2013-07-18 23:59:14 +10:00
|
|
|
" -O options Extra options to pass to dsmInitEx\n"
|
2013-11-07 18:06:56 +11:00
|
|
|
#ifdef USE_DIGEST
|
2014-01-24 16:49:50 +11:00
|
|
|
" -m digest Calculate digest for data being stored in TSM, eg: md5, sha1...\n"
|
2013-11-07 18:06:56 +11:00
|
|
|
#endif
|
2013-07-18 23:59:14 +10:00
|
|
|
" -v Verbose. More -v's gives more verbosity\n"
|
2014-06-20 22:51:18 +10:00
|
|
|
" -V Verbose information on TSM transfer\n"
|
2018-03-21 00:13:36 +11:00
|
|
|
,TSMPIPE_VERSION,TSMPIPE_RELEASE,TSMPIPE_LEVEL,TSMPIPE_SUBLEVEL);
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2016-06-23 15:10:58 +10:00
|
|
|
exit(0);
|
2010-11-14 15:13:57 +11:00
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
void usage_action(void) {
|
2016-06-23 15:10:58 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Must give one of -i, -p, -c, -x, -d, -t",1);
|
2013-11-07 15:10:18 +11:00
|
|
|
}
|
|
|
|
|
2010-11-14 15:13:57 +11:00
|
|
|
int main(int argc, char *argv[]) {
|
2013-07-18 23:59:14 +10:00
|
|
|
int c;
|
|
|
|
extern int optopt;
|
|
|
|
extern char *optarg;
|
2013-11-07 15:10:18 +11:00
|
|
|
int action=0;
|
|
|
|
char *space=NULL, *filename=NULL, *lenstr=NULL, *desc=NULL, *pitdate=NULL, *options=NULL, *expdate_low=NULL, *expdate_high=NULL, *insdate_low=NULL, *insdate_high=NULL;
|
2014-06-20 22:51:18 +10:00
|
|
|
dsBool_t summary=bFalse;
|
2015-09-23 15:07:22 +10:00
|
|
|
dsBool_t friendly=bFalse;
|
2013-07-18 23:59:14 +10:00
|
|
|
off_t length;
|
|
|
|
dsUint32_t dsmHandle;
|
2013-11-07 15:10:18 +11:00
|
|
|
dsmQueryType qType=0xff; // We set this to an unlikely value, it should be set correctly via our getopt
|
|
|
|
qryArchiveData qaData;
|
|
|
|
qryBackupData qbData;
|
|
|
|
dsmObjName objName;
|
|
|
|
int rc=0;
|
2014-06-20 22:51:18 +10:00
|
|
|
double stored=0;
|
2013-11-07 18:06:56 +11:00
|
|
|
#ifdef USE_DIGEST
|
|
|
|
char *digest=NULL;
|
|
|
|
#endif
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2016-07-07 15:00:21 +10:00
|
|
|
while ((c = getopt(argc, argv, "hiABcxdtUvVe:E:f:Fgl:L:m:n:N:s:D:O:pP:")) != -1) {
|
2013-07-18 23:59:14 +10:00
|
|
|
switch(c) {
|
|
|
|
case 'h': usage(); break;
|
2013-11-07 15:10:18 +11:00
|
|
|
case 'A': qType = qtArchive; break;
|
|
|
|
case 'B': qType = qtBackup; break;
|
|
|
|
|
|
|
|
case 'i': if (action != 0) usage_action(); action = ACTION_INFO; break;
|
2016-06-23 15:10:58 +10:00
|
|
|
case 'p': if (action != 0) usage_action(); action = ACTION_PASSWORD; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
case 'c': if (action != 0) usage_action(); action = ACTION_CREATE; break;
|
|
|
|
case 'x': if (action != 0) usage_action(); action = ACTION_EXTRACT; break;
|
|
|
|
case 'd': if (action != 0) usage_action(); action = ACTION_DELETE; break;
|
2016-07-07 15:00:21 +10:00
|
|
|
case 'g': if (action != 0) usage_action(); action = ACTION_PURGE; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
case 't': if (action != 0) usage_action(); action = ACTION_LIST; break;
|
2014-06-20 22:51:18 +10:00
|
|
|
case 'U': if (action != 0) usage_action(); action = ACTION_UPDATE; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
case 'v': verbose++; break;
|
2014-06-20 22:51:18 +10:00
|
|
|
case 'V': summary = bTrue; break;
|
2013-07-18 23:59:14 +10:00
|
|
|
case 's': space = optarg; break;
|
|
|
|
case 'f': filename = optarg; break;
|
2015-09-23 15:07:22 +10:00
|
|
|
case 'F': friendly = bTrue; break;
|
2013-07-18 23:59:14 +10:00
|
|
|
case 'l': lenstr = optarg; break;
|
2014-06-20 22:51:18 +10:00
|
|
|
case 'L': lenstr = optarg; if (action != ACTION_CREATE) usage_action(); action = ACTION_CREATE_UPDATE; break;
|
2013-07-18 23:59:14 +10:00
|
|
|
case 'D': desc = optarg; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2013-11-07 18:06:56 +11:00
|
|
|
#ifdef USE_DIGEST
|
|
|
|
case 'm': digest = optarg; break;
|
|
|
|
#endif
|
2013-07-18 23:59:14 +10:00
|
|
|
case 'O': options = optarg; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
case 'P': pitdate = optarg; break;
|
2013-11-07 15:10:18 +11:00
|
|
|
case 'e': expdate_low = optarg; break;
|
|
|
|
case 'E': expdate_high = optarg; break;
|
|
|
|
case 'n': insdate_low = optarg; break;
|
|
|
|
case 'N': insdate_high = optarg; break;
|
2013-07-18 23:59:14 +10:00
|
|
|
|
|
|
|
case ':':
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: Option -%c requires an operand\n",__func__,optopt);
|
2013-07-18 23:59:14 +10:00
|
|
|
exit(1);
|
|
|
|
case '?':
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: Unrecognized option: -%c\n",__func__,optopt);
|
2013-07-18 23:59:14 +10:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
// Arguement Validation
|
|
|
|
if (action == 0) {
|
2016-06-23 15:10:58 +10:00
|
|
|
usage_action();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (action == ACTION_PASSWORD) {
|
|
|
|
rc = tsm_setpassword(options);
|
|
|
|
|
|
|
|
if (! rc)
|
|
|
|
debugLog(0,__func__,"ERROR: Operation Failed",3);
|
|
|
|
else
|
|
|
|
debugLog(1,__func__,"Operation Success",0);
|
|
|
|
|
|
|
|
exit(0);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2015-09-23 15:07:22 +10:00
|
|
|
if (action != ACTION_LIST && friendly) {
|
|
|
|
debugLog(0,__func__,"ERROR: -F can only be used with -t",1);
|
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (pitdate && qType != qtBackup) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: -P can only be used with -B",1);
|
2013-11-05 00:13:12 +11:00
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if ((insdate_low|| insdate_high || expdate_low || expdate_high) && qType != qtArchive) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: -e, -E, -n, -N can only be used with -A",1);
|
2013-11-07 15:10:18 +11:00
|
|
|
}
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (action != ACTION_INFO) {
|
2013-07-18 23:59:14 +10:00
|
|
|
if (! space) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Must give -s filespacename",1);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2014-06-20 22:51:18 +10:00
|
|
|
if (! filename && action != ACTION_UPDATE) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Must give -f filename",1);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2014-06-20 22:51:18 +10:00
|
|
|
if ((action == ACTION_CREATE || action == ACTION_CREATE_UPDATE || action == ACTION_UPDATE) && ! lenstr) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Must give -l|-L length with -c | -u",1);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2014-06-20 22:51:18 +10:00
|
|
|
if ((action != ACTION_CREATE && action != ACTION_CREATE_UPDATE && action != ACTION_UPDATE) && lenstr) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: -l|-L length useless without -c | -u",1);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (desc && qType != qtArchive) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: -D desc useless without -A",1);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-07 15:00:21 +10:00
|
|
|
if (action == ACTION_PURGE && qType != qtBackup) {
|
|
|
|
debugLog(0,__func__,"ERROR: -g can only be used with -B",1);
|
|
|
|
}
|
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
/* Let the TSM api get the signals */
|
|
|
|
signal(SIGPIPE, SIG_IGN);
|
|
|
|
signal(SIGINT, SIG_IGN);
|
|
|
|
signal(SIGUSR1, SIG_IGN);
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (getenv("DSM_DIR") && ((! copy_env("DSM_DIR", "DSMI_DIR")) || (! copy_env("DSM_CONFIG", "DSMI_CONFIG"))))
|
2013-07-18 23:59:14 +10:00
|
|
|
exit(1);
|
|
|
|
|
|
|
|
// OK, we are ready to talk to TSM
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(1,__func__,"Create TSM session",0);
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2016-06-23 15:10:58 +10:00
|
|
|
dsmHandle = tsm_initsess(options,NULL);
|
2013-11-07 15:10:18 +11:00
|
|
|
if (! dsmHandle)
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Unable to create TSM session?",2);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"Session Initiated",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
|
|
|
switch (action) {
|
|
|
|
// Show our session information
|
|
|
|
case ACTION_INFO:
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"INFO Operation",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
|
|
|
rc = tsm_sessioninfo(dsmHandle);
|
|
|
|
break;
|
|
|
|
|
|
|
|
// If we are backing up or archiving
|
|
|
|
case ACTION_CREATE:
|
2014-06-20 22:51:18 +10:00
|
|
|
case ACTION_CREATE_UPDATE:
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"CREATE Operation",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
|
|
|
length = atof(lenstr);
|
|
|
|
if (length <= 0)
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Provide positive length, overestimate if guessing",1);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2013-11-07 18:06:56 +11:00
|
|
|
#ifdef USE_DIGEST
|
2014-08-26 00:21:53 +10:00
|
|
|
stored = tsm_sendfile(dsmHandle,space,filename,length,desc,((qType == qtArchive) ? stArchiveMountWait : stBackupMountWait),((action == ACTION_CREATE_UPDATE && qType==qtBackup) ? bTrue : bFalse),summary,digest);
|
2013-11-07 18:06:56 +11:00
|
|
|
#else
|
2014-08-26 00:21:53 +10:00
|
|
|
stored = tsm_sendfile(dsmHandle,space,filename,length,desc,((qType == qtArchive) ? stArchiveMountWait : stBackupMountWait),((action == ACTION_CREATE_UPDATE && qType==qtBackup) ? bTrue : bFalse),summary);
|
2013-11-07 18:06:56 +11:00
|
|
|
#endif
|
2014-06-20 22:51:18 +10:00
|
|
|
rc = stored ? 1 : 0;
|
|
|
|
|
|
|
|
if (rc && action == ACTION_CREATE_UPDATE && qType==qtBackup) {
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"UPDATE FS Operation",0);
|
2014-06-20 22:51:18 +10:00
|
|
|
rc = tsm_updatefs(dsmHandle,space,stored);
|
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ACTION_DELETE:
|
2016-07-07 15:00:21 +10:00
|
|
|
case ACTION_PURGE:
|
2013-11-07 15:10:18 +11:00
|
|
|
case ACTION_LIST:
|
|
|
|
case ACTION_EXTRACT:
|
|
|
|
memset(&qaData,0x00,sizeof(qryArchiveData));
|
|
|
|
memset(&qbData,0x00,sizeof(qryBackupData));
|
|
|
|
objName = dsmNameToObjname(space,filename);
|
|
|
|
|
|
|
|
// Setup our Query Object
|
|
|
|
switch (qType) {
|
|
|
|
case qtBackup:
|
|
|
|
qbData.stVersion = qryBackupDataVersion;
|
|
|
|
qbData.objName = &objName;
|
|
|
|
qbData.owner = "";
|
2013-11-11 13:49:46 +11:00
|
|
|
|
|
|
|
switch (action) {
|
2016-07-07 15:00:21 +10:00
|
|
|
case ACTION_PURGE:
|
2013-11-11 13:49:46 +11:00
|
|
|
case ACTION_DELETE:
|
|
|
|
qbData.objState = DSM_ACTIVE;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ACTION_EXTRACT:
|
|
|
|
qbData.objState = pitdate ? DSM_ANY_MATCH : DSM_ACTIVE;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ACTION_LIST:
|
|
|
|
qbData.objState = DSM_ANY_MATCH;
|
|
|
|
break;
|
|
|
|
}
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2016-07-07 15:00:21 +10:00
|
|
|
if (action == ACTION_DELETE || action == ACTION_PURGE || ! pitdate) {
|
2013-11-07 15:10:18 +11:00
|
|
|
qbData.pitDate.year = DATE_MINUS_INFINITE;
|
|
|
|
} else {
|
|
|
|
qbData.pitDate = dsmStrToDate(pitdate);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case qtArchive:
|
|
|
|
qaData.stVersion = qryArchiveDataVersion;
|
|
|
|
qaData.objName = &objName;
|
|
|
|
qaData.owner = "";
|
|
|
|
qaData.descr = desc ? desc : "*";
|
2013-11-05 16:11:45 +11:00
|
|
|
|
|
|
|
qaData.insDateLowerBound.year = DATE_MINUS_INFINITE;
|
|
|
|
qaData.insDateUpperBound.year = DATE_PLUS_INFINITE;
|
|
|
|
qaData.expDateLowerBound.year = DATE_MINUS_INFINITE;
|
|
|
|
qaData.expDateUpperBound.year = DATE_PLUS_INFINITE;
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (insdate_low)
|
|
|
|
qaData.insDateLowerBound = dsmStrToDate(insdate_low);
|
2013-11-05 16:11:45 +11:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (insdate_high)
|
|
|
|
qaData.insDateUpperBound = dsmStrToDate(insdate_high);
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (expdate_low)
|
|
|
|
qaData.expDateLowerBound = dsmStrToDate(expdate_low);
|
2013-07-18 23:59:14 +10:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (expdate_high)
|
|
|
|
qaData.expDateUpperBound = dsmStrToDate(expdate_high);
|
|
|
|
break;
|
2013-11-05 16:11:45 +11:00
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
default:
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: UNKNOWN Type %d\n",__func__,qType);
|
2013-11-07 15:10:18 +11:00
|
|
|
exit(2);
|
2013-11-05 16:11:45 +11:00
|
|
|
}
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
switch (action) {
|
|
|
|
case ACTION_DELETE:
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"DELETE Operation",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
rc = tsm_deletefile(dsmHandle,qType,qaData,qbData);
|
|
|
|
break;
|
|
|
|
|
2016-07-07 15:00:21 +10:00
|
|
|
case ACTION_PURGE:
|
|
|
|
debugLog(2,__func__,"PURGE Operation",0);
|
|
|
|
/** We use qtReserved8 to let tsm_deletefile() know that we want to purge - this will break a future API **/
|
|
|
|
rc = tsm_deletefile(dsmHandle,qtReserved8,qaData,qbData);
|
|
|
|
break;
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
case ACTION_EXTRACT:
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"EXTRACT Operation",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
rc = tsm_restorefile(dsmHandle,qType,qaData,qbData);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ACTION_LIST:
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(2,__func__,"LIST Operation",0);
|
2015-09-23 15:07:22 +10:00
|
|
|
rc = tsm_listfile(dsmHandle,qType,qaData,qbData,friendly);
|
2013-11-07 15:10:18 +11:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: Action not yet programmed for %d\n",__func__,action);
|
2013-11-07 15:10:18 +11:00
|
|
|
exit(2);
|
2013-11-05 16:11:45 +11:00
|
|
|
}
|
2013-11-07 15:10:18 +11:00
|
|
|
break;
|
|
|
|
|
2014-06-20 22:51:18 +10:00
|
|
|
case ACTION_UPDATE:
|
|
|
|
length = atof(lenstr);
|
|
|
|
if (length <= 0)
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Provide positive length",1);
|
2014-06-20 22:51:18 +10:00
|
|
|
|
|
|
|
rc = tsm_updatefs(dsmHandle,space,length);
|
|
|
|
break;
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
default:
|
2015-09-23 11:36:02 +10:00
|
|
|
fprintf(stderr,"%s: UNKNOWN Operation %d",__func__,action);
|
2013-11-07 15:10:18 +11:00
|
|
|
exit(2);
|
2013-07-18 23:59:14 +10:00
|
|
|
}
|
|
|
|
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(1,__func__,"Terminate TSM session",0);
|
2013-11-07 15:10:18 +11:00
|
|
|
|
2013-07-18 23:59:14 +10:00
|
|
|
dsmTerminate(dsmHandle);
|
|
|
|
|
2013-11-07 15:10:18 +11:00
|
|
|
if (! rc)
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(0,__func__,"ERROR: Operation Failed",3);
|
2013-11-07 15:10:18 +11:00
|
|
|
else
|
2015-09-23 11:36:02 +10:00
|
|
|
debugLog(1,__func__,"Operation Success",0);
|
2013-07-18 23:59:14 +10:00
|
|
|
|
|
|
|
return 0;
|
2010-11-14 15:13:57 +11:00
|
|
|
}
|