/* Options: Date: 2024-10-18 17:24:44 Version: 6.110 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://reportfiling.pwc.de //GlobalNamespace: //AddServiceStackTypes: True //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True IncludeTypes: DeleteElmaCredential.* //ExcludeTypes: //DefaultImports: package:servicestack/servicestack.dart,dart:typed_data */ import 'package:servicestack/servicestack.dart'; import 'dart:typed_data'; /** * Represents a PEM-encoded certificate. */ // @Api(Description="Represents a PEM-encoded certificate.") class PemCertificate implements IConvertible { /** * The unique identifier (e.g. the file name) of the certificate. */ // @ApiMember(Description="The unique identifier (e.g. the file name) of the certificate.", IsRequired=true, Name="Id") String? id; /** * The PEM-encoded content of the certificate. */ // @ApiMember(Description="The PEM-encoded content of the certificate.", IsRequired=true, Name="Content") String? content; /** * The description of the certificate. */ // @ApiMember(Description="The description of the certificate.", Name="Description") String? description; /** * Tags to label or identify the certificate. */ // @ApiMember(Description="Tags to label or identify the certificate.", Name="Tags") List? tags; PemCertificate({this.id,this.content,this.description,this.tags}); PemCertificate.fromJson(Map json) { fromMap(json); } fromMap(Map json) { id = json['id']; content = json['content']; description = json['description']; tags = JsonConverters.fromJson(json['tags'],'List',context!); return this; } Map toJson() => { 'id': id, 'content': content, 'description': description, 'tags': JsonConverters.toJson(tags,'List',context!) }; getTypeName() => "PemCertificate"; TypeContext? context = _ctx; } /** * Represents the credentials of a user to authenticate the access of an ELMA server. */ // @Api(Description="Represents the credentials of a user to authenticate the access of an ELMA server.") class ElmaCredential implements IElmaCredential, IConvertible { /** * The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval. */ // @ApiMember(Description="The unique identifier of this instance. This identifer is only relevant in the context of data storage and retrieval.", IsRequired=true, Name="Id") String? id; /** * The security certificate to authenticate the user and grant access to the ELMA server. This certificate is generated from the BZSt-issued *.pfx BOP certificate. More details on BOP (BZSt-Online Portal - https://www.elster.de/bportal/start) */ // @ApiMember(Description="The security certificate to authenticate the user and grant access to the ELMA server. This certificate is generated from the BZSt-issued *.pfx BOP certificate. More details on BOP (BZSt-Online Portal - https://www.elster.de/bportal/start)", IsRequired=true, Name="Certificate") // @required() // @StringLength(2147483647) PemCertificate? certificate; /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ // @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") // @required() // @StringLength(11) String? authSteuernummer; /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ // @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") // @required() // @StringLength(10) String? accountId; /** * The password to protect the certificate from unauthorized access. */ // @ApiMember(Description="The password to protect the certificate from unauthorized access.", IsRequired=true, Name="Password") String? password; ElmaCredential({this.id,this.certificate,this.authSteuernummer,this.accountId,this.password}); ElmaCredential.fromJson(Map json) { fromMap(json); } fromMap(Map json) { id = json['id']; certificate = JsonConverters.fromJson(json['certificate'],'PemCertificate',context!); authSteuernummer = json['authSteuernummer']; accountId = json['accountId']; password = json['password']; return this; } Map toJson() => { 'id': id, 'certificate': JsonConverters.toJson(certificate,'PemCertificate',context!), 'authSteuernummer': authSteuernummer, 'accountId': accountId, 'password': password }; getTypeName() => "ElmaCredential"; TypeContext? context = _ctx; } /** * Specfies a service to the delete an ELMA credential. */ // @Api(Description="Specfies a service to the delete an ELMA credential.") abstract class DeleteElmaCredentialBase implements IPost { /** * The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under "My BOP" under the "Registration Information" */ // @ApiMember(Description="The BZSt (Bundeszentralamt für Steuern) - tax number of the user. 11-character text field that may only consist of two capital letters and 9 digits (0-9). The fiscal authority BZSt provides this number during registration at the BOP (BZSt-Online Portal - https://www.elster.de/bportal/start). The number is available in the private area of the BOP user account under \"My BOP\" under the \"Registration Information\"", IsRequired=true, Name="AuthSteuernummer") String? authSteuernummer; /** * The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9). */ // @ApiMember(Description="The account identifier of a BZSt-Online Portal (BOP) user. 10-character text field that may only contain numbers (0-9).", IsRequired=true, Name="AccountId") String? accountId; /** * The password that protects the credential certificate from unauthorized access. */ // @ApiMember(Description="The password that protects the credential certificate from unauthorized access.", IsRequired=true, Name="Password") String? password; DeleteElmaCredentialBase({this.authSteuernummer,this.accountId,this.password}); DeleteElmaCredentialBase.fromJson(Map json) { fromMap(json); } fromMap(Map json) { authSteuernummer = json['authSteuernummer']; accountId = json['accountId']; password = json['password']; return this; } Map toJson() => { 'authSteuernummer': authSteuernummer, 'accountId': accountId, 'password': password }; getTypeName() => "DeleteElmaCredentialBase"; TypeContext? context = _ctx; } abstract class IElmaCredential { PemCertificate? certificate; String? authSteuernummer; String? accountId; String? password; } /** * Represents a service response that encapsulates an ELMA credential. The password of the ELMA credential in this response is encrypted and can only be decrypted by the owner of the private key. */ // @Api(Description="Represents a service response that encapsulates an ELMA credential. The password of the ELMA credential in this response is encrypted and can only be decrypted by the owner of the private key.") class ElmaCredentialResponse implements IConvertible { /** * The unique identifier of the response. */ // @ApiMember(Description="The unique identifier of the response.", Name="Id") String? id; /** * The encapsulated ELMA credential. */ // @ApiMember(Description="The encapsulated ELMA credential.", Name="Credential") ElmaCredential? credential; /** * The status of the response. */ // @ApiMember(Description="The status of the response.", Name="ResponseStatus") ResponseStatus? responseStatus; ElmaCredentialResponse({this.id,this.credential,this.responseStatus}); ElmaCredentialResponse.fromJson(Map json) { fromMap(json); } fromMap(Map json) { id = json['id']; credential = JsonConverters.fromJson(json['credential'],'ElmaCredential',context!); responseStatus = JsonConverters.fromJson(json['responseStatus'],'ResponseStatus',context!); return this; } Map toJson() => { 'id': id, 'credential': JsonConverters.toJson(credential,'ElmaCredential',context!), 'responseStatus': JsonConverters.toJson(responseStatus,'ResponseStatus',context!) }; getTypeName() => "ElmaCredentialResponse"; TypeContext? context = _ctx; } /** * Represents a service to the delete an ELMA credential. */ // @Route("/sync/elma/credentials/delete", "POST") // @Api(Description="Represents a service to the delete an ELMA credential.") class DeleteElmaCredential extends DeleteElmaCredentialBase implements IReturn, IConvertible, IPost { DeleteElmaCredential(); DeleteElmaCredential.fromJson(Map json) : super.fromJson(json); fromMap(Map json) { super.fromMap(json); return this; } Map toJson() => super.toJson(); createResponse() => ElmaCredentialResponse(); getResponseTypeName() => "ElmaCredentialResponse"; getTypeName() => "DeleteElmaCredential"; TypeContext? context = _ctx; } TypeContext _ctx = TypeContext(library: 'reportfiling.pwc.de', types: { 'PemCertificate': TypeInfo(TypeOf.Class, create:() => PemCertificate()), 'ElmaCredential': TypeInfo(TypeOf.Class, create:() => ElmaCredential()), 'DeleteElmaCredentialBase': TypeInfo(TypeOf.AbstractClass), 'IElmaCredential': TypeInfo(TypeOf.Interface), 'ElmaCredentialResponse': TypeInfo(TypeOf.Class, create:() => ElmaCredentialResponse()), 'DeleteElmaCredential': TypeInfo(TypeOf.Class, create:() => DeleteElmaCredential()), });