Holon Platform JSON Module - Reference Manual

Total Page:16

File Type:pdf, Size:1020Kb

Holon Platform JSON Module - Reference Manual Holon Platform JSON Module - Reference manual Table of Contents 1. Introduction. 2 1.1. Sources and contributions . 3 2. Obtaining the artifacts . 3 2.1. Using the Platform BOM . 4 3. What’s new in version 5.2.x. 4 4. What’s new in version 5.1.x. 4 5. PropertyBox type handling . 4 5.1. Serialization . 5 5.1.1. PropertyBox properties serialization strategy. 5 5.2. Deserialization. 6 5.3. Property set serialization and deserialization strategies. 7 6. Date and time data types . 8 6.1. java.time.* data types support . 8 6.2. java.util.Date serialization and deserialization . 9 7. The Json API . 9 7.1. Obtain an implementation . 9 7.1.1. Currently available implementations . 10 7.2. Serialization. 10 7.2.1. PropertyBox serialization . 11 7.2.2. Generic Collections serialization. 12 7.3. Deserialization . 13 7.3.1. PropertyBox deserialization. 14 7.3.2. JSON arrays deserialization . 14 8. Supported JSON libraries . 15 9. Jackson integration . 15 9.1. Jackson ObjectMapper configuration . 15 9.1.1. PropertyBox type support. 16 9.1.2. PropertyBox serialization configuration. 17 9.1.3. Jackson java.time.* data types support . 17 9.1.4. ISO-8601 java.util.Date serialization . 18 9.2. Jackson Json API implementation. 19 9.3. JAX-RS integration . 19 9.3.1. PropertyBox type deserialization . 20 9.3.2. Deal with the JAX-RS context ObjectMapper instance . 22 9.3.3. JAX-RS integration configuration . 23 9.4. Spring integration. 23 9.5. Spring Boot integration . 24 10. Gson integration. 24 10.1. Gson GsonBuilder configuration . 25 10.1.1. PropertyBox type support . 25 10.1.2. PropertyBox serialization configuration . 26 10.2. Gson java.time.* data types support. 27 10.3. ISO-8601 java.util.Date serialization . 27 10.4. Gson Json API implementation . 28 10.5. JAX-RS integration . 29 10.5.1. PropertyBox type deserialization . 29 10.5.2. Deal with the JAX-RS context Gson instance . 31 10.5.3. JAX-RS integration configuration . 32 10.6. Spring integration . 32 10.7. Spring Boot integration. 33 11. Loggers . 33 12. System requirements . 34 12.1. Java . 34 Copyright © 2016-2019 Copies of this document may be made for your own use and for distribution to others, provided that you do not charge any fee for such copies and further provided that each copy contains this Copyright Notice, whether distributed in print or electronically. 1. Introduction The Holon Platform JSON module provides the support for the JSON data-interchange format, including configuration facilities, data abstraction, PropertyBox type support and seamless integration with the most popular JSON mapping and processing libraries: Jackson and Gson. Through the Json API, the JSON serialization and deserialization using Java object types can be handled in an abstract and implementation-independent way, easily dealing with common JSON mapping concerns such as temporal types consistent support and generic collection types, besides a full support of the Holon platform Property model out-of-the-box. Furthermore, the JSON module faces the following integration concerns: • Gson GsonBuilder configuration • Jackson ObjectMapper configuration • Full support of the Java 8 date and time API for the java.time.* data types serialization and deserialization • Consistent Date data types handling using the ISO-8601 format • JAX-RS integration and auto-configuration • Spring boot auto-configuration 1.1. Sources and contributions The Holon Platform JSON module source code is available from the GitHub repository https://github.com/holon-platform/holon-json. See the repository README file for information about: • The source code structure. • How to build the module artifacts from sources. • Where to find the code examples. • How to.
Recommended publications
  • So Many Date Formats: Which Should You Use? Kamlesh Patel, Jigar Patel, Dilip Patel, Vaishali Patel Rang Technologies Inc, Piscataway, NJ
    Paper – 2463-2017 So Many Date Formats: Which Should You Use? Kamlesh Patel, Jigar Patel, Dilip Patel, Vaishali Patel Rang Technologies Inc, Piscataway, NJ ABSTRACT Nearly all data is associated with some Date information. In many industries, a SAS® programmer comes across various Date formats in data that can be of numeric or character type. An industry like pharmaceuticals requires that dates be shown in ISO 8601 formats due to industry standards. Many SAS programmers commonly use a limited number of Date formats (like YYMMDD10. or DATE9.) with workarounds using scans or substring SAS functions to process date-related data. Another challenge for a programmer can be the source data, which can include either Date-Time or only Date information. How should a programmer convert these dates to the target format? There are many existing Date formats (like E8601 series, B8601 series, and so on) and informants available to convert the source Date to the required Date efficiently. In addition, there are some useful functions that we can explore for deriving timing-related variables. For these methods to be effective, one can use simple tricks to remember those formats. This poster is targeted to those who have a basic understanding of SAS dates. KEYWORDS SAS, date, time, Date-Time, format, informat, ISO 8601, tips, Basic, Extended, Notation APPLICATIONS: SAS v9.2 INTRODUCTION Date and time concept in SAS is very interesting and can be handled very efficiently if SAS programmers know beyond basics of different SAS Date formats and informats along with many different Date functions. There are various formats available to use as per need in SAS.
    [Show full text]
  • ASN.1. Communication Between Heterogeneous Systems – Errata
    ASN.1. Communication between heterogeneous systems – Errata These errata concern the June 5, 2000 electronic version of the book "ASN.1. Communication between heterogeneous systems", by Olivier Dubuisson (© 2000). (freely available at http://www.oss.com/asn1/resources/books‐whitepapers‐pubs/asn1‐ books.html#dubuisson.) N.B.: The first page number refers to the PDF electronic copy and is the number printed on each page, not the number at the bottom of the Acrobat Reader window. The page number in parentheses refers to the paper copy published by Morgan Kaufmann. Page 9 (page 8 for the paper copy): ‐ last line, replace "(the number 0 low‐weighted byte" with "(the number 0 low‐weighted bit". Page 19 (page 19 for the paper copy): ‐ on the paper copy, second bullet, replace "the Physical Layer marks up..." with "the Data Link Layer marks up...". ‐ on the electronic copy, second bullet, replace "it is down to the Physical Layer to mark up..." with "it is down to the Data Link Layer to mark up...". Page 25 (page 25 for the paper copy): second paragraph, replace "that all the data exchange" with "that all the data exchanged". Page 32 (page 32 for the paper copy): last paragraph, replace "The order number has at least 12 digits" with "The order number has always 12 digits". Page 34 (page 34 for the paper copy): first paragraph, replace "it will be computed again since..." with "it will be computed again because...". Page 37 for the electronic copy only: in the definition of Quantity, replace "unites" with "units". Page 104 (page 104 for the paper copy): ‐ in rule <34>, delete ", digits"; ‐ at the end of section 8.3.2, add the following paragraph: Symbols such as "{", "[", "[[", etc, are also lexical tokens of the ASN.1 notation.
    [Show full text]
  • Understanding JSON Schema Release 2020-12
    Understanding JSON Schema Release 2020-12 Michael Droettboom, et al Space Telescope Science Institute Sep 14, 2021 Contents 1 Conventions used in this book3 1.1 Language-specific notes.........................................3 1.2 Draft-specific notes............................................4 1.3 Examples.................................................4 2 What is a schema? 7 3 The basics 11 3.1 Hello, World!............................................... 11 3.2 The type keyword............................................ 12 3.3 Declaring a JSON Schema........................................ 13 3.4 Declaring a unique identifier....................................... 13 4 JSON Schema Reference 15 4.1 Type-specific keywords......................................... 15 4.2 string................................................... 17 4.2.1 Length.............................................. 19 4.2.2 Regular Expressions...................................... 19 4.2.3 Format.............................................. 20 4.3 Regular Expressions........................................... 22 4.3.1 Example............................................. 23 4.4 Numeric types.............................................. 23 4.4.1 integer.............................................. 24 4.4.2 number............................................. 25 4.4.3 Multiples............................................ 26 4.4.4 Range.............................................. 26 4.5 object................................................... 29 4.5.1 Properties...........................................
    [Show full text]
  • Array Databases: Concepts, Standards, Implementations
    Baumann et al. J Big Data (2021) 8:28 https://doi.org/10.1186/s40537-020-00399-2 SURVEY PAPER Open Access Array databases: concepts, standards, implementations Peter Baumann , Dimitar Misev, Vlad Merticariu and Bang Pham Huu* *Correspondence: b. Abstract phamhuu@jacobs-university. Multi-dimensional arrays (also known as raster data or gridded data) play a key role in de Large-Scale Scientifc many, if not all science and engineering domains where they typically represent spatio- Information Systems temporal sensor, image, simulation output, or statistics “datacubes”. As classic database Research Group, Jacobs technology does not support arrays adequately, such data today are maintained University, Bremen, Germany mostly in silo solutions, with architectures that tend to erode and not keep up with the increasing requirements on performance and service quality. Array Database systems attempt to close this gap by providing declarative query support for fexible ad-hoc analytics on large n-D arrays, similar to what SQL ofers on set-oriented data, XQuery on hierarchical data, and SPARQL and CIPHER on graph data. Today, Petascale Array Database installations exist, employing massive parallelism and distributed processing. Hence, questions arise about technology and standards available, usability, and overall maturity. Several papers have compared models and formalisms, and benchmarks have been undertaken as well, typically comparing two systems against each other. While each of these represent valuable research to the best of our knowledge there is no comprehensive survey combining model, query language, architecture, and practical usability, and performance aspects. The size of this comparison diferentiates our study as well with 19 systems compared, four benchmarked to an extent and depth clearly exceeding previous papers in the feld; for example, subsetting tests were designed in a way that systems cannot be tuned to specifcally these queries.
    [Show full text]
  • Representation of Date and Time Data Standard
    REPRESENTATION OF DATE AND TIME DATA STANDARD Standard No.: EX000013.1 January 6, 2006 This standard has been produced through the Environmental Data Standards Council (EDSC). Representation of Date and Time Data Standard Std No.: EX000013.1 Foreword The Environmental Data Standards Council (EDSC) identifies, prioritizes and pursues the creation of data standards for those areas where information exchange standards will provide the most value in achieving environmental results. The Council involves Tribes and Tribal Nations, state and federal agencies in the development of the standards and then provides the draft materials for general review. Business groups, non-governmental organizations, and other interested parties may then provide input and comment for Council consideration and standard finalization. Standards are available at http://www.epa.gov/datastandards 1.0 INTRODUCTION This is a format standard which indicates how one displays a particular day within a Gregorian calendar month and specifies an instance of time in the day. Time is expressed in Coordinated Universal Time (UTC). UTC is the official time scale, maintained by the Bureau International des Poids et Mesures (BIPM), and the International Earth Rotation Service (IERS). Examples of the formats follow: a. Date only format When the need is for an expression only of a calendar date, then the complete representation shall be a single numeric data element comprising eight digits, where [YYYY] represents a calendar year, [MM] the ordinal number of a calendar month within the calendar year, and [DD] the ordinal number of a day within the calendar month. Extended format: YYYY-MM-DD EXAMPLE 1985-04-12 b.
    [Show full text]
  • Flask-JSON Documentation Release 0.3.4
    Flask-JSON Documentation Release 0.3.4 Sergey Kozlov Aug 23, 2019 Contents 1 Installation 3 2 Initialization 5 3 Basic usage 7 4 Examples 9 5 Creating JSON responses 11 5.1 Jsonify HTTP errors........................................... 13 6 Encoding values 15 6.1 Iterables................................................. 15 6.2 Time values................................................ 15 6.3 Translation strings............................................ 16 6.4 Custom types............................................... 16 6.5 Encoding order.............................................. 17 7 Errors handing 19 8 JSONP support 21 9 Testing 23 10 Configuration 25 11 API 29 11.1 Low-Level API.............................................. 34 12 Flask-JSON Changelog 37 12.1 0.3.4................................................... 37 12.2 0.3.3................................................... 37 12.3 0.3.2................................................... 37 12.4 0.3.1................................................... 37 12.5 0.3.0................................................... 37 12.6 0.2.0................................................... 38 12.7 0.1.................................................... 38 12.8 0.0.1................................................... 38 i Index 39 ii Flask-JSON Documentation, Release 0.3.4 Flask-JSON is a simple extension that adds better JSON support to Flask application. It helps to handle JSON-based requests and provides the following features: • json_response() and @as_json to generate JSON responses.
    [Show full text]
  • Audit Data Standards
    August 2013 Audit Data Standards Base Standard AuditDataStandards.Base.August2013 Prepared by the AICPA Assurance Services Executive Committee Emerging Assurance Technologies Task Force aicpa.org/FRC aicpa.org/FRC Permission to utilize, copy, distribute and/or transmit the Work (including the right to make commercial use thereof) is permitted, as long as an attribution statement substantially in the following form is prominently included within your product or material: “Copyright 2013 by American Institute of Certified Public Accountants, Inc. (AICPA). All rights reserved. Used with permission.” Any such utilization is further conditioned upon there being no suggestion that AICPA endorses either the person, firm or other entity utilizing the Work or the actual use being made of the Work. No derivative rights are included within or by this grant of permission. To inquire about additional permission issues or to utilize the Work in any other fashion, contact AICPA’s Permissions Team: [email protected]. Page 2 of 14 Assurance Services Executive Committee (2012–2013) William R. Titera, Chair Chris Kradjan Dorsey Baskin Mark Mayberry Greg Bedard Fain McDaniel Robert Dohrer Beth Schneider Glenn Galfond Leslie Thompson Theresa Grafenstine Miklos Vasarhelyi Charles Harris Emerging Assurance Technologies Task Force Audit Data Standard Working Group William R. Titera, Chair Kristine Hasenstab Glenn Galfond, Lead Steven Henchock Paul Barbour Mark Mayberry Karl Busch Phillip McCollough Thomas Duncan Joel Pinkus Charles Harris Miklos Vasarhelyi Additional Contributors Eric E. Cohen Gianluca Garbellotto D.J. Elmore Fain McDaniel AICPA Staff Amy Pawlicki Dorothy McQuilken Director Manager Business Reporting, Assurance and Advisory Business Reporting, Assurance and Advisory Services Services Page 3 of 14 Audit Data Standards The benefits of standardization are well-recognized and have led to the development of various general IT standards.
    [Show full text]
  • Parts 43 and 45 Technical Specifications
    CFTC Technical Specification Parts 43 and 45 swap data reporting and public dissemination requirements September 17, 2020 Version 2.0 This Technical Specification document (“Tech Spec”) provides technical specifications for reporting swap data to Swap Data Repositories (SDRs) under parts 43 and 45. i TABLE OF CONTENTS INDEX OF DATA ELEMENTS ........................................................................................................................................................................................... III 1 INTRODUCTION ................................................................................................................................................................................................. VI 1.1 BACKGROUND .................................................................................................................................................................................................................. VI 1.2 STRUCTURE AND DESCRIPTION OF COLUMN HEADINGS ............................................................................................................................................................ VI 1.3 EXPLANATION OF DATA ELEMENT OR CATEGORY .................................................................................................................................................................... IX 1.4 UNIQUE PRODUCT IDENTIFIER (UPI) ....................................................................................................................................................................................
    [Show full text]
  • International Standard Iso 8601-1:2019(E)
    This preview is downloaded from www.sis.se. Buy the entire standard via https://www.sis.se/std-80010314 INTERNATIONAL ISO STANDARD 8601-1 First edition 2019-02 Date and time — Representations for information interchange — Part 1: Basic rules Date et heure — Représentations pour l'échange d'information — Partie 1: Règles de base Reference number ISO 8601-1:2019(E) © ISO 2019 This preview is downloaded from www.sis.se. Buy the entire standard via https://www.sis.se/std-80010314 ISO 8601-1:2019(E) COPYRIGHT PROTECTED DOCUMENT © ISO 2019 All rights reserved. Unless otherwise specified, or required in the context of its implementation, no part of this publication may be reproduced or utilized otherwise in any form or by any means, electronic or mechanical, including photocopying, or posting on the internet or an intranet, without prior written permission. Permission can be requested from either ISO at the address belowCP 401or ISO’s • Ch. member de Blandonnet body in 8 the country of the requester. ISO copyright office Phone: +41 22 749 01 11 CH-1214 Vernier, Geneva Fax:Website: +41 22www.iso.org 749 09 47 PublishedEmail: [email protected] Switzerland ii © ISO 2019 – All rights reserved This preview is downloaded from www.sis.se. Buy the entire standard via https://www.sis.se/std-80010314 ISO 8601-1:2019(E) Contents Page Foreword ..........................................................................................................................................................................................................................................v
    [Show full text]
  • Universal User Guide TCM-X Current Meters, MAT-1 Data Logger
    Universal User Guide for TCM-x Current Meters, MAT-1 Data Logger and Domino Software Lowell Instruments, LLC 82 Technology Park Dr. East Falmouth, MA 02536 www.lowellinstruments.com Phone: 508-444-2616 Email: [email protected] Universal User Guide, Rev K, December 2020 © 2014-2020 Lowell Instruments, LLC Contents Contents ........................................................................................................................................................ 2 1 Introduction .......................................................................................................................................... 5 1.1 How to use this manual ................................................................................................................... 5 2 Getting Started ...................................................................................................................................... 6 2.1 Installing Software ........................................................................................................................... 6 2.2 Connect to the Logger...................................................................................................................... 6 2.3 Create a Setup File ........................................................................................................................... 7 2.4 Save File on MAT-1 Logger drive ...................................................................................................... 8 2.5 Communicating with the
    [Show full text]
  • International Standard Iso/Iec 29341
    INTERNATIONALThis is a preview - click here to buy the full publication ISO/IEC STANDARD 29341-30-11 First edition 2017-06 Information technology — UPnP Device Architecture — Part 30-11: IoT management and control device control protocol — IoT management and control data model service Technologies de l’information — Architecture de dispositif UPnP — Partie 30-11: Protocole de contrôle de dispositif de gestion et de contrôle de l’Internet des objets — Service de modèle de données de gestion et de contrôle de l’Internet des objets Reference number ISO/IEC 29341-30-11:2017(E) © ISO/IEC 2017 ISO/IEC 29341-30-11:2017(E)This is a preview - click here to buy the full publication COPYRIGHT PROTECTED DOCUMENT © ISO/IEC 2017, Published in Switzerland All rights reserved. Unless otherwise specified, no part of this publication may be reproduced or utilized otherwise in any form orthe by requester. any means, electronic or mechanical, including photocopying, or posting on the internet or an intranet, without prior written permission. Permission can be requested from either ISO at the address below or ISO’s member body in the country of Ch. de Blandonnet 8 • CP 401 ISOCH-1214 copyright Vernier, office Geneva, Switzerland Tel. +41 22 749 01 11 Fax +41 22 749 09 47 www.iso.org [email protected] ii © ISO/IEC 2017 – All rights reserved This is a preview - click here to buy the full publication ISO/IEC 29341-30-11:2017(E) CONTENTS 1 Scope .......................................................................................................................... viii 2 Normative References ................................................................................................... 1 3 Terms, Definitions and Abbreviations ............................................................................. 2 4 Notations and conventions ............................................................................................. 2 4.1 Notation ..............................................................................................................
    [Show full text]
  • Sc22/Wg20 N1085
    WG14 N1038 Ballot resolution for SC 22 N3210 C Locale for Registration with ISO/IEC 15897 Netherlands NEN (the Dutch NB) supports the registration of N3210 as the C locale with the following comments: 1. differences between the (text of) the POSIX locale and the C locale may cause confusion, and should therefore be eliminated. As the POSIX locale is part of ISO 9945, and hence cannot easily be changed, it is recommended to make the C locale identical to the POSIX locale as follows: in Clause 3, replace the specification for FULL STOP from '<.>' to '"."' Response: Agreed (editorial). 2. in the C Standard Locale, replace the Charset from ‘ISO_646.IRV:1991' to 'ISO646:1993'. Response: Not accepted. Charmaps referenced need to be registered also. 'ISO_646.IRV:1991' is a registered charmap with ISO/IEC 15897, while there is no registration named 'ISO646:1993'. 3. once the POSIX locale is removed from the ISO 9945 standard, WG15 and WG14 are recommended to revise the registered POSIX and C locales, in order to align the specifications with the ISO 8601 standard for date formats (i.e., replace the mm/dd/yy format by the yyyy/mm/dd format). Response: Not accepted. The format mm/dd/yy is prescribed normatively for the standard C locale in the ISO/IEC 9899:1999 standard clause 7.23.3.5 item 7. Sweden - 'O' Member 1. The date format should be according to ISO 8601:2001 (with full year representation). This allows for easy collation in datetime order of the formatted results. Response: Not accepted.
    [Show full text]