Index: openacs-4/packages/acs-content-repository/tcl/revision-procs-oracle.xql =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/acs-content-repository/tcl/revision-procs-oracle.xql,v diff -u -r1.13.20.5 -r1.13.20.6 --- openacs-4/packages/acs-content-repository/tcl/revision-procs-oracle.xql 5 Dec 2022 11:26:13 -0000 1.13.20.5 +++ openacs-4/packages/acs-content-repository/tcl/revision-procs-oracle.xql 23 Apr 2024 14:43:30 -0000 1.13.20.6 @@ -2,14 +2,6 @@ oracle8.1.6 - - - select :path || filename - from cr_revisions - where revision_id = :revision_id - - - select content Index: openacs-4/packages/acs-content-repository/tcl/revision-procs-postgresql.xql =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/acs-content-repository/tcl/revision-procs-postgresql.xql,v diff -u -r1.11.2.5 -r1.11.2.6 --- openacs-4/packages/acs-content-repository/tcl/revision-procs-postgresql.xql 5 Dec 2022 11:26:13 -0000 1.11.2.5 +++ openacs-4/packages/acs-content-repository/tcl/revision-procs-postgresql.xql 23 Apr 2024 14:43:30 -0000 1.11.2.6 @@ -2,14 +2,6 @@ postgresql7.1 - - - select :path || content - from cr_revisions - where revision_id = :revision_id - - - select lob as content, 'lob' as storage_type Index: openacs-4/packages/acs-content-repository/tcl/revision-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/acs-content-repository/tcl/revision-procs.tcl,v diff -u -r1.37.2.8 -r1.37.2.9 --- openacs-4/packages/acs-content-repository/tcl/revision-procs.tcl 9 Jan 2024 13:06:17 -0000 1.37.2.8 +++ openacs-4/packages/acs-content-repository/tcl/revision-procs.tcl 23 Apr 2024 14:43:30 -0000 1.37.2.9 @@ -110,22 +110,17 @@ -storage_area_key } { set path [cr_fs_path $storage_area_key] - if {[db_type] eq "oracle"} { - # - # CR datamodel for Oracle differs from the one in Postgres - # concerning file revisions. For Oracle, an additional column - # cr_revisions.filename stores the actual filename. - # - set filename [db_string write_file_content {}] - } else { - set filename $path$content - } - if {$filename eq ""} { - error "No content for the revision $revision_id.\ - This seems to be an error which occurred during the upload of the file" + # + # For content items of type "file", the content is in fact the + # relative path to the file. However, we prefer a zero-trust + # approach here and we recompute the filename from item and + # revision id. This should work the same for Oracle and Postgres + # and avoids going to the db. + # + set filename ${path}[::cr_create_content_file_path $item_id $revision_id] - } elseif {![file readable $filename]} { + if {![file readable $filename]} { ns_log Error "Could not read file $filename. Maybe the content repository is (partially) missing?" ns_return 404 text/plain {}