SAP SO_DOCUMENT_UPDATE Function Module for SAPoffice: Insert document with binary content
SO_DOCUMENT_UPDATE is a standard so document update SAP function module available within SAP R/3 or S/4 Hana systems, depending on your version and release level. It is used for SAPoffice: Insert document with binary content processing and below is the pattern details for this FM, showing its interface including any import and export parameters, exceptions etc. there is also a full "cut and paste" ABAP pattern code example, along with implementation ABAP coding, documentation and contribution comments specific to this or related objects.
See here to view full function module documentation and code listing for so document update FM, simply by entering the name SO_DOCUMENT_UPDATE into the relevant SAP transaction such as SE37 or SE38.
Function Group: SOA1
Program Name: SAPLSOA1
Main Program: SAPLSOA1
Appliation area: S
Release date: N/A
Mode(Normal, Remote etc): Remote-Enabled
Update:

Function SO_DOCUMENT_UPDATE pattern details
In-order to call this FM within your sap programs, simply using the below ABAP pattern details to trigger the function call...or see the full ABAP code listing at the end of this article. You can simply cut and paste this code into your ABAP progrom as it is, including variable declarations.CALL FUNCTION 'SO_DOCUMENT_UPDATE'"SAPoffice: Insert document with binary content.
EXPORTING
PARENT_ID = "
OBJECT_HD_CHANGE = "
* OBJECT_FL_CHANGE = "
DOCUMENT_ID = "
* FORWARDER = "
* OWNER = "
* OBJECT_REAPPEAR = ' ' "
IMPORTING
OBJECT_HD_DISPLAY = "
OBJECT_FL_DISPLAY = "
TABLES
* OBJCONT_TEXT = "
* OBJCONT_BIN = "
* OBJHEAD = "
* OBJPARA = "
* OBJPARB = "
EXCEPTIONS
ACTIVE_USER_NOT_EXIST = 1 PARAMETER_ERROR = 10 SUBSTITUTE_NOT_ACTIVE = 11 SUBSTITUTE_NOT_DEFINED = 12 X_ERROR = 13 DL_NAME_EXIST = 2 FOLDER_NOT_EXIST = 3 FOLDER_NO_AUTHORIZATION = 4 FORWARDER_NOT_EXIST = 5 OBJECT_NO_AUTHORIZATION = 6 OBJECT_NOT_EXIST = 7 OPERATION_NO_AUTHORIZATION = 8 OWNER_NOT_EXIST = 9
IMPORTING Parameters details for SO_DOCUMENT_UPDATE
PARENT_ID -
Data type: SOODKOptional: No
Call by Reference: No ( called with pass by value option)
OBJECT_HD_CHANGE -
Data type: SOOD1Optional: No
Call by Reference: No ( called with pass by value option)
OBJECT_FL_CHANGE -
Data type: SOFM1Optional: Yes
Call by Reference: No ( called with pass by value option)
DOCUMENT_ID -
Data type: SOODKOptional: No
Call by Reference: No ( called with pass by value option)
FORWARDER -
Data type: SOUD-USRNAMOptional: Yes
Call by Reference: No ( called with pass by value option)
OWNER -
Data type: SOUD-USRNAMOptional: Yes
Call by Reference: No ( called with pass by value option)
OBJECT_REAPPEAR -
Data type: SONV-FLAGDefault: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)
EXPORTING Parameters details for SO_DOCUMENT_UPDATE
OBJECT_HD_DISPLAY -
Data type: SOOD2Optional: No
Call by Reference: No ( called with pass by value option)
OBJECT_FL_DISPLAY -
Data type: SOFM2Optional: No
Call by Reference: No ( called with pass by value option)
TABLES Parameters details for SO_DOCUMENT_UPDATE
OBJCONT_TEXT -
Data type: SOLIOptional: Yes
Call by Reference: No ( called with pass by value option)
OBJCONT_BIN -
Data type: SOLIXOptional: Yes
Call by Reference: No ( called with pass by value option)
OBJHEAD -
Data type: SOLIOptional: Yes
Call by Reference: No ( called with pass by value option)
OBJPARA -
Data type: SELCOptional: Yes
Call by Reference: No ( called with pass by value option)
OBJPARB -
Data type: SOOP1Optional: Yes
Call by Reference: No ( called with pass by value option)
EXCEPTIONS details
ACTIVE_USER_NOT_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
PARAMETER_ERROR -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
SUBSTITUTE_NOT_ACTIVE -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
SUBSTITUTE_NOT_DEFINED -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
X_ERROR -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
DL_NAME_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
FOLDER_NOT_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
FOLDER_NO_AUTHORIZATION -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
FORWARDER_NOT_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
OBJECT_NO_AUTHORIZATION -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
OBJECT_NOT_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
OPERATION_NO_AUTHORIZATION -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
OWNER_NOT_EXIST -
Data type:Optional: No
Call by Reference: No ( called with pass by value option)
Copy and paste ABAP code example for SO_DOCUMENT_UPDATE Function Module
The ABAP code below is a full code listing to execute function module POPUP_TO_CONFIRM including all data declarations. The code uses the original data declarations rather than the latest in-line data DECLARATION SYNTAX but I have included an ABAP code snippet at the end to show how declarations would look using the newer method of declaring data variables on the fly. This will allow you to compare and fully understand the new inline method. Please note some of the newer syntax such as the @DATA is not available until a later 4.70 service pack (SP8), which i why i have stuck to the origianl for this example.| DATA: | ||||
| lv_parent_id | TYPE SOODK, " | |||
| lt_objcont_text | TYPE STANDARD TABLE OF SOLI, " | |||
| lv_object_hd_display | TYPE SOOD2, " | |||
| lv_active_user_not_exist | TYPE SOOD2, " | |||
| lv_parameter_error | TYPE SOOD2, " | |||
| lv_substitute_not_active | TYPE SOOD2, " | |||
| lv_substitute_not_defined | TYPE SOOD2, " | |||
| lv_x_error | TYPE SOOD2, " | |||
| lt_objcont_bin | TYPE STANDARD TABLE OF SOLIX, " | |||
| lv_dl_name_exist | TYPE SOLIX, " | |||
| lv_object_hd_change | TYPE SOOD1, " | |||
| lv_object_fl_display | TYPE SOFM2, " | |||
| lt_objhead | TYPE STANDARD TABLE OF SOLI, " | |||
| lv_folder_not_exist | TYPE SOLI, " | |||
| lv_object_fl_change | TYPE SOFM1, " | |||
| lt_objpara | TYPE STANDARD TABLE OF SELC, " | |||
| lv_document_id | TYPE SOODK, " | |||
| lv_folder_no_authorization | TYPE SOODK, " | |||
| lt_objparb | TYPE STANDARD TABLE OF SOOP1, " | |||
| lv_forwarder | TYPE SOUD-USRNAM, " | |||
| lv_forwarder_not_exist | TYPE SOUD, " | |||
| lv_owner | TYPE SOUD-USRNAM, " | |||
| lv_object_no_authorization | TYPE SOUD, " | |||
| lv_object_reappear | TYPE SONV-FLAG, " SPACE | |||
| lv_object_not_exist | TYPE SONV, " | |||
| lv_operation_no_authorization | TYPE SONV, " | |||
| lv_owner_not_exist | TYPE SONV. " |
|   CALL FUNCTION 'SO_DOCUMENT_UPDATE' "SAPoffice: Insert document with binary content |
| EXPORTING | ||
| PARENT_ID | = lv_parent_id | |
| OBJECT_HD_CHANGE | = lv_object_hd_change | |
| OBJECT_FL_CHANGE | = lv_object_fl_change | |
| DOCUMENT_ID | = lv_document_id | |
| FORWARDER | = lv_forwarder | |
| OWNER | = lv_owner | |
| OBJECT_REAPPEAR | = lv_object_reappear | |
| IMPORTING | ||
| OBJECT_HD_DISPLAY | = lv_object_hd_display | |
| OBJECT_FL_DISPLAY | = lv_object_fl_display | |
| TABLES | ||
| OBJCONT_TEXT | = lt_objcont_text | |
| OBJCONT_BIN | = lt_objcont_bin | |
| OBJHEAD | = lt_objhead | |
| OBJPARA | = lt_objpara | |
| OBJPARB | = lt_objparb | |
| EXCEPTIONS | ||
| ACTIVE_USER_NOT_EXIST = 1 | ||
| PARAMETER_ERROR = 10 | ||
| SUBSTITUTE_NOT_ACTIVE = 11 | ||
| SUBSTITUTE_NOT_DEFINED = 12 | ||
| X_ERROR = 13 | ||
| DL_NAME_EXIST = 2 | ||
| FOLDER_NOT_EXIST = 3 | ||
| FOLDER_NO_AUTHORIZATION = 4 | ||
| FORWARDER_NOT_EXIST = 5 | ||
| OBJECT_NO_AUTHORIZATION = 6 | ||
| OBJECT_NOT_EXIST = 7 | ||
| OPERATION_NO_AUTHORIZATION = 8 | ||
| OWNER_NOT_EXIST = 9 | ||
| . " SO_DOCUMENT_UPDATE | ||
ABAP code using 7.40 inline data declarations to call FM SO_DOCUMENT_UPDATE
The below ABAP code uses the newer in-line data declarations. This allows you to see the coding differences/benefits of the later inline syntax. Please note some of the newer syntax below, such as the @DATA is not available until 4.70 EHP 8.| "SELECT single USRNAM FROM SOUD INTO @DATA(ld_forwarder). | ||||
| "SELECT single USRNAM FROM SOUD INTO @DATA(ld_owner). | ||||
| "SELECT single FLAG FROM SONV INTO @DATA(ld_object_reappear). | ||||
| DATA(ld_object_reappear) | = ' '. | |||
Search for further information about these or an SAP related objects