Contents Implementation & Administration Guide 1.1 Previous Next

Adding Applications and Widgets to the Portal

To expand the functionality of the SAS Information Delivery Portal, you can develop your own custom Java Server Pages (JSPs) that take advantage of the portal's content, metadata, and security services. These services are available through the portal's Application Programming Interfaces (APIs). Using these APIs, you can implement robust data analysis and reporting features with minimal programming effort.

Custom JSPs can be deployed in the portal either as widgets or as applications. A widget (also referred to as a portlet) is a graphical user interface (GUI) component that is produced by a JSP. A widget can be hosted within a portal window or within a custom application. An application is a Web application deployed in the Portal that is composed of JSPs and other resources. Applications are launched from within the portal, and they run outside of the portal container. In either scenario, the portal framework provides a secure and convenient platform on which to deploy custom-developed JSPs and make them available to the appropriate users.

Both applications and widgets leverage the portal's APIs for content, metadata, and security services. However, they differ from one another in several ways, as described in the following table:

A widget... An application...
...generates an HTML fragment that is hosted by the portal (or by a custom application that is launched from the portal). ...is a Web application that is launched from the portal.
...is a generic presentation component driven by parameters. ...can perform any type of function, and is sometimes driven by parameters.
...is subject to the navigation features of the portal (or other host application). ...has its own navigation features.
...appears within a window on the portal (or within the host application's user interface).
Portal screen with sample widget
...is launched in a separate browser window.
Portal screen, with application in separate browser window

Note: If an application does not use the services of the portal, you should implement it as a link from the portal, not as an application.

To design and develop a custom widget or application for deployment in the portal, you should have a working knowledge of JSPs, Java servlets, and the Java programming language. Follow these steps to develop a custom JSP (widget or application) and add it to the portal:

  1. Design the widget or application.

  2. Code the widget or application.

  3. Install the widget or application and its associated files in the portal web application.

  4. Use the Personalize tool to add the widget or application to the portal's enterprise directory.

  5. Add the data sources to the portal's enterprise directory.

  6. Define access rules for the widget or application and for the data sources.

  7. Use the Personalize tool to make the widget or application appear as a selection on the portal.

Step 1: Design the Widget or Application

As you design a widget or application to be implemented in the SAS Information Delivery Portal, you should consider the following questions:

Step 2: Code the Widget or Application

To design and develop a custom widget or application for deployment in the portal, you should have a working knowledge of JSPs, Java servlets, and the Java programming language. If you wish, you can develop the widget or application using the SAS webAF development platform. The webAF software is part of SAS AppDev Studio, which is provided in the SAS Information Delivery Portal package.

To assist you in the development process, several sample applications and widgets are provided with the SAS Information Delivery Portal. You can view the source code for these samples, along with brief explanatory comments, by accessing the following links:

When coding an application or a widget for deployment in the portal, it is important to follow these basic guidelines:

Step 3: Install the Widget or Application and Its Associated Files in the Portal Web Application

To install the widget or application in the portal Web application, follow these steps:

  1. Move or copy the JSP that invokes the application or widget, along with its supporting resource files, to the appropriate path in the portal's setup directory. This path must be in or under the directory that contains the JSP files for the portal application. The four sample applications reside in the path /jsp/html/samples. For effective management of the portal, you should create a separate directory structure, such as /jsp/custom, for your custom widgets and applications.

  2. If the application or widget requires Java classes, place them in the path Portal/WEB-INF/classes. The subdirectory name should match the name of the package that contains the classes.

  3. If the application or widget requires JAR files, place them in the path Portal/WEB-INF/lib.

  4. Run the PortalConfigure program, and deploy the resulting WAR file in the servlet container. For detailed installation instructions, see the readme file that accompanies the portal package.

Step 4: Use the Personalize Tool to Add the Widget or Application to the Portal's Enterprise Directory

Use the portal's Personalize tool to add the application or widget to the portal. This tool provides a graphical user interface for entering the metadata for the application or widget. The metadata includes the path and file name of the main JSP, as well as information about parameters and their default values. For detailed instructions, refer to Adding and Editing Personal Applications, Adding and Editing Role-Based Applications, Adding and Editing Personal Widgets, or Adding and Editing Role-Based Widgets in the portal User's Guide.

Step 5: Add the Data Sources to the Portal's Enterprise Directory

If your data sources have already been defined in the enterprise directory, you can skip this step.

To enable the widget or application to leverage the portal's content and security features, you must add metadata to the portal's enterprise directory to define each SAS table, MDDB, or other data source that will provide input. The SAS servers, spawners, and logins associated with the data sources must also be defined. You can then use methods from the Enterprise Directory SDK to access these resources.

To create metadata for SAS data sources, you can use the Integration Technologies Administrator application. For details, refer to the SAS Integration Technologies Administrator page on the SAS Integration Technologies Web site. For an overview of metadata requirements for the portal, refer to Adding SAS Content and related sections in this manual.

Note: Although the metadata for application and widget data sources must be added to the enterprise directory, it is not necessary for these data sources to be surfaced on portal lists.

Step 6: Define Access Rules for the Widget or Application and for Its Data Sources

Take any necessary steps to control access to the application or widget and its data sources. For general information about access control, refer to Controlling Access to Portal Content.

Step 7: Use the Personalize Tool to Make the Widget or Application Appear as a Selection on the Portal

Depending on who has access permission to the application or widget, you can use one of several methods to make it appear as a selection on the portal:

For more information, refer to the Personalization topic in the portal User's Guide.


Contents Implementation & Administration Guide 1.1 Previous Next

Copyright © 2025 SAS Institute Inc. All Rights Reserved.