AlbaApi

<back to all web services

PostPdfFileRequest

The following routes are available for this service:
POST/pdf/file
import 'package:servicestack/servicestack.dart';
import 'dart:typed_data';

abstract class IVirtualDirectory
{
}

abstract class IVirtualPathProvider
{
    IVirtualDirectory? rootDirectory;
    String? virtualPathSeparator;
    String? realPathSeparator;
}

abstract class IVirtualFile
{
    IVirtualPathProvider? virtualPathProvider;
    String? extension;
    int? length;
}

// @flags()
class CacheControl
{
    static const CacheControl None = const CacheControl._(0);
    static const CacheControl Public = const CacheControl._(1);
    static const CacheControl Private = const CacheControl._(2);
    static const CacheControl MustRevalidate = const CacheControl._(4);
    static const CacheControl NoCache = const CacheControl._(8);
    static const CacheControl NoStore = const CacheControl._(16);
    static const CacheControl NoTransform = const CacheControl._(32);
    static const CacheControl ProxyRevalidate = const CacheControl._(64);

    final int _value;
    const CacheControl._(this._value);
    int get value => _value;
    static List<CacheControl> get values => const [None,Public,Private,MustRevalidate,NoCache,NoStore,NoTransform,ProxyRevalidate];
}

abstract class IContentTypeWriter
{
}

abstract class IResponse
{
    dynamic? originalResponse;
    IRequest? request;
    int? statusCode;
    String? statusDescription;
    String? contentType;
    Uint8List? outputStream;
    dynamic? dto;
    bool? useBufferedStream;
    bool? isClosed;
    bool? keepAlive;
    bool? hasStarted;
    Map<String,dynamic?>? items;
}

// @flags()
class RequestAttributes
{
    static const RequestAttributes None = const RequestAttributes._(0);
    static const RequestAttributes Localhost = const RequestAttributes._(1);
    static const RequestAttributes LocalSubnet = const RequestAttributes._(2);
    static const RequestAttributes External = const RequestAttributes._(4);
    static const RequestAttributes Secure = const RequestAttributes._(8);
    static const RequestAttributes InSecure = const RequestAttributes._(16);
    static const RequestAttributes AnySecurityMode = const RequestAttributes._(24);
    static const RequestAttributes HttpHead = const RequestAttributes._(32);
    static const RequestAttributes HttpGet = const RequestAttributes._(64);
    static const RequestAttributes HttpPost = const RequestAttributes._(128);
    static const RequestAttributes HttpPut = const RequestAttributes._(256);
    static const RequestAttributes HttpDelete = const RequestAttributes._(512);
    static const RequestAttributes HttpPatch = const RequestAttributes._(1024);
    static const RequestAttributes HttpOptions = const RequestAttributes._(2048);
    static const RequestAttributes HttpOther = const RequestAttributes._(4096);
    static const RequestAttributes AnyHttpMethod = const RequestAttributes._(8160);
    static const RequestAttributes OneWay = const RequestAttributes._(8192);
    static const RequestAttributes Reply = const RequestAttributes._(16384);
    static const RequestAttributes AnyCallStyle = const RequestAttributes._(24576);
    static const RequestAttributes Soap11 = const RequestAttributes._(32768);
    static const RequestAttributes Soap12 = const RequestAttributes._(65536);
    static const RequestAttributes Xml = const RequestAttributes._(131072);
    static const RequestAttributes Json = const RequestAttributes._(262144);
    static const RequestAttributes Jsv = const RequestAttributes._(524288);
    static const RequestAttributes ProtoBuf = const RequestAttributes._(1048576);
    static const RequestAttributes Csv = const RequestAttributes._(2097152);
    static const RequestAttributes Html = const RequestAttributes._(4194304);
    static const RequestAttributes Wire = const RequestAttributes._(8388608);
    static const RequestAttributes MsgPack = const RequestAttributes._(16777216);
    static const RequestAttributes FormatOther = const RequestAttributes._(33554432);
    static const RequestAttributes AnyFormat = const RequestAttributes._(67076096);
    static const RequestAttributes Http = const RequestAttributes._(67108864);
    static const RequestAttributes MessageQueue = const RequestAttributes._(134217728);
    static const RequestAttributes Tcp = const RequestAttributes._(268435456);
    static const RequestAttributes Grpc = const RequestAttributes._(536870912);
    static const RequestAttributes EndpointOther = const RequestAttributes._(1073741824);
    static const RequestAttributes AnyEndpoint = const RequestAttributes._(2080374784);
    static const RequestAttributes InProcess = const RequestAttributes._(-2147483648);
    static const RequestAttributes InternalNetworkAccess = const RequestAttributes._(-2147483645);
    static const RequestAttributes AnyNetworkAccessType = const RequestAttributes._(-2147483641);
    static const RequestAttributes Any = const RequestAttributes._(-1);

    final int _value;
    const RequestAttributes._(this._value);
    int get value => _value;
    static List<RequestAttributes> get values => const [None,Localhost,LocalSubnet,External,Secure,InSecure,AnySecurityMode,HttpHead,HttpGet,HttpPost,HttpPut,HttpDelete,HttpPatch,HttpOptions,HttpOther,AnyHttpMethod,OneWay,Reply,AnyCallStyle,Soap11,Soap12,Xml,Json,Jsv,ProtoBuf,Csv,Html,Wire,MsgPack,FormatOther,AnyFormat,Http,MessageQueue,Tcp,Grpc,EndpointOther,AnyEndpoint,InProcess,InternalNetworkAccess,AnyNetworkAccessType,Any];
}

abstract class IRequestPreferences
{
    bool? acceptsBrotli;
    bool? acceptsDeflate;
    bool? acceptsGzip;
}

abstract class IRequest
{
    dynamic? originalRequest;
    IResponse? response;
    String? operationName;
    String? verb;
    RequestAttributes? requestAttributes;
    IRequestPreferences? requestPreferences;
    dynamic? dto;
    String? contentType;
    bool? isLocal;
    String? userAgent;
    Map<String,Cookie?>? cookies;
    String? responseContentType;
    bool? hasExplicitResponseContentType;
    Map<String,dynamic?>? items;
    NameValueCollection? headers;
    NameValueCollection? queryString;
    NameValueCollection? formData;
    bool? useBufferedStream;
    String? rawUrl;
    String? absoluteUri;
    String? userHostAddress;
    String? remoteIp;
    String? authorization;
    bool? isSecureConnection;
    List<String>? acceptTypes;
    String? pathInfo;
    String? originalPathInfo;
    Uint8List? inputStream;
    int? contentLength;
    List<IHttpFile>? files;
    Uri? urlReferrer;
}

class HttpResult implements IConvertible
{
    String? responseText;
    Uint8List? responseStream;
    FileInfo? fileInfo;
    IVirtualFile? virtualFile;
    String? contentType;
    Map<String,String?>? headers;
    List<Cookie>? cookies;
    String? eTag;
    Duration? age;
    Duration? maxAge;
    DateTime? expires;
    DateTime? lastModified;
    CacheControl? cacheControl;
    Func<IDisposable>? resultScope;
    bool? allowsPartialResponse;
    Map<String,String?>? options;
    int? status;
    HttpStatusCode? statusCode;
    String? statusDescription;
    dynamic? response;
    IContentTypeWriter? responseFilter;
    IRequest? requestContext;
    String? view;
    String? template;
    int? paddingLength;
    bool? isPartialRequest;

    HttpResult({this.responseText,this.responseStream,this.fileInfo,this.virtualFile,this.contentType,this.headers,this.cookies,this.eTag,this.age,this.maxAge,this.expires,this.lastModified,this.cacheControl,this.resultScope,this.allowsPartialResponse,this.options,this.status,this.statusCode,this.statusDescription,this.response,this.responseFilter,this.requestContext,this.view,this.template,this.paddingLength,this.isPartialRequest});
    HttpResult.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        responseText = json['responseText'];
        responseStream = JsonConverters.fromJson(json['responseStream'],'Uint8List',context!);
        fileInfo = JsonConverters.fromJson(json['fileInfo'],'FileInfo',context!);
        virtualFile = JsonConverters.fromJson(json['virtualFile'],'IVirtualFile',context!);
        contentType = json['contentType'];
        headers = JsonConverters.toStringMap(json['headers']);
        cookies = JsonConverters.fromJson(json['cookies'],'List<Cookie>',context!);
        eTag = json['eTag'];
        age = JsonConverters.fromJson(json['age'],'Duration',context!);
        maxAge = JsonConverters.fromJson(json['maxAge'],'Duration',context!);
        expires = JsonConverters.fromJson(json['expires'],'DateTime',context!);
        lastModified = JsonConverters.fromJson(json['lastModified'],'DateTime',context!);
        cacheControl = JsonConverters.fromJson(json['cacheControl'],'CacheControl',context!);
        resultScope = JsonConverters.fromJson(json['resultScope'],'Func<IDisposable>',context!);
        allowsPartialResponse = json['allowsPartialResponse'];
        options = JsonConverters.fromJson(json['options'],'Map<String,String?>',context!);
        status = json['status'];
        statusCode = JsonConverters.fromJson(json['statusCode'],'HttpStatusCode',context!);
        statusDescription = json['statusDescription'];
        response = JsonConverters.fromJson(json['response'],'dynamic',context!);
        responseFilter = JsonConverters.fromJson(json['responseFilter'],'IContentTypeWriter',context!);
        requestContext = JsonConverters.fromJson(json['requestContext'],'IRequest',context!);
        view = json['view'];
        template = json['template'];
        paddingLength = json['paddingLength'];
        isPartialRequest = json['isPartialRequest'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'responseText': responseText,
        'responseStream': JsonConverters.toJson(responseStream,'Uint8List',context!),
        'fileInfo': JsonConverters.toJson(fileInfo,'FileInfo',context!),
        'virtualFile': JsonConverters.toJson(virtualFile,'IVirtualFile',context!),
        'contentType': contentType,
        'headers': headers,
        'cookies': JsonConverters.toJson(cookies,'List<Cookie>',context!),
        'eTag': eTag,
        'age': JsonConverters.toJson(age,'Duration',context!),
        'maxAge': JsonConverters.toJson(maxAge,'Duration',context!),
        'expires': JsonConverters.toJson(expires,'DateTime',context!),
        'lastModified': JsonConverters.toJson(lastModified,'DateTime',context!),
        'cacheControl': JsonConverters.toJson(cacheControl,'CacheControl',context!),
        'resultScope': JsonConverters.toJson(resultScope,'Func<IDisposable>',context!),
        'allowsPartialResponse': allowsPartialResponse,
        'options': JsonConverters.toJson(options,'Map<String,String?>',context!),
        'status': status,
        'statusCode': JsonConverters.toJson(statusCode,'HttpStatusCode',context!),
        'statusDescription': statusDescription,
        'response': JsonConverters.toJson(response,'dynamic',context!),
        'responseFilter': JsonConverters.toJson(responseFilter,'IContentTypeWriter',context!),
        'requestContext': JsonConverters.toJson(requestContext,'IRequest',context!),
        'view': view,
        'template': template,
        'paddingLength': paddingLength,
        'isPartialRequest': isPartialRequest
    };

    getTypeName() => "HttpResult";
    TypeContext? context = _ctx;
}

class Margin implements IConvertible
{
    String? top;
    String? bottom;
    String? left;
    String? right;

    Margin({this.top,this.bottom,this.left,this.right});
    Margin.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        top = json['top'];
        bottom = json['bottom'];
        left = json['left'];
        right = json['right'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'top': top,
        'bottom': bottom,
        'left': left,
        'right': right
    };

    getTypeName() => "Margin";
    TypeContext? context = _ctx;
}

class PaperSize implements IConvertible
{
    double? width;
    double? height;

    PaperSize({this.width,this.height});
    PaperSize.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        width = JsonConverters.toDouble(json['width']);
        height = JsonConverters.toDouble(json['height']);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'width': width,
        'height': height
    };

    getTypeName() => "PaperSize";
    TypeContext? context = _ctx;
}

enum PageOrientation
{
    Landscape,
    Portrait,
}

enum WaitUntil
{
    Load,
    DOMContentLoaded,
    NetworkIdle0,
    NetworkIdle2,
}

enum CssMediaType
{
    Print,
    Screen,
}

class WaitForSelectorOption implements IConvertible
{
    String? selector;
    bool? isVisible;

    WaitForSelectorOption({this.selector,this.isVisible});
    WaitForSelectorOption.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        selector = json['selector'];
        isVisible = json['isVisible'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'selector': selector,
        'isVisible': isVisible
    };

    getTypeName() => "WaitForSelectorOption";
    TypeContext? context = _ctx;
}

class GeneratePdfOptions implements IConvertible
{
    String? filename;
    Margin? margin;
    PaperSize? paperSize;
    PageOrientation? pageOrientation;
    bool? displayHeader;
    bool? displayFooter;
    bool? displayPagination;
    String? headerHtml;
    String? footerHtml;
    WaitUntil? waitUntil;
    int? navigationTimeout;
    CssMediaType? cssMediaType;
    List<WaitForSelectorOption>? waitForSelectorOptions;
    bool? hasCustomPdfDate;
    String? customPdfDate;

    GeneratePdfOptions({this.filename,this.margin,this.paperSize,this.pageOrientation,this.displayHeader,this.displayFooter,this.displayPagination,this.headerHtml,this.footerHtml,this.waitUntil,this.navigationTimeout,this.cssMediaType,this.waitForSelectorOptions,this.hasCustomPdfDate,this.customPdfDate});
    GeneratePdfOptions.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        filename = json['filename'];
        margin = JsonConverters.fromJson(json['margin'],'Margin',context!);
        paperSize = JsonConverters.fromJson(json['paperSize'],'PaperSize',context!);
        pageOrientation = JsonConverters.fromJson(json['pageOrientation'],'PageOrientation',context!);
        displayHeader = json['displayHeader'];
        displayFooter = json['displayFooter'];
        displayPagination = json['displayPagination'];
        headerHtml = json['headerHtml'];
        footerHtml = json['footerHtml'];
        waitUntil = JsonConverters.fromJson(json['waitUntil'],'WaitUntil',context!);
        navigationTimeout = json['navigationTimeout'];
        cssMediaType = JsonConverters.fromJson(json['cssMediaType'],'CssMediaType',context!);
        waitForSelectorOptions = JsonConverters.fromJson(json['waitForSelectorOptions'],'List<WaitForSelectorOption>',context!);
        hasCustomPdfDate = json['hasCustomPdfDate'];
        customPdfDate = json['customPdfDate'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'filename': filename,
        'margin': JsonConverters.toJson(margin,'Margin',context!),
        'paperSize': JsonConverters.toJson(paperSize,'PaperSize',context!),
        'pageOrientation': JsonConverters.toJson(pageOrientation,'PageOrientation',context!),
        'displayHeader': displayHeader,
        'displayFooter': displayFooter,
        'displayPagination': displayPagination,
        'headerHtml': headerHtml,
        'footerHtml': footerHtml,
        'waitUntil': JsonConverters.toJson(waitUntil,'WaitUntil',context!),
        'navigationTimeout': navigationTimeout,
        'cssMediaType': JsonConverters.toJson(cssMediaType,'CssMediaType',context!),
        'waitForSelectorOptions': JsonConverters.toJson(waitForSelectorOptions,'List<WaitForSelectorOption>',context!),
        'hasCustomPdfDate': hasCustomPdfDate,
        'customPdfDate': customPdfDate
    };

    getTypeName() => "GeneratePdfOptions";
    TypeContext? context = _ctx;
}

class PostPdfFileRequest implements IConvertible
{
    String? url;
    GeneratePdfOptions? options;

    PostPdfFileRequest({this.url,this.options});
    PostPdfFileRequest.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        url = json['url'];
        options = JsonConverters.fromJson(json['options'],'GeneratePdfOptions',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'url': url,
        'options': JsonConverters.toJson(options,'GeneratePdfOptions',context!)
    };

    getTypeName() => "PostPdfFileRequest";
    TypeContext? context = _ctx;
}

abstract class IHttpFile
{
    String? name;
    String? fileName;
    int? contentLength;
    String? contentType;
    Uint8List? inputStream;
}

TypeContext _ctx = TypeContext(library: 'hcbtas_q_albamfs_api.azurewebsites.net', types: <String, TypeInfo> {
    'IVirtualDirectory': TypeInfo(TypeOf.Interface),
    'IVirtualPathProvider': TypeInfo(TypeOf.Interface),
    'IVirtualFile': TypeInfo(TypeOf.Interface),
    'CacheControl': TypeInfo(TypeOf.Enum, enumValues:CacheControl.values),
    'IContentTypeWriter': TypeInfo(TypeOf.Interface),
    'IResponse': TypeInfo(TypeOf.Interface),
    'RequestAttributes': TypeInfo(TypeOf.Enum, enumValues:RequestAttributes.values),
    'IRequestPreferences': TypeInfo(TypeOf.Interface),
    'IRequest': TypeInfo(TypeOf.Interface),
    'HttpResult': TypeInfo(TypeOf.Class, create:() => HttpResult()),
    'Uint8List': TypeInfo(TypeOf.Class, create:() => Uint8List(0)),
    'FileInfo': TypeInfo(TypeOf.Class, create:() => FileInfo()),
    'List<Cookie>': TypeInfo(TypeOf.Class, create:() => <Cookie>[]),
    'Cookie': TypeInfo(TypeOf.Class, create:() => Cookie()),
    'Func<IDisposable>': TypeInfo(TypeOf.Class, create:() => Func<IDisposable>()),
    'IDisposable': TypeInfo(TypeOf.Class, create:() => IDisposable()),
    'Map<String,String?>': TypeInfo(TypeOf.Class, create:() => Map<String,String?>()),
    'HttpStatusCode': TypeInfo(TypeOf.Class, create:() => HttpStatusCode()),
    'Margin': TypeInfo(TypeOf.Class, create:() => Margin()),
    'PaperSize': TypeInfo(TypeOf.Class, create:() => PaperSize()),
    'PageOrientation': TypeInfo(TypeOf.Enum, enumValues:PageOrientation.values),
    'WaitUntil': TypeInfo(TypeOf.Enum, enumValues:WaitUntil.values),
    'CssMediaType': TypeInfo(TypeOf.Enum, enumValues:CssMediaType.values),
    'WaitForSelectorOption': TypeInfo(TypeOf.Class, create:() => WaitForSelectorOption()),
    'GeneratePdfOptions': TypeInfo(TypeOf.Class, create:() => GeneratePdfOptions()),
    'List<WaitForSelectorOption>': TypeInfo(TypeOf.Class, create:() => <WaitForSelectorOption>[]),
    'PostPdfFileRequest': TypeInfo(TypeOf.Class, create:() => PostPdfFileRequest()),
    'IHttpFile': TypeInfo(TypeOf.Interface),
});

Dart PostPdfFileRequest 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 /pdf/file HTTP/1.1 
Host: hcbtas-q-albamfs-api.azurewebsites.net 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	url: String,
	options: 
	{
		filename: String,
		pageOrientation: Landscape,
		displayHeader: False,
		displayFooter: False,
		displayPagination: False,
		headerHtml: String,
		footerHtml: String,
		waitUntil: Load,
		navigationTimeout: 0,
		cssMediaType: Print,
		waitForSelectorOptions: 
		[
			{
				
			}
		],
		hasCustomPdfDate: False,
		customPdfDate: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	
}