Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@sap/xsodata

Package Overview
Dependencies
Maintainers
3
Versions
46
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@sap/xsodata

Expose data from a HANA database as OData V2 service with help of .xsodata files.

  • 3.4.0
  • npm
  • Socket score

Version published
Weekly downloads
960
increased by47.47%
Maintainers
3
Weekly downloads
 
Created
Source

XSODATA

Expose data from HANA database artefacts like tables or views as OData V2 service with the help of .xsodata service definition files.

Note: XSOData was developed to provide XS Classic users using XSOData the possibility to migrate to XS Advanced on node.js. This library contains nearly the same feature set as XSOData provided on SAP HANA XS Classic. This module is already in maintenance mode and it is not planned to extend or enhance it.

  If you want to create new OData services we strongly reoommend to use OData V4 along with a generic CDS-OData provider.
  Here you can model your consumption persistency model with CDS (Core Data Services) and expose parts or the complete
  model as OData service. Such a solution is already productively available on the JAVA runtime stack. 
  
  For node.js we also provide an OData V4 solution. The development of the OData V4 node.js Library already started in 2016.
  It is also planned that a generic CDS-Odata provider will be deliverd.

Usage

  • This module is used in the XSJS shim for SAP HANA XSC Engine applications to allow the reuse of .xsodata files from XSC applications on SAP HANA XSA.

  • It can also be used directly in your own nodejs server application. Be aware that you use the same version of the hdb and winston node module version in your application.

Warning

  • The xsodata library CHANGES the TRANSACTION ISOLATION LEVEL on the used database connection
  • The xsodata library CHANGES the SCHEMA on the used database connection
  • The xsodata library uses temporary tables for performance reasons
  • If you manually modify the db-connection/client inside xsodata-application-exits the modifications you have done will not be restored by the xsodata library

So the user of the xsodata library should clean the database connection

Features - Overview

  • Automatic metadata handling based on XSOData definition and HANA db metadata artifacts
  • OData request handling with URI parsing including system query options
  • OData request/response serialization and deserialization
  • Load table records from HANA database via generated SQL queries
  • Calculation view support
  • Batch handling

Supported OData V2 Features:

GET Requests:

  • URI0 = scheme serviceRoot
  • URI1 = scheme serviceRoot "/" entitySet
  • URI2 = scheme serviceRoot "/" entitySet "(" keyPredicate ")"
  • URI6 = scheme serviceRoot "/" entitySet "(" keyPredicate ")/" entityNavProperty
  • URI7 = scheme serviceRoot "/" entitySet "(" keyPredicate ")/$links/" entityNavProperty
  • URI8 = scheme serviceRoot "/$metadata"
  • URI9 = scheme serviceRoot "/$batch"
  • URI15 = scheme serviceRoot "/" entitySet count

CreateUpdateDelete Requests:

  • CUD - Entity
  • CUD - Link

System Query options:

  • $top
  • $skip
  • $filter, except for:
    • comparison of navigation properties
  • $orderby, except for:
    • comparison of navigation properties
  • $expand
  • $select
  • $format
    • only json supported
  • $inlinecount

Supported HTTP methods per requests type

Supported XS1 OData features (defined in the XSOData file):

  • Definition of OData schema namespace
  • OData Service exposure
  • Metadata caching
  • Create/update/delete restrictions of OData requests
  • Exposure of table and views (including calculation views) as EntitySet
  • Property Projection: Expose a subset of the table columns as properties of an OData EntityType
  • [Automatic OData key generation] (/documentation/generatedKeys.md), e.g. required for aggregated views
  • Simple and complex associations
  • [Data aggregation] (/documentation/aggregations.md)
  • Parameter EntitySets for calculation views
  • ETAG handling
  • Nullable properties
  • Cache Control via cache header
  • [Custom exits] (/documentation/customExits.md) (JavaScript and SQL Script) for modification and validation requests
  • Custom exits in batch requests
  • Uses only UTF-8
  • Uses "content-type: application/json" for CREATE, UPDATE, DELETE
  • Expose data only via JSON format (ATOM format is not supported)
  • Supported types and type mapping see here
  • [Supported XSOData features by OSDL] (/documentation/xsodataEbnf.md)

Note:

  • XS1 applications using analytical views, attribute views or calculation views <= SAP HANA SPS 10 have to migrate first their views to the new calculation views of SPS 11.
  • Authentication/Authorisation is not handled by XSOData node module and has to be done by the application using the node module.
  • [The module can be used in development mode and productive mode] (/documentation/modes.md)
  • [Debug View is available when using the module in development mode] (/documentation/debugView.md)

Features per HANA DB Artifact

Table

Supports the following Features:

Supported Http Verbs:

  • GET, PUT, POST, DELETE

SQL View

Supports the following Features:

Supported Http Verbs:

  • GET

XS Advanced Calculation View

Supports the following Features:

Supported Http Verbs:

  • GET

Samples

New features with xsodata 3.0.0:

  • Fixed conversion of binary data if generated key are used
  • Support Node.js 4.x.x, 6.x.x and newly 8.x.x
  • Deprecated 0.12.9

New features with xsodata 2.4.0:

  • Add "hints" setting to xsodata file definition to provide custom hints for SQL-select

New features with xsodata 2.3.0:

  • Fixed __metadata Uri in payload: name/value key pairs are now correct
  • Rollback performed also for non batch modifications
  • Improved cleanup of temporary tables
  • Improved error message when using key property with point '.'
  • Before/After commit exits also called for non batch modifications
  • Updated dependencies

Modifications with SAP HANA XSA 2.0 SPS 2:

  • Request specific logging
  • I18N support for language specific metadata, e.g. labels in annotations
  • Update of Open Source libraries
  • Several smaller bugfixes

Modifications with SAP HANA XSA 2.0 SPS 1:

  • Switch to scoped package name @sap/xsodata
  • Support for node.js version 4.X.X & 6.9.X

New Features with SAP HANA XSA 2.0 SPS 0:

New Features with SAP HANA XSA SPS 12:

  • Support for $links requests
  • Custom exits for $links requests (modification requests only)
  • Support for node.js version 0.12.X & 4.4.X

Keywords

FAQs

Package last updated on 11 Jun 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc