Reputation: 2241
I am trying to create a new customer in Magento. Here's PHP script I wrote for that
<?php
$callbackUrl = "http://localhost/magento/webservices/NewCustomer1.php";
$temporaryCredentialsRequestUrl = "http://localhost/magento/oauth/initiate?oauth_callback=". urlencode($callbackUrl);
$adminAuthorizationUrl = 'http://localhost/magento/admin/oauth_authorize';
$accessTokenRequestUrl = 'http://localhost/magento/oauth/token';
$apiUrl = 'http://localhost/magento/api/rest';
$consumerKey = 's3xt7w8lwhfrrfzrfvwm3lrilkf66d5n';
$consumerSecret = 'vr3eq1x899pz1cf4zzxjzx3q03t66r3n';
session_start();
if (!isset($_GET['oauth_token']) && isset($_SESSION['state']) && $_SESSION['state'] == 1) {
$_SESSION['state'] = 0;
}
try {
$authType = ($_SESSION['state'] == 2) ? OAUTH_AUTH_TYPE_AUTHORIZATION : OAUTH_AUTH_TYPE_URI;
$oauthClient = new OAuth($consumerKey, $consumerSecret, OAUTH_SIG_METHOD_HMACSHA1, $authType);
$oauthClient->enableDebug();
if (!isset($_GET['oauth_token']) && !$_SESSION['state']) {
$requestToken = $oauthClient->getRequestToken($temporaryCredentialsRequestUrl);
$_SESSION['secret'] = $requestToken['oauth_token_secret'];
$_SESSION['state'] = 1;
header('Location: ' . $adminAuthorizationUrl . '?oauth_token=' . $requestToken['oauth_token']);
exit;
} else if ($_SESSION['state'] == 1) {
$oauthClient->setToken($_GET['oauth_token'], $_SESSION['secret']);
$accessToken = $oauthClient->getAccessToken($accessTokenRequestUrl);
$_SESSION['state'] = 2;
$_SESSION['token'] = $accessToken['oauth_token'];
$_SESSION['secret'] = $accessToken['oauth_token_secret'];
header('Location: ' . $callbackUrl);
exit;
} else {
$oauthClient->setToken($_SESSION['token'], $_SESSION['secret']);
$resourceUrl = "$apiUrl/customers/create";
$customerData = json_encode(array(
'firstname' => 'demofirstname',
'lastname' => 'demolastname',
'email_address' => '[email protected]',
'password' => 'demo1234',
'confirmation' => 'demo1234',
));
$headers = array('Content-Type' => 'application/json');
$oauthClient->fetch($resourceUrl, $customerData, OAUTH_HTTP_METHOD_POST, $headers);
print_r($oauthClient->getLastResponseInfo());
}
} catch (OAuthException $e) {
print_r($e);
}
?>
I am getting this error
OAuthException: Invalid auth/bad request (got a 405, expected HTTP/1.1 20X or a redirect) in C:\wamp\www\magento\WebServices\newcustomer1.php on line 47 Call Stack #TimeMemoryFunctionLocation 10.0010386016{main}( )..\newcustomer1.php:0 20.0017391216OAuth->fetch( )..\newcustomer1.php:47 )
I am new to Oauth and PHP. Will be glad if someone can help.
Upvotes: 3
Views: 5678
Reputation: 2241
This custom API I wrote works like a breeze. You will need to create a SOAP user from Magento Admin Panel and add SOAP user & DB credentials in following code to make it work.
require_once('../app/Mage.php' );
$dbhost = 'localhost';
$dbUsername = 'root';
$dbPassword = 'password';
$dbName = 'magento';
$soapUsername = 'soapuser';
$soapPassword = 'password';
Mage::app("default");
$store = Mage::app()->getStore();
$storeId = $store->getId();
$websiteId = Mage::app()->getStore()->getWebsiteId();
$email = $_POST['email'];
$firstname = $_POST['firstname'];
$lastname = $_POST['lastname'];
$password = $_POST['password'];
$proxy = new SoapClient('http://yourdomain/magento/index.php/api/?wsdl'); // TODO : change url
$session = $proxy->login($soapUsername, $soapPassword);
try{
$result = $proxy->call($session,'customer.create',array(array('email' => "$email", 'firstname' => "$firstname", 'lastname' => "$lastname", 'password' => "$password", 'website_id' => "$websiteId", 'store_id' => "$storeId", 'group_id' => 1)));
echo json_encode("New Customer created with Id-$result");
$custId = $result;
$shoppingCartId = $proxy->call($session, 'cart.create', array(1));
$customer = array(
'firstname' => "$firstname",
'lastname' => "$lastname",
'email' => "$email",
'password' => md5("$password"),
'customer_id' => "$custId",
'mode' => 'customer',
'website_id' => "$websiteId",
'store_id' => "$storeId",
'group_id' => 1
);
$resultCustomerSet = $proxy->call($session, 'cart_customer.set', array( $shoppingCartId, $customer, $storeId) );
$db_handle = mysql_connect($dbhost, $dbUsername, $dbPassword) or die(mysql_error());
$db_found = mysql_select_db($dbName, $db_handle);
mysql_query("UPDATE `sales_flat_quote` SET `is_active` = '1' WHERE `customer_email` = '$email' ");
mysql_query("INSERT INTO `wishlist` VALUES('','$custId','0','','$timestamp')");
}
catch( Exception $e ) {
echo json_encode($e->getMessage());
}
Upvotes: 0
Reputation: 21
The official magento rest api only allow you create customer with admin permission. Use admin permission to do that or just implement a custom one for guest permission.
Upvotes: 0
Reputation: 4486
At around line 36:
$resourceUrl = "$apiUrl/customers/create";
Remove the create
at the end. so it is now:
$resourceUrl = "$apiUrl/customers/";
You already have OAUTH_HTTP_METHOD_POST
to specify this verb for REST. so the resulting resource url should be : http://localhost/magento/api/rest/customers/
The error you're getting is a HTTP 405 Method Not Allowed
meaning either your endpoint disallows POST
or doesn't know about it. In your case, it's the latter.
read more about the resource endpoints here: http://www.magentocommerce.com/api/rest/Resources/resources.html
Upvotes: 2