Logo Search packages:      
Sourcecode: maxdb-7.5.00 version File versions

vcn32.cpp

/* @lastChanged: "1998-06-26  9:57"
 *
 * @filename:    vcn32.cpp
 * @purpose:     "backup history management"
 * @release:     7.1.0.0
 * @see:         "-.-"
 *
 * @copyright:   (c) 1998-2004 SAP AG-2004"
 *
 * ==================================================================
 *
 * responsible:   MartinR, TiloH
 *
 * created:       1998-05-25 by MartinR
 *
 * purpose:       basic module for backup history
 *                               
 * ==================================================================



    ========== licence begin  GPL
    Copyright (c) 1998-2004 SAP AG

    This program is free software; you can redistribute it and/or
    modify it under the terms of the GNU General Public License
    as published by the Free Software Foundation; either version 2
    of the License, or (at your option) any later version.

    This program 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
    ========== licence end



 */

/* ------------------------------------------------------------------
 * list of functions:
 *
 * cn32_AllocHistorySession
 * cn32_HistorySession
 * cn32_AllocEBIDList
 * cn32_EBIDList
 *
 * cn32FreeEBIDList
 * cn32BackupHistoryOpen
 * cn32BackupHistoryList
 * cn32BackupHistoryListNext
 * cn32BackupHistoryClose
 * cn32BackupHistoryDate
 * cn32GetEBIDs
 * cn32ListNextEBIDs
 * cn32ForgetEBIDs
 * cn32AnalyzeLogBackup
 * ------------------------------------------------------------------
 */

// ------------------------------------------------------------------
// includes
// ------------------------------------------------------------------

#include <stdio.h>
#include <stdlib.h>

#include "SAPDB/DBM/Srv/BackupHistory/DBMSrvBHist_History.hpp"
#include "SAPDB/DBM/Srv/BackupHistory/DBMSrvBHist_EBIDList.hpp"
#include "hcn32.h"
#include "hcn90.h"


// PRIVATE FUNCTION cn32_AllocHistorySession
// ------------------------------------------------------------------
// purpose: allocate new memory for backup session
//
static tcn00_Error cn32_AllocHistorySession (
      VControlDataT                 *  vcontrol,
      char                          *  replyData,
      int                           *  replyLen,
      DBMSrvBHist_History           *& pHistorySession )
{
    tcn00_Error rc=OK_CN00;

    if(0==pHistorySession)
        pHistorySession=new DBMSrvBHist_History();

    if(0==pHistorySession)
        rc=cn90AnswerIError(replyData, replyLen, ERR_MEM_CN00);
    else
        vcontrol->pHistorySession=pHistorySession;

    return rc;
} // end cn32_AllocHistorySession

// PRIVATE FUNCTION cn32_HistorySession
// ------------------------------------------------------------------
// purpose: get the history session from global struct and check
//
static tcn00_Error cn32_HistorySession(
        VControlDataT                 * vcontrol,
        char                          * replyData,
        int                           * replyLen,
        DBMSrvBHist_History          *& pHistorySession)
{
    tcn00_Error rc=OK_CN00;

    pHistorySession=vcontrol->pHistorySession;

    // is there no active history session?
    if(0==pHistorySession)
        rc=cn90AnswerIError(replyData, replyLen, ERR_NOHISTORYSESSION_CN00);

    return rc;
} // end cn32_HistorySession

// PUBLIC FUNCTION cn32FreeHistorySession
// ------------------------------------------------------------------
// purpose: frees the history session from the VControlDataT structure
//
void cn32FreeHistorySession(VControlDataT * vcontrol)
{
    if(0!=vcontrol && 0!=vcontrol->pHistorySession)
    {
        delete vcontrol->pHistorySession;
        vcontrol->pHistorySession=0;
    }
} // end cn32FreeHistorySession

// PRIVATE FUNCTION cn32_AllocEBIDList
// ------------------------------------------------------------------
// purpose: allocate new memory for a EBID list
//
static tcn00_Error cn32_AllocEBIDList(VControlDataT         * vcontrol,
                                      char                  * replyData,
                                      int                   * replyLen,
                                      DBMSrvBHist_EBIDList *& pEBIDList)
{
    tcn00_Error rc=OK_CN00;

    if(0!=vcontrol)
    {
        if(0==pEBIDList)
            pEBIDList=new DBMSrvBHist_EBIDList();

        if(0==pEBIDList)
            cn90AnswerIError(replyData, replyLen, ERR_MEM_CN00);
        else
            vcontrol->pEBIDList=pEBIDList;
    }

    return rc;
} // end cn32_AllocEBIDList

// PRIVATE FUNCTION cn32_EBIDList
// ------------------------------------------------------------------
// purpose: get the EBID list from global struct and check
//
static tcn00_Error cn32_EBIDList(VControlDataT        *  vcontrol,
                                 char                 *  replyData,
                                 int                  *  replyLen,
                                 DBMSrvBHist_EBIDList *& pEBIDList)
{
    tcn00_Error rc=OK_CN00;

    pEBIDList=vcontrol->pEBIDList;

    // is there an active history session?
    if(0==pEBIDList)
        rc=cn90AnswerIError(replyData, replyLen, ERR_NOEBIDLIST_CN00);

    return rc;
} // end cn32_EBIDList

// PUBLIC FUNCTION cn32FreeEBIDList
// ------------------------------------------------------------------
// purpose: frees the EBID List from the VControlDataT structure
//
void cn32FreeEBIDList(VControlDataT * vcontrol)
{
    if(0!=vcontrol && 0!=vcontrol->pEBIDList)
    {
        delete vcontrol->pEBIDList;
        vcontrol->pEBIDList=0;
    }
} // end cn32FreeEBIDList

/* SPECIFICATION PUBLIC FUNCTIONS
 * ------------------------------------------------------------------
 */

// PUBLIC FUNCTION cn32BackupHistoryOpen
// ------------------------------------------------------------------
// purpose: open backup history session and read contents
//
//
tcn00_Error cn32BackupHistoryOpen(
      VControlDataT * vcontrol,
      CommandT      * command,
      char          * replyData,
      int           * replyLen,
      int             replyLenMax)
{
    tcn00_Error           rc=OK_CN00; 
    DBMSrvBHist_History * pHistorySession=0;

    rc=cn32_HistorySession(vcontrol, replyData, replyLen, pHistorySession);

    if(OK_CN00==rc)
    {
        cn32FreeHistorySession(vcontrol);
        pHistorySession=0; // (*pHistorySession) was freed one line above, so don't reference to it anymore
    }

    rc=cn32_AllocHistorySession(vcontrol, replyData, replyLen, pHistorySession);

    if(OK_CN00==rc)
        rc=pHistorySession->BackupHistoryOpen(vcontrol, command, replyData, replyLen, replyLenMax);

    if(OK_CN00!=rc)
        cn32FreeHistorySession(vcontrol);

    return rc;
} // end cn32BackupHistoryOpen

// PUBLIC FUNCTION cn32BackupHistoryList
// ------------------------------------------------------------------
// purpose: list contents of history
//
tcn00_Error cn32BackupHistoryList(
      VControlDataT * vcontrol,
      CommandT      * command,
      char          * replyData,
      int           * replyLen,
      int             replyLenMax)
{
    tcn00_Error           rc=OK_CN00;

    DBMSrvBHist_History * pHistorySession=0;

    // get or open the history session
    rc=cn32_HistorySession(vcontrol, replyData, replyLen, pHistorySession);

    if(ERR_NOHISTORYSESSION_CN00==rc)
    {
        rc=cn32BackupHistoryOpen(vcontrol, command, replyData, replyLen, replyLenMax);

        if(OK_CN00==rc)
            rc=cn32_HistorySession(vcontrol, replyData, replyLen, pHistorySession);
    }

    if(OK_CN00==rc)
        rc=pHistorySession->BackupHistoryList(vcontrol, command, replyData, replyLen, replyLenMax);

    return rc;
} // end cn32BackupHistoryList

// PUBLIC FUNCTION cn32BackupHistoryListNext
// ------------------------------------------------------------------
// purpose: continue listing contents of history
//
tcn00_Error cn32BackupHistoryListNext(
      VControlDataT * vcontrol,
      CommandT      * command,
      char          * replyData,
      int           * replyLen,
      int             replyLenMax)
{
    tcn00_Error           rc=OK_CN00;
    DBMSrvBHist_History * pHistorySession=0;

    // get the history session
    rc=cn32_HistorySession(vcontrol, replyData, replyLen, pHistorySession);

    if(OK_CN00==rc)
        rc=pHistorySession->BackupHistoryListNext(vcontrol, command, replyData, replyLen, replyLenMax);

    return rc;
} // end cn32BackupHistoryListNext

const char * LongHelp_GetEBIDS_cn32=
    "@command backup_ext_ids_get You inquire external backup IDs and other "
        "information about backups for a database instance that are currently "
        "stored in a backup tool. Use the command backup_ext_ids_list to "
        "display the inquired information."
    "@preconditions You have the DBM operator authorization Backup or DBInfoRead."
    "@syntax backup_ext_ids_get <medium> [<database_name>] [<database_server>]"
        "@param <medium>        Name of the backup medium; this must be defined "
            "beforehand with the help of the command medium_put"
        "@param <database_name> Name of the database instance from which the "
            "backups were created"
        "@param <database_server>   Name of the server on which the backups were created"
    "@reply OK";

// PUBLIC FUNCTION cn32BackupHistoryClose
// ------------------------------------------------------------------
// purpose: close backup history session
//
tcn00_Error cn32BackupHistoryClose(
      VControlDataT * vcontrol,
      CommandT      * command,
      char          * replyData,
      int           * replyLen,
      int             replyLenMax)
{
    tcn00_Error           rc=OK_CN00;
    DBMSrvBHist_History * pHistorySession=0;

    rc=cn32_HistorySession(vcontrol, replyData, replyLen, pHistorySession);

    if(OK_CN00==rc)
    {
        pHistorySession->BackupHistoryClose(vcontrol, command, replyData, replyLen, replyLenMax);
        cn32FreeHistorySession(vcontrol);
    }

    return rc;
} // end cn32BackupHistoryClose

// PUBLIC FUNCTION cn32BackupHistoryDate
// ------------------------------------------------------------------
// purpose: get date of history file
//
tcn00_Error cn32BackupHistoryDate (
      VControlDataT * vcontrol,
      CommandT      * command,
      char          * replyData,
      int           * replyLen,
      int             replyLenMax )
{
    tcn00_Error         rc=OK_CN00;
    DBMSrvBHist_History TempHistory;

    rc=TempHistory.BackupHistoryDate(vcontrol, command, replyData, replyLen, replyLenMax);

    return rc;
} // end cn32BackupHistoryDate

// PUBLIC FUNCTION cn32GetEBIDs
// ------------------------------------------------------------------
// purpose: queries an external backup tool for a list of external
//          backup IDs (EBIDs). The tool is determined through a
//          backup medium and the list consists of EBIDs for backups
//          which are currently available.
//
tcn00_Error cn32GetEBIDs(VControlDataT * vcontrol,
                         CommandT      * command,
                         char          * replyData,
                         int           * replyLen,
                         int             replyLenMax)
{
    tcn00_Error            rc=OK_CN00;
    DBMSrvBHist_EBIDList * pEBIDList=0;

    rc=cn32_EBIDList(vcontrol, replyData, replyLen, pEBIDList);

    if(rc==OK_CN00)
    {
        cn32FreeEBIDList(vcontrol);
        pEBIDList=0;                    // (*pEBIDList) was freed one line above, so don't reference to it anymore
    }

    rc=cn32_AllocEBIDList(vcontrol, replyData, replyLen, pEBIDList);

    if(OK_CN00==rc)
        rc=pEBIDList->GetEBIDs(vcontrol, command, replyData, replyLen, replyLenMax);

    if(OK_CN00==rc)
        sprintf(replyData, "%s%s", ANSWER_OK_CN00, LINE_SEPSTRING_CN00);

    *replyLen=int(strlen(replyData));

    return rc;
} // end cn32GetEBIDs

const char * LongHelp_GetEBIDSFromTool_cn32=
    "@command backup_ext_ids_getfromtool You inquire external backup IDs and other "
        "information about backups for a database instance that are currently "
        "stored in a backup tool. Use the command backup_ext_ids_list to "
        "display the inquired information."
    "@preconditions You have the DBM operator authorization Backup or DBInfoRead."
    "@syntax backup_ext_ids_getfromtool <tool_type> [<database_name>] [<database_server>]"
        "@param <tool_type>      The backup tool that should be used. See command medium_put "
            "(option <tool_type>) for supported backup tools and allowed values for <tooltype>."
        "@param <database_name> Name of the database instance from which the "
            "backups were created"
        "@param <database_server>   Name of the server on which the backups were created"
    "@reply OK";

// PUBLIC FUNCTION cn32ListNextEBIDs
// ------------------------------------------------------------------
// purpose: prints a list of EBIDs to the reply buffer
//
tcn00_Error cn32ListNextEBIDs(VControlDataT * vcontrol,
                              CommandT      * command,
                              char          * replyData,
                              int           * replyLen,
                              int             replyLenMax)
{
    tcn00_Error            rc;
    DBMSrvBHist_EBIDList * pEBIDList=0;

    rc=cn32_EBIDList(vcontrol, replyData, replyLen, pEBIDList);

    if(OK_CN00==rc)
        rc=pEBIDList->ListNextEBIDs(vcontrol, replyData, replyLen, replyLenMax);

    *replyLen=(int)strlen(replyData);

    return rc;
} // end cn32ListNextEBIDs

// PUBLIC FUNCTION cn32ForgetEBIDs
// ------------------------------------------------------------------
// purpose: frees EBID list
//
tcn00_Error cn32ForgetEBIDs(VControlDataT * vcontrol,
                            CommandT      * command,
                            char          * replyData,
                            int           * replyLen,
                            int             replyLenMax )
{
    tcn00_Error            rc=OK_CN00;
    DBMSrvBHist_EBIDList * pEBIDList=0;

    rc=cn32_EBIDList(vcontrol, replyData, replyLen, pEBIDList);

    if(OK_CN00==rc)
    {
        cn32FreeEBIDList(vcontrol);
        sprintf(replyData, "%s%s", ANSWER_OK_CN00, LINE_SEPSTRING_CN00);
    }

    *replyLen = (int)strlen(replyData);

    return rc;
} // end cn32ForgetEBIDs

// PUBLIC FUNCTION cn32AnalyzeLogBackup
// ------------------------------------------------------------------
// purpose: frees EBID list
//
tcn00_Error cn32AnalyzeLogBackup(tcn003_BackupResult * tResult)
{
    tcn00_Error           rc=OK_CN00;
    DBMSrvBHist_History HistorySession;

    rc=HistorySession.AnalyzeLogBackup(tResult);

    return rc;
} // end cn32AnalyzeLogBackup

Generated by  Doxygen 1.6.0   Back to index