Pular para o conteúdo principal

Webcenter Content - Jython to Checkin Content with Attachments (CHECKIN_NEW_WITH_RENDITIONS)

In the last few days, i had to load a content that, by its requirements, needs to attach files to the content.

My first alternative would be Batch Loading, however for the bacth loder file it was not possible because it does not actually support the rendition service.

With the next option, i tried to use the IdcCommand, but still had many problems, such as errors below:

sample hda file:
[oracle @ hostname bin] $ cat idctst.txt
@Properties LocalData
IdcService = EDIT_RENDITIONS
dID = 37020
renditionKeys = addRendition0
addRendition0.name = test543
addRendition0.action = edit
addRendition0.file = test.txt
addRendition0.file: path = / u01 / oracle / domains / content_domain / ucm / cs / vault / ~ temp / test.txt
@end
<< EOD >>

Executing:
[oracle @ hostname bin] $ ./IdcCommand -f idctst.txt -u sysadmin -l log.log -c server

Error:
Java HotSpot (TM) 64-Bit Server VM warning: Using the ParNew young collector with the Serial old collector is deprecated and will likely be removed in a future release
> system / 6 09.22 12: 22: 44.847 main Configuring tracing verbose: false; sections: system
> system / 6 09.22 12: 22: 44.848 main Configuring tracing verbose: false; Services:
09-29-2017: Error executing the EDIT_RENDITIONS service. Unable to process post data while adding or deleting attachments or renditions attached to content item 'OWCCDEV12C035232'. Invalid path to attachment.


My appeal was to use RIDC and needing a quick implementation, nothing better than using Jython.

Below, I share a simplified and functional version of the code:

cat checkin_attachments.py

from oracle.stellent.ridc import IdcClientManager
from oracle.stellent.ridc import IdcContext
from oracle.stellent.ridc.model import TransferFile
from java.io import File

manager = IdcClientManager ()
client = manager.createClient ("idc://127.0.0.1:4444")
userContext = IdcContext ("weblogic")
# client = manager.createClient ("http://127.0.0.1:16200/cs/idcplg")
# userContext = IdcContext ("<user>", "<password>")


# Checkin a new file
binder = client.createBinder ()
binder.putLocal("IdcService", "CHECKIN_NEW_WITH_RENDITIONS")

binder.putLocal("dDocTitle", "Test File")
binder.putLocal("dDocType", "Document")
binder.putLocal("dSecurityGroup", "Public")
binder.putLocal("dDocAccount", "")
binder.addFile("primaryFile", TransferFile(File("content1.txt")))
binder.putLocal("fParentGUID", "D53FEDE1CA293189BB21BBC2C2BC3089")

#Add Attachments
inder.putLocal("renditionKeys", "aRendition0,aRendition1")

binder.putLocal("aRendition0.action", "edit")
binder.putLocal("aRendition0.name", "FileAttach")
binder.putLocal("aRendition0.file:path", "test.txt")
binder.addFile("aRendition0.file", TransferFile(File("test.txt")))

binder.putLocal("aRendition1.action", "edit")
binder.putLocal("aRendition1.name", "FileAttach")
binder.putLocal("aRendition1.file:path", "test.txt")
binder.addFile("aRendition1.file", TransferFile(File("test2.txt")))

# response
response = client.sendRequest (userContext, binder)
responseBinder = response.getResponseAsBinder ()
localData = responseBinder.getLocalData ()
dDocName = localData.get ("dDocName")
dID = localData.get ("dID")



Running:

. $MW_HOME/wlserver/server/bin/setWLSEnv.sh

java weblogic.WLST checkin_attachments.py



Reference:

https://blogs.oracle.com
MOS 2072524.1

Comentários

Postagens mais visitadas deste blog

Index SKIP SCAN???

Index Skip Scan nada mais é que o "split" logico de um indice composto, ou seja, se sua clausula WHERE não tiver todos os campos do indice composto, ele é dividido em menores sub-indices Exemplo: -------- SQL> create table teste(a number,b number); Table created. SQL> begin 2 for i in 1..1000 3 loop 4 insert into teste values(i, 56); 5 end loop; 6 end; 7 / PL/SQL procedure successfully completed. SQL> create index idx_teste on teste(a,b); Index created. SQL> analyze table teste compute statistics; Table analyzed. SQL> explain plan for select /*+ index_ss(teste idx_teste) */ * from teste where b=56; Explained. SQL> start ?\rdbms\admin\utlxpls.sql -------------------------------------------------------------------------------- | Operation | Name | Rows | Bytes| Cost | Pstart| Pstop | -------------------------------------------------------------------------------- | SELECT STATEMENT | | 1

Configurar Tamanho de UNDO e tempo de RETENÇÃO (UNDO_RETENTION)

-- Tamanho Undo Atual SELECT SUM(a.bytes) "UNDO_SIZE" FROM v$datafile a, v$tablespace b, dba_tablespaces c WHERE c.contents = 'UNDO' AND c.status = 'ONLINE' AND b.name = c.tablespace_name AND a.ts# = b.ts#; -- Blocos de UNDO por Seg. SELECT MAX(undoblks/((end_time-begin_time)*3600*24)) "UNDO_BLOCK_PER_SEC" FROM v$undostat; --Tamanho do Bloco SELECT TO_NUMBER(value) "DB_BLOCK_SIZE [KByte]" FROM v$parameter WHERE name = 'db_block_size'; -- Select calcula UNDO RETENTION SELECT d.undo_size/(1024*1024) "ACTUAL UNDO SIZE [MByte]", SUBSTR(e.value,1,25) "UNDO RETENTION [Sec]", ROUND((d.undo_size / (to_number(f.value) * g.undo_block_per_sec))) "OPTIMAL UNDO RETENTION [Sec]" FROM ( SELECT SUM(a.bytes) undo_size FROM v$datafile a, v$tablespace b, dba_tablespaces c WHERE c.contents = 'UNDO'