curl_file.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. /*
  2. +----------------------------------------------------------------------+
  3. | PHP Version 7 |
  4. +----------------------------------------------------------------------+
  5. | Copyright (c) 1997-2018 The PHP Group |
  6. +----------------------------------------------------------------------+
  7. | This source file is subject to version 3.01 of the PHP license, |
  8. | that is bundled with this package in the file LICENSE, and is |
  9. | available through the world-wide-web at the following url: |
  10. | http://www.php.net/license/3_01.txt |
  11. | If you did not receive a copy of the PHP license and are unable to |
  12. | obtain it through the world-wide-web, please send a note to |
  13. | license@php.net so we can mail you a copy immediately. |
  14. +----------------------------------------------------------------------+
  15. | Author: Stanislav Malyshev <stas@php.net> |
  16. +----------------------------------------------------------------------+
  17. */
  18. #ifdef HAVE_CONFIG_H
  19. # include "config.h"
  20. #endif
  21. #include "php.h"
  22. #include "Zend/zend_exceptions.h"
  23. #include "php_curl.h"
  24. #if HAVE_CURL
  25. PHP_CURL_API zend_class_entry *curl_CURLFile_class;
  26. static void curlfile_ctor(INTERNAL_FUNCTION_PARAMETERS)
  27. {
  28. zend_string *fname, *mime = NULL, *postname = NULL;
  29. zval *cf = return_value;
  30. ZEND_PARSE_PARAMETERS_START(1,3)
  31. Z_PARAM_PATH_STR(fname)
  32. Z_PARAM_OPTIONAL
  33. Z_PARAM_STR(mime)
  34. Z_PARAM_STR(postname)
  35. ZEND_PARSE_PARAMETERS_END();
  36. zend_update_property_string(curl_CURLFile_class, cf, "name", sizeof("name")-1, ZSTR_VAL(fname));
  37. if (mime) {
  38. zend_update_property_string(curl_CURLFile_class, cf, "mime", sizeof("mime")-1, ZSTR_VAL(mime));
  39. }
  40. if (postname) {
  41. zend_update_property_string(curl_CURLFile_class, cf, "postname", sizeof("postname")-1, ZSTR_VAL(postname));
  42. }
  43. }
  44. /* {{{ proto CURLFile::__construct(string $name, [string $mimetype [, string $postfilename]])
  45. Create the CURLFile object */
  46. ZEND_METHOD(CURLFile, __construct)
  47. {
  48. return_value = getThis();
  49. curlfile_ctor(INTERNAL_FUNCTION_PARAM_PASSTHRU);
  50. }
  51. /* }}} */
  52. /* {{{ proto CURLFile curl_file_create(string $name, [string $mimetype [, string $postfilename]])
  53. Create the CURLFile object */
  54. PHP_FUNCTION(curl_file_create)
  55. {
  56. object_init_ex( return_value, curl_CURLFile_class );
  57. curlfile_ctor(INTERNAL_FUNCTION_PARAM_PASSTHRU);
  58. }
  59. /* }}} */
  60. static void curlfile_get_property(char *name, size_t name_len, INTERNAL_FUNCTION_PARAMETERS)
  61. {
  62. zval *res, rv;
  63. if (zend_parse_parameters_none() == FAILURE) {
  64. return;
  65. }
  66. res = zend_read_property(curl_CURLFile_class, getThis(), name, name_len, 1, &rv);
  67. ZVAL_COPY_DEREF(return_value, res);
  68. }
  69. static void curlfile_set_property(char *name, size_t name_len, INTERNAL_FUNCTION_PARAMETERS)
  70. {
  71. zend_string *arg;
  72. ZEND_PARSE_PARAMETERS_START(1,1)
  73. Z_PARAM_STR(arg)
  74. ZEND_PARSE_PARAMETERS_END();
  75. zend_update_property_string(curl_CURLFile_class, getThis(), name, name_len, ZSTR_VAL(arg));
  76. }
  77. /* {{{ proto string CURLFile::getFilename()
  78. Get file name */
  79. ZEND_METHOD(CURLFile, getFilename)
  80. {
  81. curlfile_get_property("name", sizeof("name")-1, INTERNAL_FUNCTION_PARAM_PASSTHRU);
  82. }
  83. /* }}} */
  84. /* {{{ proto string CURLFile::getMimeType()
  85. Get MIME type */
  86. ZEND_METHOD(CURLFile, getMimeType)
  87. {
  88. curlfile_get_property("mime", sizeof("mime")-1, INTERNAL_FUNCTION_PARAM_PASSTHRU);
  89. }
  90. /* }}} */
  91. /* {{{ proto string CURLFile::getPostFilename()
  92. Get file name for POST */
  93. ZEND_METHOD(CURLFile, getPostFilename)
  94. {
  95. curlfile_get_property("postname", sizeof("postname")-1, INTERNAL_FUNCTION_PARAM_PASSTHRU);
  96. }
  97. /* }}} */
  98. /* {{{ proto void CURLFile::setMimeType(string $mime)
  99. Set MIME type */
  100. ZEND_METHOD(CURLFile, setMimeType)
  101. {
  102. curlfile_set_property("mime", sizeof("mime")-1, INTERNAL_FUNCTION_PARAM_PASSTHRU);
  103. }
  104. /* }}} */
  105. /* {{{ proto void CURLFile::setPostFilename(string $name)
  106. Set file name for POST */
  107. ZEND_METHOD(CURLFile, setPostFilename)
  108. {
  109. curlfile_set_property("postname", sizeof("postname")-1, INTERNAL_FUNCTION_PARAM_PASSTHRU);
  110. }
  111. /* }}} */
  112. /* {{{ proto CURLFile::__wakeup()
  113. Unserialization handler */
  114. ZEND_METHOD(CURLFile, __wakeup)
  115. {
  116. zend_unset_property(curl_CURLFile_class, getThis(), "name", sizeof("name")-1);
  117. zend_update_property_string(curl_CURLFile_class, getThis(), "name", sizeof("name")-1, "");
  118. zend_throw_exception(NULL, "Unserialization of CURLFile instances is not allowed", 0);
  119. }
  120. /* }}} */
  121. ZEND_BEGIN_ARG_INFO_EX(arginfo_curlfile_create, 0, 0, 1)
  122. ZEND_ARG_INFO(0, filename)
  123. ZEND_ARG_INFO(0, mimetype)
  124. ZEND_ARG_INFO(0, postname)
  125. ZEND_END_ARG_INFO()
  126. ZEND_BEGIN_ARG_INFO(arginfo_curlfile_name, 0)
  127. ZEND_ARG_INFO(0, name)
  128. ZEND_END_ARG_INFO()
  129. static const zend_function_entry curlfile_funcs[] = {
  130. PHP_ME(CURLFile, __construct, arginfo_curlfile_create, ZEND_ACC_CTOR|ZEND_ACC_PUBLIC)
  131. PHP_ME(CURLFile, getFilename, NULL, ZEND_ACC_PUBLIC)
  132. PHP_ME(CURLFile, getMimeType, NULL, ZEND_ACC_PUBLIC)
  133. PHP_ME(CURLFile, setMimeType, arginfo_curlfile_name, ZEND_ACC_PUBLIC)
  134. PHP_ME(CURLFile, getPostFilename, NULL, ZEND_ACC_PUBLIC)
  135. PHP_ME(CURLFile, setPostFilename, arginfo_curlfile_name, ZEND_ACC_PUBLIC)
  136. PHP_ME(CURLFile, __wakeup, NULL, ZEND_ACC_PUBLIC)
  137. PHP_FE_END
  138. };
  139. void curlfile_register_class(void)
  140. {
  141. zend_class_entry ce;
  142. INIT_CLASS_ENTRY( ce, "CURLFile", curlfile_funcs );
  143. curl_CURLFile_class = zend_register_internal_class(&ce);
  144. zend_declare_property_string(curl_CURLFile_class, "name", sizeof("name")-1, "", ZEND_ACC_PUBLIC);
  145. zend_declare_property_string(curl_CURLFile_class, "mime", sizeof("mime")-1, "", ZEND_ACC_PUBLIC);
  146. zend_declare_property_string(curl_CURLFile_class, "postname", sizeof("postname")-1, "", ZEND_ACC_PUBLIC);
  147. }
  148. #endif