SAP User Exits and Enhancements
SAP User Exits and Enhancements
SAP User Exits and Enhancements
What is SAP ?
SAP PM T-Codes Userxits allow us to add our own functionality to SAP standard program
without modifying it . These are implemented in the form of subroutines and
PM BRD/COR hence are also known as FORM EXITs. The userexits are generally collected
Maintenance
in includes and attached to the standard program by the SAP.
Add Your URL All Userexits start with the word USEREXIT_...
User Exits & FORM USEREXIT_..
Enhancements
z..
Best Of SAP Links ENDFORM.
BDC Code
The problem lies in finding the correct userexit and how to find it if one exists
My Resume for the purpose. Once the correct userexit is found the necessary
customer code is inserted in the customer include starting with the z..
SAP SmartForms Step in the form routine.
by Step
Useful Tips
Certain application like SD still provide this form of enhancement using
Contact Information userexit but this practice is no longer being followed for newer extensions
Guest Book and instead they are using EXITs which come bundeled in enhancement
Consultants List packages . Neverthiless existing USEREXITS will be supported by SAP an all
ABAP Code the newer versions of SAP.
USEREXIT_PRICING_PREPARE_TKOMP or
USEREXIT_PRICING_PREPARE_TKOMK
Depending upon which table (KOMK or KOMP) the new fields were inserted
we use either of the above two userexits.These userexits are found in include
MV45AFZZ of the standard SAP sales order creation program SAPMV45A.
In the case of userexit which will be called when invoicing is done ,these
are provided in the include RY60AFZZ which is in the standard SAP
program SAPMV45A. The name of the userexits are same. i.e
USEREXIT_PRICING_PREPARE_TKOMP or
USEREXIT_PRICING_PREPARE_TKOMK
These userexits are used for passing the data from the communication
structure to the pricing procedure, for this we have to fill the newely
created field in the communication structure KOMG for this we fill the code in
the above userexit using the MOVE statement after the data that
has to be passed is taken from the database table by using the SELECT
statement. The actual structure which is visible in these userexits and which is
to be filled for that particular field is TKOMP or TKOMK.
Before the coding for these userexits is done ,it is necessary to create a new
field in either of the two tables KOMK or KOMP .For this purpose
includes are provided in each of them .
To create the field in header data(KOMK) the include provided is KOMKAZ
and to create the field in item data(KOMP) the include provided is KOMPAZ.
One possible example for the need of creating new fields can be e.g. Frieght
to be based upon transportation zone ,for this no field is available in field
catalog and hence it can be created in KOMK and then above userexits can
be used to fill the transportation data to it.
2)The other method of finding userexit is to find the word USEREXIT in the
associated program of the transaction for which we want to determine
userexit using SE38.
3)The other method of finding userexits is to find the include in case of
SD/MM applications where the userexits are located ,this can be found in the
SAP reference IMG generally in the subfolder under SYSTEM
MODIFICATION.
USEREXIT_NUMBER_RANGE
This userexit is used to assign a different internal document number to the
sales order(VA01) when it is created depending on some criteria like a
different SALES ORGANIZAION(VKORG) .
USEREXIT_SAVE_DOCUMENT_PREPARE
This userexit is used to insert the ABAP code which will be called when
the document (sales order VA01) is just about to be saved.This userexit is
used generally for custom checks on different fields , to display some
information before the order will be saved or for making changes to certain
fields before the sales order will be saved.
e.g. EXIT_SAPMV45A_002
This exit is found in SD in enhancement V45A0002.
TYPES OF EXITS
1)MENU EXITS
2)FUNCTION EXITS
3)TABLE EXITS
4)SCREEN EXITS
5)KEYWORD EXITS
6)FIELD EXITS
FUNCTION EXITS
These are used to add functionality through ABAP code . These start from
the word EXIT_programname_NNN ending in a 3 digit number. No access
code is required to implement any tupe of exit including function exits.
The function exits are called from the standard SAP program in the form
of ABAP statement
CALL CUSTOMER-FUNCTION 'NNN'
e.g.
ADDING A DEFAULT SOLD-TO-PARTY in Sales Order Creation
To show a default sold-to-party in this field when the user creates a sales
order (VA01) we can use a function exit .This function exit is located
in enhancement no V45A0002 . Before we can choose the exit we have to
create a project in CMOD after that enter V45A0002 in the enhancement field
and click on the components . In the components you will see the
exit EXIT_SAPMV45A_002 . This exit is used for our purpose.
Double clicking on this exit will takes us to function builder (SE37) . This
function exit has one exporting parameters and two importing parameters, we
are interested in exporting parameter which is E_KUNNR
of type KNA1-KUNNR i.e if we move the desired customer name to this
structure(E_KUNNR) it will be shown in the field as the default value when we
create the sales order.
This function also contains a customer include ZXVVA04 . This include
will be used to write our custom code .
Double clicking on this include and it will prompt us that this include does not
exists do you want to create this object ,select yes and the include will be
created .In this include we can write our own code that will fill the field
E_KUNNR.
e.g. E_KUNNR = 301.
Activate the include and Activate the project. Now when ever the SALES
ORDER will be created , sold-to-party field will come up with a predefined
customer .
FIELD EXITS
The field exits are managed,created,activated through program
RSMODPRF. The field exit is associated with a data element existing in
ABAP dictionary and hence to the screen field using that data element.
The format of field exit is :
FIELD_EXIT_dataelement_A-Z or 0-9
If a particular screen and program name is not specified than the field exit
will effect all the screens containing that data element.
The function module associated with field exit shows two parameters
INPUT and OUTPUT. Input parameter contains the data passed to the field
exit when the field exit was invoked by the R/3 , We can write our own code to
change the output parameter depending upon our requirements.
Before the field exit can have any effect the system profile parameter
ABAP/FIELDEXIT in all the application servers should be set to YES
ABAP/FIELDEXIT = YES
http://wiki.sdn.sap.com/wiki/x/
Applies to:
SAP ABAP, my SAP ECC 6.0, for more information, visit the ABAP homepage.
Summary
The enhancement concept allows you to add your own functionality to SAP's standard business
applications without having to modify the original applications. To modify the standard SAP
behavior as per customer requirements, we can use enhancement framework.
This document explains about User exits and Customer Exits.
Author(s) Bio
Tutun Nandy is working with Infosys Technology Ltd since 2008. His expertise includes SAP
ABAP.
Table of Contents
3) Customer Exit........................................................................
6) Screen Exist.........................................................................
7) Menu Exits...........................................................................
User exits
These are implemented in the form of subroutines and hence are also known as FORM EXITs.
The user exits are generally collected in includes and attached to the standard program by the
SAP.
User exits are a type of system enhancement that was originally developed for the R/3 SD (Sales
and distribution) module. User-exits are empty subroutines that SAP Developers have provided
for you. You can fill them with your own source code. Technically this is a modification.
All User exits start with the word USEREXIT_...
FORM USEREXIT_XXXX....
INCLUDE ZZUSEREXIT.......
ENDFORM.
Examples:
- In User exits MV45AFZZ(Sales Order Exit), we have subroutine
USEREXIT_PRICING_PREPARE_TKOMK
USEREXIT_PRICING_PREPARE_TKOMP
This user exit can be used to move additional fields into the communication table which is used
for pricing. TKOMK for header fields and TKOMG for item fields. The fields which are not in
either of the two tables KOMK and KOMP cannot be used in pricing.
zvendpgm (Vendor Program), zpricegrp (Price Group), kvgr5(Airport Code) fields value moving
from VBAP to KOMP table.
- In User exits MV50AFZ1(Delivery Exit), you have subroutine
USEREXIT_SAVE_DOCUMENT_PREPARE
This user exit can be used for changes or checks, before a document is saved.
Customer exits
SAP creates customer exits for specific programs, screens, and menus within standard
applications. These exits do not contain any functionality. Instead, the customer exits act as
hooks. You can hang your own add-on functionality onto these hooks.
Customer exits are nothing but a include in customer name space will be provided in the function
module which starts with CALL CUSTOMER. You can fill them with your own source code.
Technically this is an enhancement. User exits generally refer to SD module while customer
exits refer to all modules like MM, SD, PP, FICO etc.
Advantage:
- They do not affect standard SAP source code
- They do not affect software updates
Disadvantage:
- Customer exits are not available for all programs and screens found in the SAP System. You
can only use customer exits if they already exist in the SAP System.
Before User exits using: No error comes for any Country code.
After User exits using: Error comes for any Country code like 'IN'. Only permissible country
code is 'US'.
2. Screen Exits:
Allow customer to add fields to a screen via a sub screen in an SAP program. The sub screen is
called within the standard screen's flow logic.
Format: CALL CUSTOMER-SUBSCREEN CUSTSCR1
3. Menu exits:
Menu exits allow you to add your own functionality to menus. Menu exits are implemented by
SAP and are reserved menu entries in the GUI interface. The developer can add his/her own text
and logic for the menu.
Function codes for menu exits all start with "+".
Format: +CUS (additional item in GUI status)
Methods to find out customer Exits:
There are numbers of way by using we can find out Customer Exits.
Find(Cntrl+F)
Then use Call customer and select in main program radio button tab and press Enter.
We can find out all the possible Customer exits based on this transaction.
Method # 2: SMOD
Go to Transaction SMOD (SAP Enhancement).
We can find out all the possible Enhancement (Customer exits) based on this package.
Method # 3: SE84
Go to Transaction SE84.
Select Enhancements -> Customer Exits -> Enhancements
Give Package and Execute. We can find out all the possible Enhancement (Customer exits)
based on this Package.
Method # 4: SE81
Go to Transaction SE81.
Click on Module name (ex: SD).
Then from top menu select Edit -> Select sub tree +/-.
Method # 5: ST05
Go to Transaction ST05. Select Table Buffer Trace & Activate Trace.
Then go to the transaction, based on which you want to see the customer exits.
Come back to ST05, Deactivate Trace & display Trace.
Then go to FIND & write text EXIT_ & press ENTER.
We can find out all the possible Enhancement (Customer exits) based on this Transaction .This
is not good technique to find out customer exits because all the possible exits may not be find out
using this technique.
SAP Enhancements (SMOD):
This transaction is used to see the list of objects in an enhancement. It is a container which holds
many related objects within it.
If you Double click on TEST button, you will get below screen.
From the above screen shot we can say that the Function Exit is already implemented (Green
light) but in Inactive stage (Red light).
Project Creation (CMOD):
This Transaction is used to create a project. Project is also a container, which holds several
Enhancements. If we identify the User Exits and write down the code only within it, then the
functionality will not be worked. That is why we require adding the enhancement into a project
& making it active.
CMOD Transaction is used to create a project.
Select Enhancement assignments and you add your Enhancement in this project.
You can add multiple Enhancements in one project. But you can't add one enhancement in
multiple projects. Then error message will be generated.
Error message generate, because Enhancement V45A0002 is already exist in other project.
From screen short no: 2 of CMOD description, if we click on Components, we will get the list of
Customer exits belongs to these enhancements.
Both green light shows that the exit is already implemented & is Active stage.
Table Description