|  | @@ -32,6 +32,7 @@
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #include "credentials.h"
 | 
	
		
			
				|  |  | +#include "call_credentials.h"
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #ifdef HAVE_CONFIG_H
 | 
	
		
			
				|  |  |  #include "config.h"
 | 
	
	
		
			
				|  | @@ -49,55 +50,56 @@
 | 
	
		
			
				|  |  |  #include <grpc/grpc.h>
 | 
	
		
			
				|  |  |  #include <grpc/grpc_security.h>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -zend_class_entry *grpc_ce_credentials;
 | 
	
		
			
				|  |  | +zend_class_entry *grpc_ce_channel_credentials;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -/* Frees and destroys an instance of wrapped_grpc_credentials */
 | 
	
		
			
				|  |  | -void free_wrapped_grpc_credentials(void *object TSRMLS_DC) {
 | 
	
		
			
				|  |  | -  wrapped_grpc_credentials *creds = (wrapped_grpc_credentials *)object;
 | 
	
		
			
				|  |  | +/* Frees and destroys an instance of wrapped_grpc_channel_credentials */
 | 
	
		
			
				|  |  | +void free_wrapped_grpc_channel_credentials(void *object TSRMLS_DC) {
 | 
	
		
			
				|  |  | +  wrapped_grpc_channel_credentials *creds =
 | 
	
		
			
				|  |  | +      (wrapped_grpc_channel_credentials *)object;
 | 
	
		
			
				|  |  |    if (creds->wrapped != NULL) {
 | 
	
		
			
				|  |  | -    grpc_credentials_release(creds->wrapped);
 | 
	
		
			
				|  |  | +    grpc_channel_credentials_release(creds->wrapped);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    efree(creds);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -/* Initializes an instance of wrapped_grpc_credentials to be associated with an
 | 
	
		
			
				|  |  | - * object of a class specified by class_type */
 | 
	
		
			
				|  |  | -zend_object_value create_wrapped_grpc_credentials(zend_class_entry *class_type
 | 
	
		
			
				|  |  | -                                                      TSRMLS_DC) {
 | 
	
		
			
				|  |  | +/* Initializes an instance of wrapped_grpc_channel_credentials to be
 | 
	
		
			
				|  |  | + * associated with an object of a class specified by class_type */
 | 
	
		
			
				|  |  | +zend_object_value create_wrapped_grpc_channel_credentials(
 | 
	
		
			
				|  |  | +    zend_class_entry *class_type TSRMLS_DC) {
 | 
	
		
			
				|  |  |    zend_object_value retval;
 | 
	
		
			
				|  |  | -  wrapped_grpc_credentials *intern;
 | 
	
		
			
				|  |  | +  wrapped_grpc_channel_credentials *intern;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  intern =
 | 
	
		
			
				|  |  | -      (wrapped_grpc_credentials *)emalloc(sizeof(wrapped_grpc_credentials));
 | 
	
		
			
				|  |  | -  memset(intern, 0, sizeof(wrapped_grpc_credentials));
 | 
	
		
			
				|  |  | +  intern = (wrapped_grpc_channel_credentials *)emalloc(
 | 
	
		
			
				|  |  | +      sizeof(wrapped_grpc_channel_credentials));
 | 
	
		
			
				|  |  | +  memset(intern, 0, sizeof(wrapped_grpc_channel_credentials));
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    zend_object_std_init(&intern->std, class_type TSRMLS_CC);
 | 
	
		
			
				|  |  |    object_properties_init(&intern->std, class_type);
 | 
	
		
			
				|  |  |    retval.handle = zend_objects_store_put(
 | 
	
		
			
				|  |  |        intern, (zend_objects_store_dtor_t)zend_objects_destroy_object,
 | 
	
		
			
				|  |  | -      free_wrapped_grpc_credentials, NULL TSRMLS_CC);
 | 
	
		
			
				|  |  | +      free_wrapped_grpc_channel_credentials, NULL TSRMLS_CC);
 | 
	
		
			
				|  |  |    retval.handlers = zend_get_std_object_handlers();
 | 
	
		
			
				|  |  |    return retval;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -zval *grpc_php_wrap_credentials(grpc_credentials *wrapped) {
 | 
	
		
			
				|  |  | +zval *grpc_php_wrap_channel_credentials(grpc_channel_credentials *wrapped) {
 | 
	
		
			
				|  |  |    zval *credentials_object;
 | 
	
		
			
				|  |  |    MAKE_STD_ZVAL(credentials_object);
 | 
	
		
			
				|  |  | -  object_init_ex(credentials_object, grpc_ce_credentials);
 | 
	
		
			
				|  |  | -  wrapped_grpc_credentials *credentials =
 | 
	
		
			
				|  |  | -      (wrapped_grpc_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  | +  object_init_ex(credentials_object, grpc_ce_channel_credentials);
 | 
	
		
			
				|  |  | +  wrapped_grpc_channel_credentials *credentials =
 | 
	
		
			
				|  |  | +      (wrapped_grpc_channel_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  |            credentials_object TSRMLS_CC);
 | 
	
		
			
				|  |  |    credentials->wrapped = wrapped;
 | 
	
		
			
				|  |  |    return credentials_object;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  | - * Create a default credentials object.
 | 
	
		
			
				|  |  | - * @return Credentials The new default credentials object
 | 
	
		
			
				|  |  | + * Create a default channel credentials object.
 | 
	
		
			
				|  |  | + * @return ChannelCredentials The new default channel credentials object
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -PHP_METHOD(Credentials, createDefault) {
 | 
	
		
			
				|  |  | -  grpc_credentials *creds = grpc_google_default_credentials_create();
 | 
	
		
			
				|  |  | -  zval *creds_object = grpc_php_wrap_credentials(creds);
 | 
	
		
			
				|  |  | +PHP_METHOD(ChannelCredentials, createDefault) {
 | 
	
		
			
				|  |  | +  grpc_channel_credentials *creds = grpc_google_default_credentials_create();
 | 
	
		
			
				|  |  | +  zval *creds_object = grpc_php_wrap_channel_credentials(creds);
 | 
	
		
			
				|  |  |    RETURN_DESTROY_ZVAL(creds_object);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -108,9 +110,9 @@ PHP_METHOD(Credentials, createDefault) {
 | 
	
		
			
				|  |  |   *     (optional)
 | 
	
		
			
				|  |  |   * @param string pem_cert_chain PEM encoding of the client's certificate chain
 | 
	
		
			
				|  |  |   *     (optional)
 | 
	
		
			
				|  |  | - * @return Credentials The new SSL credentials object
 | 
	
		
			
				|  |  | + * @return ChannelCredentials The new SSL credentials object
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -PHP_METHOD(Credentials, createSsl) {
 | 
	
		
			
				|  |  | +PHP_METHOD(ChannelCredentials, createSsl) {
 | 
	
		
			
				|  |  |    char *pem_root_certs = NULL;
 | 
	
		
			
				|  |  |    grpc_ssl_pem_key_cert_pair pem_key_cert_pair;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -121,71 +123,65 @@ PHP_METHOD(Credentials, createSsl) {
 | 
	
		
			
				|  |  |    /* "|s!s!s! == 3 optional nullable strings */
 | 
	
		
			
				|  |  |    if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|s!s!s!",
 | 
	
		
			
				|  |  |                              &pem_root_certs, &root_certs_length,
 | 
	
		
			
				|  |  | -                            &pem_key_cert_pair.private_key, &private_key_length,
 | 
	
		
			
				|  |  | +                            &pem_key_cert_pair.private_key,
 | 
	
		
			
				|  |  | +                            &private_key_length,
 | 
	
		
			
				|  |  |                              &pem_key_cert_pair.cert_chain,
 | 
	
		
			
				|  |  |                              &cert_chain_length) == FAILURE) {
 | 
	
		
			
				|  |  |      zend_throw_exception(spl_ce_InvalidArgumentException,
 | 
	
		
			
				|  |  |                           "createSsl expects 3 optional strings", 1 TSRMLS_CC);
 | 
	
		
			
				|  |  |      return;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | -  grpc_credentials *creds = grpc_ssl_credentials_create(
 | 
	
		
			
				|  |  | +  grpc_channel_credentials *creds = grpc_ssl_credentials_create(
 | 
	
		
			
				|  |  |        pem_root_certs,
 | 
	
		
			
				|  |  |        pem_key_cert_pair.private_key == NULL ? NULL : &pem_key_cert_pair, NULL);
 | 
	
		
			
				|  |  | -  zval *creds_object = grpc_php_wrap_credentials(creds);
 | 
	
		
			
				|  |  | +  zval *creds_object = grpc_php_wrap_channel_credentials(creds);
 | 
	
		
			
				|  |  |    RETURN_DESTROY_ZVAL(creds_object);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /**
 | 
	
		
			
				|  |  |   * Create composite credentials from two existing credentials.
 | 
	
		
			
				|  |  | - * @param Credentials cred1 The first credential
 | 
	
		
			
				|  |  | - * @param Credentials cred2 The second credential
 | 
	
		
			
				|  |  | - * @return Credentials The new composite credentials object
 | 
	
		
			
				|  |  | + * @param ChannelCredentials cred1 The first credential
 | 
	
		
			
				|  |  | + * @param CallCredentials cred2 The second credential
 | 
	
		
			
				|  |  | + * @return ChannelCredentials The new composite credentials object
 | 
	
		
			
				|  |  |   */
 | 
	
		
			
				|  |  | -PHP_METHOD(Credentials, createComposite) {
 | 
	
		
			
				|  |  | +PHP_METHOD(ChannelCredentials, createComposite) {
 | 
	
		
			
				|  |  |    zval *cred1_obj;
 | 
	
		
			
				|  |  |    zval *cred2_obj;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    /* "OO" == 3 Objects */
 | 
	
		
			
				|  |  |    if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "OO", &cred1_obj,
 | 
	
		
			
				|  |  | -                            grpc_ce_credentials, &cred2_obj,
 | 
	
		
			
				|  |  | -                            grpc_ce_credentials) == FAILURE) {
 | 
	
		
			
				|  |  | +                            grpc_ce_channel_credentials, &cred2_obj,
 | 
	
		
			
				|  |  | +                            grpc_ce_call_credentials) == FAILURE) {
 | 
	
		
			
				|  |  |      zend_throw_exception(spl_ce_InvalidArgumentException,
 | 
	
		
			
				|  |  |                           "createComposite expects 2 Credentials", 1 TSRMLS_CC);
 | 
	
		
			
				|  |  |      return;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | -  wrapped_grpc_credentials *cred1 =
 | 
	
		
			
				|  |  | -      (wrapped_grpc_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  | +  wrapped_grpc_channel_credentials *cred1 =
 | 
	
		
			
				|  |  | +      (wrapped_grpc_channel_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  |            cred1_obj TSRMLS_CC);
 | 
	
		
			
				|  |  | -  wrapped_grpc_credentials *cred2 =
 | 
	
		
			
				|  |  | -      (wrapped_grpc_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  | +  wrapped_grpc_call_credentials *cred2 =
 | 
	
		
			
				|  |  | +      (wrapped_grpc_call_credentials *)zend_object_store_get_object(
 | 
	
		
			
				|  |  |            cred2_obj TSRMLS_CC);
 | 
	
		
			
				|  |  | -  grpc_credentials *creds =
 | 
	
		
			
				|  |  | -      grpc_composite_credentials_create(cred1->wrapped, cred2->wrapped, NULL);
 | 
	
		
			
				|  |  | -  zval *creds_object = grpc_php_wrap_credentials(creds);
 | 
	
		
			
				|  |  | +  grpc_channel_credentials *creds =
 | 
	
		
			
				|  |  | +      grpc_composite_channel_credentials_create(cred1->wrapped, cred2->wrapped,
 | 
	
		
			
				|  |  | +                                                NULL);
 | 
	
		
			
				|  |  | +  zval *creds_object = grpc_php_wrap_channel_credentials(creds);
 | 
	
		
			
				|  |  |    RETURN_DESTROY_ZVAL(creds_object);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -/**
 | 
	
		
			
				|  |  | - * Create Google Compute Engine credentials
 | 
	
		
			
				|  |  | - * @return Credentials The new GCE credentials object
 | 
	
		
			
				|  |  | - */
 | 
	
		
			
				|  |  | -PHP_METHOD(Credentials, createGce) {
 | 
	
		
			
				|  |  | -  grpc_credentials *creds = grpc_google_compute_engine_credentials_create(NULL);
 | 
	
		
			
				|  |  | -  zval *creds_object = grpc_php_wrap_credentials(creds);
 | 
	
		
			
				|  |  | -  RETURN_DESTROY_ZVAL(creds_object);
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -static zend_function_entry credentials_methods[] = {
 | 
	
		
			
				|  |  | -    PHP_ME(Credentials, createDefault, NULL, ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | -    PHP_ME(Credentials, createSsl, NULL, ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | -    PHP_ME(Credentials, createComposite, NULL,
 | 
	
		
			
				|  |  | -           ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | -    PHP_ME(Credentials, createGce, NULL, ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | -    PHP_FE_END};
 | 
	
		
			
				|  |  | +static zend_function_entry channel_credentials_methods[] = {
 | 
	
		
			
				|  |  | +  PHP_ME(ChannelCredentials, createDefault, NULL,
 | 
	
		
			
				|  |  | +         ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | +  PHP_ME(ChannelCredentials, createSsl, NULL,
 | 
	
		
			
				|  |  | +         ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | +  PHP_ME(ChannelCredentials, createComposite, NULL,
 | 
	
		
			
				|  |  | +         ZEND_ACC_PUBLIC | ZEND_ACC_STATIC)
 | 
	
		
			
				|  |  | +  PHP_FE_END};
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -void grpc_init_credentials(TSRMLS_D) {
 | 
	
		
			
				|  |  | +void grpc_init_channel_credentials(TSRMLS_D) {
 | 
	
		
			
				|  |  |    zend_class_entry ce;
 | 
	
		
			
				|  |  | -  INIT_CLASS_ENTRY(ce, "Grpc\\Credentials", credentials_methods);
 | 
	
		
			
				|  |  | -  ce.create_object = create_wrapped_grpc_credentials;
 | 
	
		
			
				|  |  | -  grpc_ce_credentials = zend_register_internal_class(&ce TSRMLS_CC);
 | 
	
		
			
				|  |  | +  INIT_CLASS_ENTRY(ce, "Grpc\\ChannelCredentials",
 | 
	
		
			
				|  |  | +                   channel_credentials_methods);
 | 
	
		
			
				|  |  | +  ce.create_object = create_wrapped_grpc_channel_credentials;
 | 
	
		
			
				|  |  | +  grpc_ce_channel_credentials = zend_register_internal_class(&ce TSRMLS_CC);
 | 
	
		
			
				|  |  |  }
 |