PHP 5 Classes CreateOrder

Submitting an order. The Order ID is returned in the order object passed by reference. All orders are asynchrnous. That means, after the order is submitted, the partner-system must wait for a message from Ascio. Message are sent via HTTP-GET, PollQueue or Mail. With that no full-sync is necessary, like with other APIs. Most domains-transaction are done with CreateOrder. Following OrderTypes exist:


Contact_Update Update contacts: Admin, Tech, Billing and Reseller. Please provice at least Admin,Tech and Billing contacts for this OrderType. You need to use Registrant_Details_Update or Owner_Change to update the registrant. Contact_Update example
Change_Locks You can change the TransferLock, DeleteLock and UpdateLocks. TransferLock: The domain can't be transfered. DeleteLock: The domain can't be deleted. UpdateLock: The domain can't be updated.
Delete_Domain The domain is deleted immediatly. The recommend process is to expire the domain instead of deleting it.
Registrant_Details_Update You can change all details, that don't change the identity of the person/company. Don't change: FirstName, LastName, OrgName, RegistrantNumber. Registrant_Details_Update example
Expire_Domain The domain is deleted at the expire-date (+threshold). Ascio uses AutoRenew, so you need to explicitly expire the domain, if you don't want it to be auto-renewed. The process is: Register or Transfer, Expire. This will stop the domain from being autorenewed. If the domain is expiring, you need to use unexpire, if you want the domain to be renewed at the expire-date. Don't use Renew to unexpire a domain
Nameserver_Update For updating nameserver. Please be aware that the glue-record must be set properly for some TLDs. Please contact partnerservice if you need help with this. Nameserver_Update example
Owner_Change Change the owner of the domain. Do this, if Registrant Details Update doesn't work, because important social data has changed. Owner_Change example
Queue_Domain Queue the domain. Please specify the Queue-Phase in Order.Options. You can find more information about the Queue-Phase in the TLD-Kit.
Register_Domain Registers a domain.
Renew_Domain Add xxx Years to your expire-date. Must be allowed by the registry. Please read the TLD-Kit to see details.
Restore_Domain Restores a deleted domains. Is only possible for weeks after deletion.
Transfer_Domain Transfers a domain. You need to provide full data, that is the same as the original data. If trade is possible, then you can provide different data and an owner-change is done during the transfer. Transfers without data are possible for: com, net, org, biz, info, us, cc, cn,,,, tv some others.
Unexpire_Domain Unexpire a domain that is expiring. If you want to simulate auto-expire, then use unexpire for your renews.
Transfer_Away The transfer away is triggered by Ascio. Only exception: If you need to set a registrar-id like for, you can use the Transfer_Away and set the new registrar-id in the options.
Autorenew_Domain This order-type is triggered by Ascio. For ICANN domains it is used, to spawn the ERRP process. If your planning to send you own ERRP messages, you can wait for our autorenew and then send it. UploadMessage will prevent Ascio from sending out ERRP mails.
Autodelete_Domain This order-type is triggered by Ascio. For ICANN domains it is used, to spawn the ERRP process. If your planning to send you own ERRP messages, you can wait for our autorenew and then send it. UploadMessage will prevent Ascio from sending out ERRP mails.
Defensive_Registration A blocking registration that isn't delegated
Domain_Details_UpdateUpdate domain properties. Linked handles like Contacts, Nameservers and other Objects can't be modified with this command.
Partner_Change Move a domain to another Ascio account. Please contact Partnerservice to the the permissions.
Update_AuthInfo Update the AuthCode for the domain. Normally the Code is generated by Ascio, but for some TLDs, like .de you need to provide the Authcode with the order
Response CreateOrder(string $sessionId,Order $order)

Response codes

200Order validated
200Order received
400Order not validatedMessages
401Authorization failed
405Access denied

CreateOrder request

sessionIdExample: o58t9fjgw9bjarp6q7byv13e



PHP 5 Classes example

namespace ascio\v2\examples;
use ascio\v2 as ascio;
use ascio\lib as lib;
function example() {
	$config = new lib\Config();
	$env = $config->get("testing"); //testing or live
	$sessionId = "12345";
	$ascioClient	 = new ascio\AscioServices(array("trace" => true),$env->getWsdl("v2"));

	$domain =  new ascio\Domain();

	$order =  new ascio\Order();
	echo "start validate\n";
	$validateOrder = new  ascio\ValidateOrder($sessionId, $order);
	try {
		$response = $ascioClient->ValidateOrder($validateOrder);
	} catch (\Exception $e) {
		echo ("[".$e->faultcode . "] ". $e->faultstring);
	echo "end validate\n";
	if ($response->ValidateOrderResult->getResultCode() == 200) {
		echo "Validation: OK\r\n";
		try {
			$createOrderResponse = $ascioClient->CreateOrder(new ascio\CreateOrder($sessionId, $order));
		} catch (\Exception $e) {
			echo ("[".$e->faultcode . "] ". $e->faultstring);
		echo "Create Order: ".$createOrderResponse->CreateOrderResult->getResultCode() . " " . $createOrderResponse->CreateOrderResult->getResultMessage() . "\r\n";
		if ($createOrderResponse->CreateOrderResult->getResultCode() == 200) {
			echo "OrderId : " . $createOrderResponse->CreateOrderResult->getOrderInfo()->getOrderId() . "\r\n";
			echo "Order Status : " . $createOrderResponse->CreateOrderResult->getOrderInfo()->getStatus() . "\r\n";
		} else {
			echo ($response->CreateOrderResult->getMessage()."\n");
			foreach($createOrderResponse->CreateOrderResult->getErrors() as $error) {
				echo $error."\n";
				return $response;
		return $createOrderResponse;
	} else {
		echo ($response->ValidateOrderResult->getMessage()."\n");
		if ($response->ValidateOrderResult->getErrors()) {
			foreach($response->ValidateOrderResult->getErrors()->getString() as $error) {
				 echo $error."\n";
		return $response;
WSDL for AWS v2 (OTE) (Live)