15 REST Service Support
This chapter provides additional technical details about how the Oracle Visual Builder Add-in for Excel supports integration with REST services. It also provides information about technical known issues and limitations.
Service Descriptions
To create a layout in the workbook, the REST services that you use must provide a service description that complies with the OpenAPI specification. The service description can be a URL or a local file. For Oracle business object REST API services, the URL typically includes a describe, as in https://my-service-host/fscmRestApi/resources/latest/invoices/describe. For an Oracle REST Data Services (ORDS), the URL may be similar to https://host/ords/great_app/open-api-catalog/employees/. 
                  
You can provide the service description document when you create a layout by clicking Designer in the Oracle Visual Builder tab (see Create Layouts in an Excel Workbook). You can also provide the service description document by clicking Manage Catalogs in the Oracle Visual Builder tab (see Edit Service Descriptions and Business Objects).
Service Types
- Oracle business object REST API services
                           - Uses and requires REST API framework version 6
- Provides search editor capabilities
- Supports the ability to upload in batches
- Supports finders
 
- Oracle REST Data Services (ORDS)
                           - Provides search editor capabilities
 
The add-in can also be used with other service types as long as the service behaves as the add-in expects.
Supported Data Types
The Oracle Visual Builder Add-in for Excel supports a variety of data types exposed by business objects in web applications developed using Visual Builder and data types exposed by REST services.
The add-in supports the following OpenAPI data types (derived from the JSON Schema Specification):
- boolean
- integer
- object
- number
- string
In addition, the add-in recognizes the optional modifier property "format", when it is applied to values of type string. The two formats recognized are "date-time" and "date". There is no support for binary or byte formats or for array-valued fields.
The add-in ignores fields with unsupported data types when you create a Table layout or Form-over-Table layout in the Excel workbook. If, for example, a service that you use to retrieve data includes the attachment attribute data type, the add-in ignores it and does not create a column in the data table for this attribute type.
                  
For more information, see the specifications for OpenAPI and JSON Schema:
Object-typed Fields and Sub-fields
The add-in supports fields of type Object. These fields
                may expose sub-fields, also known as nested fields.
                  
If, for example, you have an Employee business object with the following fields:
- First Name (type: String)
- Last Name (String)
- Address: (Object) 
                        - Street (String)
- City (String)
- State (String)
- Zip (String)
- GPS Coordinates (Object) 
                              - Latitude (Number)
- Longitude (Number)
 
 
- Hire Date (Date)
In this example, the type of the Address field is Object
                and it contains sub-fields. Object fields should not be confused with arrays. In
                this example, an Employee has only one Address. The add-in does not support fields
                that are typed as arrays.
                  
The add-in handles Object fields and their sub-fields in the following manner:
- First, in the Business Object editor Fields tab, only the
                        top-level fields are listed. In this example, the top-level fields are:
                        First Name, Last Name, Address, and Hire Date. To edit the properties for
                        sub-fields of Address, edit Address and find the Sub-fields list on the
                        Field Editor window. The direct sub-fields for Address are Street, City,
                        State, Zip, and GPS Coordinates. Since GPS Coordinates is of type
                            Object, its field editor will show its sub-fields (Latitude, Longitude).
- Next, when creating a Table layout from a business object's
                        fields, the add-in promotes the sub-fields and creates columns for each
                        (leaf) sub-field. This maintains a regular, rectangular structure for the
                        table in the worksheet. So, the above example generates a table with these
                            columns:
                           - First Name
- Last Name
- Address / Street
- Address / City
- Address / State
- Address / Zip
- Address / GPS Coords / Latitude
- Address / GPS Coords / Longitude
- Hire Date
 
REST Operations
Table and Form-over-Table capabilities are enabled as follows:
- Existing row updates are enabled if the item path has either a PUT or PATCH operation. For PATCH operations, the add-in includes all data values from editable cells for the changed row(s) on upload, regardless of whether the data value was edited since download.
- Create new rows is enabled if the collection path has a POST operation
- Delete existing rows is enabled if the item path has a DELETE operation (not supported for Form-over-Table)
Note:
You can choose to disable a layout's capability even if the business object supports the operation, by deselecting it in the Layout Designer's Advanced tab.Language Support
For every request that the add-in makes to the REST service, the add-in automatically adds the accept-language header. By default, the value sent with the accept-language header is the language/culture code that Excel is currently configured to use. You can change the language as described in Change the Add-in's Language. 
                  
Each REST service determines how and whether it will react to the accept-language header.
                  
Oracle REST Data Services
As with other service types, you must provide an OpenAPI description of an ORDS service. ORDS with AutoREST can provide an OpenAPI service description.
For example, use http(s)://myhost.example.com:8888/ords/hr_demo/open-api-catalog/employees/ where:
                  
- myhost.example.com:8888is the host and domain portion
- hr_demois the schema/application
- employeesis the database table
For other ORDS endpoints, you need to find or create an OpenAPI service description. For information about AutoREST, see Automatic Enabling of Schema Objects for REST Access (AutoREST) in Oracle REST Data Services Installation, Configuration, and Development Guide.
Only basic authentication is supported when working with ORDS services.
After importing an ORDS service description, you can use the Business Object Field Editor to provide additional information about each field to improve the overall user experience. For example:
- Edit the field titles
- Designate certain fields as required
- Define lists of values. See Use Lists of Values in an Excel Workbook.
Known Issues with ORDS
- For some row-level errors, the ORDS server does not provide a specific reason for the error.
- In some cases, the ORDS server returns Create Failed for rows, when in fact the Create operation was successful. Re-downloading rows into the table will show the created rows.
- With an ORDS service, the PUT operation on the item path performs an "upsert" (see Update/Insert Table Row in Oracle REST Data Services Installation, Configuration, and Development Guide). So if you are about to update an existing row and someone else deletes that row, your update attempt may re-create that row. There's no warning or notice when this behavior occurs.
- When using ORDS lower than version 19.2, some date-time fields are not recognized as a date-time data type due to faulty service metadata. Use the add-in’s Business Object Field Editor to correct the data type.
REST Service Support Limitations
Many different request and response schema types are possible and we cannot list all that are compatible with the add-in. If a particular structure is not listed explicitly as supported, it may not work.
- Polymorphic business objects cannot be used to create a layout.
- Asymmetrical field lists. Since download, editing, and upload all occurs in the same Excel rectangular grid, the add-in counts on having a single set of field IDs (JSON member names) for both download and upload. If the REST service uses different field IDs for the same information when completing different operations, it cannot be used effectively with the add-in.
- Multi-part primary keys are supported only for Oracle business object REST API services.
- Fields with forward slash ('/') in the member name:
                        - OpenApi documents contain schema properties that represented in JSON as
                            something like "memberName" : { . . . properties describing the field ... }
- When creating the business object field from the JSON member, the add-in uses the member name as the field ID.
- Field IDs that include the / character are incompatible with the add-in, so such members will not be represented as fields in the business object.
 
- OpenApi documents contain schema properties that represented in JSON as
                            something like 
- When providing a URL for an OpenAPI service description,
                        ?metadataMode=minimalis not supported.
If a REST service owner makes significant changes to the service after the workbook is configured to integrate with the service, the integration may not function as expected. In such cases, you will need to re-import the service description and create a new layout. Or, if the change is minor, you may choose to update the business object details to match the change in the service. See Edit Service Descriptions and Business Objects.