TechStacks!

<back to all web services

CreateTechnology

Tech
Requires Authentication
The following routes are available for this service:
POST/technology
import Foundation
import ServiceStack

public class CreateTechnology : IPost, Codable
{
    public var name:String
    public var slug:String
    public var vendorName:String
    public var vendorUrl:String
    public var productUrl:String
    public var logoUrl:String
    public var Description:String
    public var isLocked:Bool
    public var tier: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
}

public class CreateTechnologyResponse : Codable
{
    public var result:Technology
    public var responseStatus:ResponseStatus

    required public init(){}
}

public class Technology : TechnologyBase
{
    required public init(){ super.init() }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
    }
}

public class TechnologyBase : Codable
{
    public var id:Int
    public var name:String
    public var vendorName:String
    public var vendorUrl:String
    public var productUrl:String
    public var logoUrl:String
    public var Description:String
    public var created:Date
    public var createdBy:String
    public var lastModified:Date
    public var lastModifiedBy:String
    public var ownerId:String
    public var slug:String
    public var logoApproved:Bool
    public var isLocked:Bool
    public var tier:TechnologyTier
    public var lastStatusUpdate:Date?
    public var organizationId:Int?
    public var commentsPostId:Int?
    public var viewCount:Int
    public var favCount:Int

    required public init(){}
}


Swift CreateTechnology 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 /technology HTTP/1.1 
Host: techstacks.io 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	name: String,
	slug: String,
	vendorName: String,
	vendorUrl: String,
	productUrl: String,
	logoUrl: String,
	description: String,
	isLocked: False,
	tier: ProgrammingLanguage
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	result: 
	{
		id: 0,
		name: String,
		vendorName: String,
		vendorUrl: String,
		productUrl: String,
		logoUrl: String,
		description: String,
		created: 0001-01-01,
		createdBy: String,
		lastModified: 0001-01-01,
		lastModifiedBy: String,
		ownerId: String,
		slug: String,
		logoApproved: False,
		isLocked: False,
		tier: ProgrammingLanguage,
		lastStatusUpdate: 0001-01-01,
		organizationId: 0,
		commentsPostId: 0,
		viewCount: 0,
		favCount: 0
	},
	responseStatus: 
	{
		errorCode: String,
		message: String,
		stackTrace: String,
		errors: 
		[
			{
				errorCode: String,
				fieldName: String,
				message: String,
				meta: 
				{
					String: String
				}
			}
		],
		meta: 
		{
			String: String
		}
	}
}