Tax Filing Service

<back to all web services

CreateE50UstXmlFromDefinition

SyncUmsatzsteuerJahressteuererklärungE50ReturnBuilderDefinition

A synchronous service to create XML content that represents an annual VAT return (Umsatzsteuerjahreserklärung) from the specified dictionary (hash map) of key/value definitions.

Requires Authentication
The following routes are available for this service:
POST/CreateE50UstXmlFromDefinition
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum


# @Api(Description="Create a VAT return from a dictionary (hash map) of key/value definitions with a dictionary (hash map) of properties.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreateXmlFromDefinitionBase:
    """
    Create a VAT return from a dictionary (hash map) of key/value definitions with a dictionary (hash map) of properties.
    """

    # @ApiMember(Description="The 4-digit year of the tax assessment.")
    jahr: int = 0
    """
    The 4-digit year of the tax assessment.
    """


    # @ApiMember(Description="Dictionary of key-value pairs that represent the intrinsic properties of the VAT return. Each key represents a name of the VAT property.Each value of the pair represents the VAT property value.")
    properties: Optional[Dict[str, str]] = None
    """
    Dictionary of key-value pairs that represent the intrinsic properties of the VAT return. Each key represents a name of the VAT property.Each value of the pair represents the VAT property value.
    """


# @Api(Description="Represents the response from a service that generates XML content.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class XmlResponse:
    """
    Represents the response from a service that generates XML content.
    """

    # @ApiMember(Description="The XML-based content of the response.")
    content: Optional[str] = None
    """
    The XML-based content of the response.
    """


    # @ApiMember(Description="Metadata that contains structured error information on the XML response.")
    response_status: Optional[ResponseStatus] = None
    """
    Metadata that contains structured error information on the XML response.
    """


# @Api(Description="A synchronous service to create XML content that represents an annual VAT return (Umsatzsteuerjahreserklärung) from the specified dictionary (hash map) of key/value definitions.")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class CreateE50UstXmlFromDefinition(CreateXmlFromDefinitionBase, IPost):
    """
    A synchronous service to create XML content that represents an annual VAT return (Umsatzsteuerjahreserklärung) from the specified dictionary (hash map) of key/value definitions.
    """

    # @ApiMember(Description="The 4-digit year of the tax assessment.")
    jahr: int = 0
    """
    The 4-digit year of the tax assessment.
    """


    # @ApiMember(Description="Dictionary of key-value pairs that represent the intrinsic properties of the VAT return. Each key represents a name of the VAT property.Each value of the pair represents the VAT property value.")
    properties: Optional[Dict[str, str]] = None
    """
    Dictionary of key-value pairs that represent the intrinsic properties of the VAT return. Each key represents a name of the VAT property.Each value of the pair represents the VAT property value.
    """

Python CreateE50UstXmlFromDefinition DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /CreateE50UstXmlFromDefinition HTTP/1.1 
Host: taxfiling.pwc.de 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	jahr: 0,
	properties: 
	{
		String: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	content: String,
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}