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

Webcenter Content - Cache Configuration for JdbcFileStore configuration

The configuration values below, control the temporarily cached files keep in FileCache table. FsCacheThreshold Specifies the maximum cache size, in megabytes (default=100) Once the threshold is met, Content Server starts deleting files that are older than the minimum age, as specified by the FsMinimumFileCacheAge parameter FsMaximumFileCacheAge The age at which files are deleted, expressed in days. The default is 365 days FsMinimumFileCacheAge The minimum age at which cached files can be deleted This parameter is used in conjunction with the FsCacheThreshold parameter to determine when to delete cached files FsCleanUpCacheDuringIndexing This parameter activates vault cache cleaning, while FsCacheThreshold, FsMaximumFileCacheAge and FsMinimumFileCacheAge are controling its behaviour.  Expect, when this is enabled on a system that currently has a large number of files in the FileCache table, the first cycle will take a long time to complete. How to Confi...

Assign Backup Policy for Boot and Block Volumes - OCI

To get Availability Domain oci iam availability-domain list  #!/bin/bash OCI_AD="hQsi:SA-SAOPAULO-1-AD-1" OCI_COMPARTMENT="ocid1.compartment.oc1..aaaaaaaavgyjpoffz5qliieawamjaksfb6juxejurtduclqjkvv66ookcxja" #Get Silver policy ocid funct_get_policy(){ OCI_POL_OCID=$(oci bv volume-backup-policy list | jq -r '.data[] | select(."display-name"|contains("silver"))' | jq -r '.id') } funct_boot_vol (){ #Create a file with all boot volume ocid oci bv boot-volume list --availability-domain ${OCI_AD} -c  ${OCI_COMPARTMENT} | jq -r '.data[].id' > boot-vol.txt while IFS="" read -r p || [ -n "$p" ] do   printf 'Seeting backup policy for %s\n' "$p"   oci bv volume-backup-policy-assignment create  --asset-id  $p  --policy-id ${OCI_POL_OCID} done < boot-vol.txt } funct_block_vol (){ #Create a file with all block volume ocid oci bv volume list  -c ${OCI_COMPARTMENT} | jq -r '.data[].id' ...

Logical Backup Using dbms_datapump

Sample scripts to make a logical backup using dbms_datapump -- BACKUP BY SCHEMA declare h1 NUMBER; begin h1 := dbms_datapump.open (operation => 'EXPORT', job_mode => 'SCHEMA', job_name => 'TESTE2', version => 'COMPATIBLE'); dbms_datapump.set_parallel(handle => h1, degree => 1); dbms_datapump.add_file(handle => h1, filename => 'BKP_SCHEMAS.LOG', directory => 'BKP_DATA_PUMP', filetype => 3); dbms_datapump.set_parameter(handle => h1, name => 'KEEP_MASTER', value => 0); dbms_datapump.metadata_filter(handle => h1, name => 'SCHEMA_EXPR', value => 'IN(''DENILSON'')'); dbms_datapump.add_file(handle => h1, filename => 'BKP_SCHEMAS.DMP', directory => 'BKP_DATA_PUMP', filetype => 1); dbms_datapump.set_parameter(handle => h1, name => 'INCLUDE_METADATA', value => 1); dbms_datapump.set_parameter(handle => h1, name ...