SAP SO_DOCUMENT_COPY Function Module for









SO_DOCUMENT_COPY is a standard so document copy SAP function module available within SAP R/3 or S/4 Hana systems, depending on your version and release level. It is used to perform a specific ABAP function and below is the pattern details, 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 copy FM, simply by entering the name SO_DOCUMENT_COPY into the relevant SAP transaction such as SE37 or SE38.

Function Group: SOB3
Program Name: SAPLSOB3
Main Program: SAPLSOB3
Appliation area: S
Release date: N/A
Mode(Normal, Remote etc): Normal Function Module
Update:



Function SO_DOCUMENT_COPY 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_COPY'"
EXPORTING
NEW_PARENT = "
FOLDER_ID = "
OBJECT_ID = "
* ATTACH_ID = "
* FORWARDER = "
* OWNER = "

IMPORTING
NEW_OBJECT_ID = "

EXCEPTIONS
ACTIVE_USER_NOT_EXIST = 1 PARAMETER_ERROR = 10 SUBSTITUTE_NOT_ACTIVE = 11 SUBSTITUTE_NOT_DEFINED = 12 DL_NAME_EXIST = 2 FOLDER_NO_AUTHORIZATION = 3 FOLDER_NOT_EXIST = 4 KPRO_TRANSFER_ERROR = 5 OBJECT_NOT_EXIST = 6 OBJECT_TYPE_NOT_EXIST = 7 OPERATION_NO_AUTHORIZATION = 8 OWNER_NOT_EXIST = 9
.



IMPORTING Parameters details for SO_DOCUMENT_COPY

NEW_PARENT -

Data type: SOODK
Optional: No
Call by Reference: No ( called with pass by value option)

FOLDER_ID -

Data type: SOFDK
Optional: No
Call by Reference: No ( called with pass by value option)

OBJECT_ID -

Data type: SOODK
Optional: No
Call by Reference: No ( called with pass by value option)

ATTACH_ID -

Data type: SOODK
Optional: Yes
Call by Reference: No ( called with pass by value option)

FORWARDER -

Data type: SOUD-USRNAM
Optional: Yes
Call by Reference: No ( called with pass by value option)

OWNER -

Data type: SOUD-USRNAM
Optional: Yes
Call by Reference: No ( called with pass by value option)

EXPORTING Parameters details for SO_DOCUMENT_COPY

NEW_OBJECT_ID -

Data type: SOODK
Optional: No
Call by Reference: Yes

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)

DL_NAME_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)

FOLDER_NOT_EXIST -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

KPRO_TRANSFER_ERROR -

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)

OBJECT_TYPE_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_COPY 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_new_parent  TYPE SOODK, "   
lv_new_object_id  TYPE SOODK, "   
lv_active_user_not_exist  TYPE SOODK, "   
lv_parameter_error  TYPE SOODK, "   
lv_substitute_not_active  TYPE SOODK, "   
lv_substitute_not_defined  TYPE SOODK, "   
lv_folder_id  TYPE SOFDK, "   
lv_dl_name_exist  TYPE SOFDK, "   
lv_object_id  TYPE SOODK, "   
lv_folder_no_authorization  TYPE SOODK, "   
lv_attach_id  TYPE SOODK, "   
lv_folder_not_exist  TYPE SOODK, "   
lv_forwarder  TYPE SOUD-USRNAM, "   
lv_kpro_transfer_error  TYPE SOUD, "   
lv_owner  TYPE SOUD-USRNAM, "   
lv_object_not_exist  TYPE SOUD, "   
lv_object_type_not_exist  TYPE SOUD, "   
lv_operation_no_authorization  TYPE SOUD, "   
lv_owner_not_exist  TYPE SOUD. "   

  CALL FUNCTION 'SO_DOCUMENT_COPY'  "
    EXPORTING
         NEW_PARENT = lv_new_parent
         FOLDER_ID = lv_folder_id
         OBJECT_ID = lv_object_id
         ATTACH_ID = lv_attach_id
         FORWARDER = lv_forwarder
         OWNER = lv_owner
    IMPORTING
         NEW_OBJECT_ID = lv_new_object_id
    EXCEPTIONS
        ACTIVE_USER_NOT_EXIST = 1
        PARAMETER_ERROR = 10
        SUBSTITUTE_NOT_ACTIVE = 11
        SUBSTITUTE_NOT_DEFINED = 12
        DL_NAME_EXIST = 2
        FOLDER_NO_AUTHORIZATION = 3
        FOLDER_NOT_EXIST = 4
        KPRO_TRANSFER_ERROR = 5
        OBJECT_NOT_EXIST = 6
        OBJECT_TYPE_NOT_EXIST = 7
        OPERATION_NO_AUTHORIZATION = 8
        OWNER_NOT_EXIST = 9
. " SO_DOCUMENT_COPY




ABAP code using 7.40 inline data declarations to call FM SO_DOCUMENT_COPY

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).
 
 
 
 
 


Search for further information about these or an SAP related objects



Comments on this SAP object

What made you want to lookup this SAP object? Please tell us what you were looking for and anything you would like to be included on this page!