-- ============================================================================ -- MARS-828 Master Installation Script -- ============================================================================ -- Author: Grzegorz Michalski -- Purpose: Deploy enhanced archival strategies for FILE_ARCHIVER package -- Target Schema: CT_MRDS -- Estimated Time: 2-3 minutes -- Prerequisites: FILE_ARCHIVER v2.0.0, ENV_MANAGER v3.x, ADMIN privileges -- ============================================================================ SET SERVEROUTPUT ON SIZE UNLIMITED SET VERIFY OFF SET FEEDBACK ON SET ECHO OFF SET SERVEROUTPUT ON SIZE UNLIMITED SET VERIFY OFF SET FEEDBACK ON SET ECHO OFF -- Create log directory if it doesn't exist host mkdir log 2>nul -- Generate dynamic SPOOL filename with timestamp var filename VARCHAR2(100) BEGIN :filename := 'log/INSTALL_MARS_828_' || SYS_CONTEXT('USERENV', 'CON_NAME') || '_' || TO_CHAR(SYSDATE,'YYYYMMDD_HH24MISS') || '.log'; END; / column filename new_value _filename select :filename filename from dual; spool &_filename PROMPT PROMPT ============================================================================ PROMPT MARS-828 Installation Starting PROMPT ============================================================================ PROMPT Package: CT_MRDS.FILE_ARCHIVER v3.3.0 + CT_MRDS.FILE_MANAGER v3.3.2 PROMPT Change: Enhanced archival strategies (MINIMUM_AGE_MONTHS, HYBRID) + TRASH retention + Selective archiving + FILE_MANAGER compatibility PROMPT Purpose: Flexible archival policies per data source with file retention and config-based control PROMPT Steps: 14 (DDL, Rename, Comments, Trigger, Statuses, Grants, Packages, Verify, Track, Configure) PROMPT Timestamp: SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS install_start FROM DUAL; PROMPT ============================================================================ -- Confirm installation with user ACCEPT continue CHAR PROMPT 'Type YES to continue with installation, or Ctrl+C to abort: ' WHENEVER SQLERROR EXIT SQL.SQLCODE BEGIN IF '&continue' IS NULL OR TRIM('&continue') IS NULL OR UPPER(TRIM('&continue')) != 'YES' THEN RAISE_APPLICATION_ERROR(-20001, 'Installation aborted by user'); END IF; END; / WHENEVER SQLERROR CONTINUE -- Installation steps PROMPT PROMPT Step 1/12: Adding archival strategy and config columns to A_SOURCE_FILE_CONFIG PROMPT ============================================================================== @@01_MARS_828_install_add_archival_strategy_columns.sql PROMPT PROMPT Step 2/12: Renaming threshold columns for consistent naming PROMPT ========================================================== @@01a_MARS_828_rename_threshold_columns.sql PROMPT PROMPT Step 3/12: Adding comprehensive column comments PROMPT =============================================== @@01b_MARS_828_add_column_comments.sql PROMPT PROMPT Step 4/12: Creating validation trigger PROMPT ====================================== @@02_MARS_828_install_archival_strategy_trigger.sql PROMPT PROMPT Step 5/12: Adding TRASH retention statuses to A_SOURCE_FILE_RECEIVED PROMPT =================================================================== @@07_MARS_828_install_add_trash_retention_statuses.sql PROMPT PROMPT Step 6/12: Granting privileges on T_FILENAME to MRDS_LOADER PROMPT ========================================================== @@08_MARS_828_install_grant_t_filename.sql PROMPT PROMPT Step 7/12: Deploying FILE_ARCHIVER Package Specification v3.3.0 PROMPT ============================================================== @@03_MARS_828_install_CT_MRDS_FILE_ARCHIVER_SPEC.sql PROMPT PROMPT Step 8/14: Deploying FILE_ARCHIVER Package Body v3.3.0 PROMPT ==================================================== @@04_MARS_828_install_CT_MRDS_FILE_ARCHIVER_BODY.sql PROMPT PROMPT Step 9/14: Deploying FILE_MANAGER Package Specification v3.3.2 PROMPT ============================================================= @@09_MARS_828_install_CT_MRDS_FILE_MANAGER_SPEC.sql PROMPT PROMPT Step 10/14: Deploying FILE_MANAGER Package Body v3.3.2 PROMPT =================================================== @@10_MARS_828_install_CT_MRDS_FILE_MANAGER_BODY.sql PROMPT PROMPT Step 11/14: Verifying installation PROMPT ================================== @@05_MARS_828_verify_installation.sql PROMPT PROMPT Step 12/14: Tracking package versions PROMPT ===================================== @@track_package_versions.sql PROMPT PROMPT Step 13/14: Verifying tracked packages PROMPT ====================================== @@verify_packages_version.sql PROMPT PROMPT Step 14/14: Configuring Release 01 tables archival strategies PROMPT ============================================================ @@06_MARS_828_configure_release01_tables.sql PROMPT PROMPT ============================================================================ PROMPT MARS-828 Installation Completed PROMPT ============================================================================ PROMPT Completion Time: SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS install_end FROM DUAL; PROMPT PROMPT Installation Summary: PROMPT - Packages Installed: PROMPT * CT_MRDS.FILE_ARCHIVER v3.3.0 (includes selective archiving and config-based TRASH policy) PROMPT * CT_MRDS.FILE_MANAGER v3.3.2 (compatible with MARS-828 threshold column renames) PROMPT - Strategies: THRESHOLD_BASED (default), MINIMUM_AGE_MONTHS (0=current month), HYBRID PROMPT - Selective Archiving: IS_ARCHIVE_ENABLED column (Y=archive, N=skip) PROMPT - TRASH Policy: IS_KEEP_IN_TRASH column (Y=keep files, N=delete immediately) PROMPT * Default: IS_ARCHIVE_ENABLED='Y', IS_KEEP_IN_TRASH='N' (archiving enabled, immediate deletion) PROMPT * TRASH is a subfolder in DATA bucket (e.g., TRASH/LM/TABLE_NAME) PROMPT * No more pKeepInTrash parameter - policy from config only PROMPT - New Procedure: ARCHIVE_ALL_FOR_SOURCE(pSourceKey) for batch processing PROMPT - TRASH Management: RESTORE_FILE_FROM_TRASH, PURGE_TRASH_FOLDER (3-level granularity) PROMPT - New Statuses: ARCHIVED_AND_TRASHED, ARCHIVED_AND_PURGED PROMPT - Backward Compatible: Yes (default THRESHOLD_BASED, existing behavior preserved) PROMPT - Configured Tables: 25 Release 01 tables (19 LM + 6 CSDB) PROMPT - Includes All Fixes from v3.0.0 through v3.2.1 PROMPT PROMPT Note: Incremental patches available in patches/ directory PROMPT PROMPT Log file: &_filename PROMPT ============================================================================ spool off quit;