MINI MINI MANI MO

Path : /opt/oracle/product/18c/dbhomeXE/md/admin/
File Upload :
Current File : //opt/oracle/product/18c/dbhomeXE/md/admin/sdowfsph.sql

Rem
Rem $Header: sdo/admin/sdowfsph.sql /main/26 2017/03/17 13:26:19 rjanders Exp $
Rem
Rem sdowfsph.sql
Rem
Rem Copyright (c) 2006, 2017, Oracle and/or its affiliates. 
Rem All rights reserved.
Rem
Rem    NAME
Rem      sdowfsph.sql - <one-line expansion of the name>
Rem
Rem    DESCRIPTION
Rem      <short description of component this file declares/defines>
Rem
Rem    NOTES
Rem      <other useful comments, qualifications, etc.>
Rem
Rem    BEGIN SQL_FILE_METADATA
Rem    SQL_SOURCE_FILE: sdo/admin/sdowfsph.sql
Rem    SQL_SHIPPED_FILE: md/admin/sdowfsph.sql
Rem    SQL_PHASE: SDOWFSPH
Rem    SQL_STARTUP_MODE: NORMAL
Rem    SQL_IGNORABLE_ERRORS: NONE
Rem    SQL_CALLING_FILE: sdo/admin/sdowfscs.sql
Rem    END SQL_FILE_METADATA
Rem
Rem    MODIFIED   (MM/DD/YY)
Rem    rjanders    03/09/17 - Add missing SQL_FILE_METADATA information
Rem    bkazar      07/18/16 - Bug 24312240
Rem    lramosc     02/16/16 - Reduce datasources
Rem    bkazar      03/04/14 - Bug 18239252: Add createDefaultFTXSD function 
Rem    bkazar      02/20/14 - Add publish_featureTypes_in_schema
Rem    rjanders    09/16/13 - OCCS: Remove hardtabs
Rem    rjanders    03/15/13 - #16473696: Start/End _ORACLE_SCRIPT
Rem                           initialization
Rem    bkazar      10/12/12 - Bug 14756954
Rem    bkazar      04/26/11 - xsd:boolean can have values true,false,1,0; modify populateVaryingAliases function
Rem    bkazar      05/27/10 - add strip_special_chars function
Rem    bkazar      05/24/10 - Case sensitive featureType tags mapped to case
Rem                           insensitive column names
Rem    bkazar      05/07/10 - varying alias for a feature
Rem    ningan      12/16/09 - in insertCapabilitiesInfo function, gives 
Rem                             parameter wfs_version a default value of '1.0.0'
Rem    bkazar      08/27/09 - insert new FeatureType's with new xsd and wfs_version column into mdsys.WFS_FeatureType$ table
Rem                           for WFS 1.1 version (for later versions, too).
Rem                           FeatureType's are published/loaded into mdsys.WFS_FeatureType$ table with 
Rem                           MDSYS.SDO_WFS_PROCESS.publishFeatureType, which will have a new parameter for wfs_version.
Rem    bkazar      07/09/09 - WFS 1.1 Capabilities Info template loaded with
Rem                           wfs_version column into into
Rem                           mdsys.WFS_CapabilitiesInfo$ table via
Rem                           MDSYS.SDO_WFS_PROCESS.insertCapabilitiesInfo
Rem    ningan      10/27/08 - bug7475076
Rem    rchatter    07/13/06 - add mandatory Column config support 
Rem    rchatter    03/28/06 - Created
Rem


Rem ********************************************************************
Rem #16473696: Indicate Oracle-Supplied object
@@?/rdbms/admin/sqlsessstart.sql
Rem ********************************************************************

CREATE OR REPLACE PACKAGE MDSYS.SDO_WFS_PROCESS AUTHID current_user AS
        SPATIALCOLSEP CONSTANT varchar2(40) := '<>';
        SPATIALPATHELEMSEP CONSTANT varchar2(20) := '>';
        NS_SEP CONSTANT varchar2(20) := '<';
        NULL_NS CONSTANT varchar2(20) := 'null';
        KEY_SEP CONSTANT varchar2(20) := ';';
        COMMIT_THRESHOLD CONSTANT number  := 1000;
        LARGE_THRESHOLD CONSTANT number  := 0;

        -- publish from relation table content
        procedure publishFeatureType(dataSrc IN VARCHAR2,
                                     ftnsUrl IN VARCHAR2,
                                     ftName IN VARCHAR2,
                                     ftnsAlias IN VARCHAR2,
                                     featureDesc IN XMLType,
                                     SCHEMALOCATION IN VARCHAR2,
                                     pkeyCol IN VARCHAR2,
                                     columnInfo IN mdsys.StringList, pSpatialCol varchar2, featureMemberNS varchar2, featureMemberName varchar2, srsNS varchar2, srsNSAlias varchar2, mandatoryColumnInfo IN mdsys.StringList default mdsys.StringList('$ALL$'), wfs_version IN varchar2 default '1.0.0',
                                     ftXSD IN XMLType default NULL/*,
                                     ftVaryingNSAlias_ColName IN StringList default NULL*/,
                                     customSrsNamePrefixes IN VARCHAR2 default NULL) ;
        procedure publishFeatureType(dataSrc IN VARCHAR2, 
                                     ftnsUrl IN VARCHAR2, 
                                     ftName IN VARCHAR2, 
                                     ftnsAlias IN VARCHAR2,
                                     featureDesc IN XMLType,
                                     SCHEMALOCATION IN VARCHAR2,
                                     pkeyCol IN VARCHAR2,
                                     columnInfo IN mdsys.StringList, pSpatialCol varchar2, featureMemberNS varchar2, featureMemberName varchar2, srsNS varchar2, srsNSAlias varchar2, viewTableName varchar2, viewTablepkeyCol varchar2, mandatoryColumnInfo IN mdsys.StringList default mdsys.StringList('$ALL$'), wfs_version IN varchar2 default '1.0.0',
                                     ftXSD IN XMLType default NULL/*,
                                     ftVaryingNSAlias_ColName IN StringList default NULL*/,
                                     customSrsNamePrefixes IN VARCHAR2 default NULL) ;
        -- publish from a external feature xsd
        procedure publishFeatureType(dataSrc IN VARCHAR2, 
                                     ftnsUrl IN VARCHAR2, 
                                     ftName IN VARCHAR2, 
                                     ftnsAlias IN VARCHAR2,
                                     featureDesc IN XMLType,
                                     SCHEMALOCATION IN VARCHAR2,
                                     pkeyCol IN VARCHAR2,
                                     columnInfo IN mdsys.StringList, pSpatialCol varchar2, featureMemberNS varchar2, featureMemberName varchar2, srsNS varchar2, srsNSAlias varchar2, featureCollectionNS varchar2, featureCollectionName varchar2, isGML3 varchar2, formattedkeyCols mdsys.StringList, viewTableName varchar2, viewTablepkeyCol varchar2, viewTableFmtKeyCols mdsys.StringList, mandatoryColumnInfo IN mdsys.StringList default mdsys.StringList('$ALL$'), wfs_version IN varchar2 default '1.0.0',
                                     ftXSD IN XMLType default NULL/*,
                                     ftVaryingNSAlias_ColName IN StringList default NULL*/,
                                     customSrsNamePrefixes IN VARCHAR2 default NULL) ;
        function populateVaryingAliases(ftXSD IN XMLType,
                                        ftName IN VARCHAR2,
                                        featureTypeId IN NUMBER,
                                        col_name IN VARCHAR2,
                                        tagTypeName OUT VARCHAR2) return varchar2;
  function strip_special_chars(input_str           varchar2,
                               chars_to_be_deleted varchar2,
                               placeholders        varchar2 default CHR(1)) return varchar2;        
        procedure publish_featureTypes_in_schema(
                                                p_owner               varchar2,
                                                p_namespace_url       varchar2,
                                                p_namespace_alias     varchar2,
                                                p_wls_postxml_url     varchar2,
                                                p_tablename_pattern   varchar2 default '%',
                                                p_wfs_version         varchar2 default '1.1.0',
                                                p_write_xsd           varchar2 default 'N');
        function createDefaultFTXSD(dataSrc VARCHAR2,
                                    ftNsUrl VARCHAR2,
                                    ftName VARCHAR2,
                                    ftNsAlias VARCHAR2,
                                    columnInfo MDSYS.StringList,
                                    wfs_version VARCHAR2)
        return CLOB;
        function colTypeToXSDType(typeOwner IN VARCHAR2, colType  IN VARCHAR2, colPrecision NUMBER, colScale NUMBER) RETURN VARCHAR2;
        -- publish from a external feature xsd
        procedure publishFeatureType(ftxsd IN XMLType, featureDesc IN XMLType, wfs_version IN varchar2 default '1.0.0'); 
        procedure processInLineComplexElement(ftxsd IN XMLType,
                               elementXml IN XMLType, 
                               elemIndex IN number, 
                               spatialCols IN OUT NOCOPY mdsys.StringList, 
                               currGmlElementsCnt IN OUT number, 
                               gmlElementsCnt IN number, 
                               parentElemPath IN varchar2,
                               gmlAlias IN VARCHAR2);
        procedure processComplexElement(ftxsd IN XMLType,
                               elementType IN varchar2, 
                               spatialCols IN OUT NOCOPY mdsys.StringList,
                               currGmlElementsCnt IN OUT number,
                               gmlElementsCnt IN number,
                               parentElemPath IN varchar2,
                               gmlAlias IN VARCHAR2);
        function isComplexObjectType(elemType IN VARCHAR2, gmlAlias IN VARCHAR2) return number ;
        function isInList(l mdsys.StringList, item varchar2) return number ;
        function orderInList(l mdsys.StringList, item varchar2) return number ;
                                        
        procedure  registerObject(objNs IN VARCHAR2, objName IN VARCHAR2, ftnsUrl IN VARCHAR2, currObjColPath varchar2, objNameIndex IN  NUMBER, ftId IN NUMBER, spatialColInfo mdsys.StringList, spatialColInfoIndex IN OUT NUMBER);
        function getXMLTagType(typeOwner IN VARCHAR2, type IN VARCHAR2) RETURN VARCHAR2;
        procedure dropFeatureType(ftnsUrl IN VARCHAR2, ftName IN VARCHAR2);
        procedure dropFeatureTypes(ftnsUrl IN VARCHAR2);
        procedure insertFtMDUpdated(ns varchar2, name varchar2, updateTs timestamp) ;
        procedure insertFtDataUpdated(ns varchar2, name varchar2, updatedRowList ROWPOINTERLIST, updateTs timestamp);
        procedure insertCapabilitiesInfo(capabilitiesInfo xmltype, wfs_version IN varchar2 default '1.0.0');
        procedure deleteCapabilitiesInfo;
        procedure  genCollectionProcs ;
        procedure genCollectionProcsHelper(objNs IN VARCHAR2, objName IN VARCHAR2) ;
        procedure populateFeatureTypeXMLInfo(xmlcoltypexsd XMLType, 
                        fTypeId number, columnName varchar2, 
                        objPathInfo mdsys.StringList) ;
        procedure deleteFeatureTypeXMLInfo(fTypeId number);
        function containsSDO(ns varchar2, name varchar2, ftId number) return number;
        function containsSDOInternal(rootns varchar2, rootname varchar2, 
                                ns varchar2, name varchar2, ftId number) return number ;
        procedure updateObjectRef(refObjNs varchar2, refObjName varchar2, featureTypeId number , refObjSeqNo number) ;
        procedure updateObjectRef(refObjNs varchar2, refObjName varchar2, 
                refObjSeqNo number, nsUrl varchar2, 
                containerObjNs varchar2, containerObjName varchar2, containerObjNameIndex number, featureTypeId number) ;
        function sortSpContentByColIndex (spatialPaths mdsys.StringList, spatialPathInfo sdo_geom_path_info, 
                userName varchar2, tableName in varchar2) return sdo_geom_path_info;
        function genSpatialPathElemColIndex(spatialPaths mdsys.StringList, spatialPathElem sdo_geom_path_elem) return number ;
        function genIdValue(data xmltype, idPaths mdsys.StringList, tNS varchar2, tName varchar2, ftUserName varchar2) return varchar2 ;
        function getPath(path mdsys.StringList) return varchar2;
        function getParsedPath(path varchar2) return mdsys.StringList; -- (ns1, name1, ns2, name2....)
        procedure genRecordTypeProcessingLogic(tNS varchar2, tName varchar2) ;
        function extractSDO(xmldata XMLType, spatialPaths mdsys.StringList, srsNs varchar2, ISGML3 varchar2, spPathsSRSNSList mdsys.StringListList) return sdo_geom_path_info ;
        function parsePath(path varchar2) return mdsys.StringList ;
        function generateParsedSpatialPath(spatialPaths mdsys.StringList) return mdsys.StringListList ;
        function processPath(srcPaths mdsys.StringListList,  genArrIdx number) return mdsys.StringListList ;
        function generateAliasString(aliasList mdsys.StringList) return varchar2 ;
        function getAlias(nsurl varchar2, aliasList mdsys.StringList) return varchar2 ;
        function putAlias (nsurl varchar2, alias varchar2, aliasList mdsys.StringList) return mdsys.StringList;
        function isRowIdIn (r ROWID, rlist RowPointerList) return number ;
        function isPKColIn (r varchar2, rlist RowPointerList) return number;
        function extractID(xmldata XMLType, idPaths mdsys.StringList) return varchar2 ;
        function processIdPath(srcPaths mdsys.StringList) return mdsys.StringList ;

        function getFeatureTypeId(ftnsUrl IN VARCHAR2, 
                                  ftName IN VARCHAR2) return number;
        procedure grantMDAccessToUser(userName IN varchar2);
        procedure revokeMDAccessFromUser(userName IN varchar2);
        procedure grantFeatureTypeToUser(ftnsUrl IN VARCHAR2,
                                  ftName IN VARCHAR2, 
                                  userName IN varchar2);
        procedure revokeFeatureTypeFromUser(ftnsUrl IN VARCHAR2,
                                  ftName IN VARCHAR2, 
                                  userName IN varchar2);
        procedure registerMTableView(ftNSUrl varchar2,
                     ftName varchar2,
                     viewTableList mdsys.StringList,
                     viewTablePkeyColList mdsys.StringList,
                     tablePKeyColList mdsys.StringList);
        procedure registerMTableView(ftNSUrl varchar2,
                     ftName varchar2,
                     viewTableList mdsys.StringList,
                     viewTablePkeyColList mdsys.StringList,
                     formattedViewTableColList mdsys.StringListList,
                     tablePKeyColList mdsys.StringList);
        procedure unRegisterMTableView(ftNSUrl varchar2, 
                       ftName varchar2);
        function notInArray(p varchar2, pList mdsys.RowPointerList) return number;

        function genSpatialArrInfo(tableNamePrefix varchar2, pkVal varchar2, 
                                   l_spatialArrList mdsys.StringListList, 
                                   data XMLType,  srsNs varchar2, spatialArrUpdMap varchar2, ISGML3 varchar2, spArrPathsSRSNSList mdsys.StringListList) 
        return mdsys.SDO_GEOM_PATH_INFO_LIST;
        function  getUpdateMap(spatialArrList mdsys.StringListList) return varchar2;
        function expandPath(aliasedPath varchar2, nsParam varchar2) return varchar2;
        function findNSUrl(nsAlias varchar2, nsAliasList mdsys.StringList, nsUrlList mdsys.StringList) return varchar2;
        function getCount(pathPattern varchar2, nsParam varchar2, data xmltype) return number;
        function enumerateArrPaths(pathPattern varchar2, nsParam varchar2, data xmltype) return mdsys.StringList;
        procedure genTriggers(tNS varchar2, tName varchar2);
        function isListMember(featureTypeName varchar2, namespaceUrl varchar2, ftIdList mdsys.StringListList) return number;
        PROCEDURE initialize_after_import;

        FUNCTION prepare_for_export_user return varchar2;
        FUNCTION prepare_for_export_user(exportSDOMetadata varchar2) return varchar2;

        FUNCTION prepare_for_export_fts (ftList mdsys.StringListList) return varchar2;
        FUNCTION prepare_for_export_fts (ftList mdsys.StringListList,  exportSDOMetadata varchar2) return varchar2;
        PROCEDURE prepare_for_export_ft_m_int(ftName in varchar2, ftNsUrl in varchar2, exportSDOMetadata varchar2) ;
        PROCEDURE prepare_for_export_ft_int(ftName in varchar2, ftNsUrl in varchar2, exportSDOMetadata varchar2);

        FUNCTION prepare_for_export_all return varchar2;
        FUNCTION prepare_for_export_all(exportSDOMetadata varchar2) return varchar2;
        procedure drop_export_tables;
        procedure genUpdateStr(spatialColCount number, update_prefix varchar2, update_suffix varchar2);
        procedure preProcessInsert (xmldata xmltype, 
                                    idPaths mdsys.StringList, 
                                    spatialPaths mdsys.StringList, 
                                    parsedAliasSpPath mdsys.StringListList, 
                                    spPathsSRSNSList mdsys.StringListList, 
                                    spatialArrPathsList mdsys.StringListList, 
                                    spArrPathsSRSNSList mdsys.StringListList, 
                                    ftNS varchar2, 
                                    ftName varchar2, 
                                    ftId number, 
                                    ftUserName varchar2, 
                                    tableName varchar2, 
                                    srsNs varchar2, 
                                    ISGML3 varchar2, 
                                    spatialPathsStgSrIds mdsys.sdoNumList, -- spatialPaths storage srid
                                    spatialArrPathsStgSrIds mdsys.sdoNumList, pkColVal OUT VARCHAR2); -- spatial Arr paths storage srids
        procedure preProcessUpdate(xmldata xmltype, 
                                   oldId varchar2, 
                                   spColUpdMap mdsys.StringList, 
                                   spArrColUpdMap mdsys.StringList, 
                                   idPaths mdsys.StringList, 
                                   spatialPaths mdsys.StringList, 
                                   parsedAliasSpPath mdsys.StringListList, 
                                   spPathsSRSNSList mdsys.StringListList, 
                                   spatialArrPathsList mdsys.StringListList, 
                                   spArrPathsSRSNSList mdsys.StringListList, 
                                   ftNS varchar2, 
                                   ftName varchar2, 
                                   ftId number, 
                                   ftUserName varchar2, 
                                   tableName varchar2, 
                                   srsNs varchar2, 
                                   ISGML3 varchar2, 
                                   spatialPathsStgSrIds mdsys.sdoNumList,  -- spatialPaths storage srid
                                   spatialArrPathsStgSrIds mdsys.sdoNumList,   -- spatial Arr paths storage srids
                                   computeSp number, newId OUT varchar2);

END SDO_WFS_PROCESS;
/
show errors;

create or replace public synonym SDO_WFS_PROCESS for mdsys.SDO_WFS_PROCESS;

show errors;

Rem ********************************************************************
Rem #16473696: Indicate Oracle-Supplied object
@?/rdbms/admin/sqlsessend.sql
Rem ********************************************************************


OHA YOOOO