2023-04-12 11:39:07 +02:00
/ * *
* @ author sg5506844 [ sg5506844 @ gmail . com ]
* @ copyright Crown Copyright 2021
* @ license Apache - 2.0
* /
import Operation from "../Operation.mjs" ;
import OperationError from "../errors/OperationError.mjs" ;
import rison from "rison" ;
/ * *
* Rison Encode operation
* /
class RisonEncode extends Operation {
/ * *
* RisonEncode constructor
* /
constructor ( ) {
super ( ) ;
this . name = "Rison Encode" ;
2024-04-05 19:10:14 +02:00
this . module = "Encodings" ;
2023-04-12 11:39:07 +02:00
this . description = "Rison, a data serialization format optimized for compactness in URIs. Rison is a slight variation of JSON that looks vastly superior after URI encoding. Rison still expresses exactly the same set of data structures as JSON, so data can be translated back and forth without loss or guesswork." ;
this . infoURL = "https://github.com/Nanonid/rison" ;
this . inputType = "Object" ;
this . outputType = "string" ;
this . args = [
{
name : "Encode Option" ,
2024-04-05 19:10:14 +02:00
type : "option" ,
value : [ "Encode" , "Encode Object" , "Encode Array" , "Encode URI" ]
2023-04-12 11:39:07 +02:00
} ,
] ;
}
/ * *
* @ param { Object } input
* @ param { Object [ ] } args
* @ returns { string }
* /
run ( input , args ) {
const [ encodeOption ] = args ;
switch ( encodeOption ) {
case "Encode" :
return rison . encode ( input ) ;
case "Encode Object" :
return rison . encode _object ( input ) ;
case "Encode Array" :
return rison . encode _array ( input ) ;
case "Encode URI" :
return rison . encode _uri ( input ) ;
2024-04-05 19:10:14 +02:00
default :
throw new OperationError ( "Invalid encode option" ) ;
2023-04-12 11:39:07 +02:00
}
}
}
export default RisonEncode ;