All Verbs | /config |
---|
import Foundation
import ServiceStack
public class GetConfig : IGet, Codable
{
required public init(){}
}
public class GetConfigResponse : Codable
{
public var allTiers:[Option]
public var allPostTypes:[Option]
public var allFlagTypes:[Option]
required public init(){}
}
// @DataContract
public class Option : Codable
{
// @DataMember(Name="name")
public var name:String
// @DataMember(Name="title")
public var title:String
// @DataMember(Name="value")
public var value:TechnologyTier?
required public init(){}
}
public enum TechnologyTier : String, Codable
{
case ProgrammingLanguage
case Client
case Http
case Server
case Data
case SoftwareInfrastructure
case OperatingSystem
case HardwareInfrastructure
case ThirdPartyServices
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /config HTTP/1.1
Host: techstacks.io
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<GetConfig xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/TechStacks.ServiceModel" />
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <GetConfigResponse xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/TechStacks.ServiceModel"> <AllFlagTypes> <Option> <name>String</name> <title>String</title> <value>ProgrammingLanguage</value> </Option> </AllFlagTypes> <AllPostTypes> <Option> <name>String</name> <title>String</title> <value>ProgrammingLanguage</value> </Option> </AllPostTypes> <AllTiers> <Option> <name>String</name> <title>String</title> <value>ProgrammingLanguage</value> </Option> </AllTiers> </GetConfigResponse>