| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use GuzzleHttp\Client; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DifyClient { | 
					
						
							|  |  |  |     protected $api_key; | 
					
						
							|  |  |  |     protected $base_url; | 
					
						
							|  |  |  |     protected $client; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-15 19:26:59 +08:00
										 |  |  |     public function __construct($api_key, $base_url = null) { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         $this->api_key = $api_key; | 
					
						
							| 
									
										
										
										
											2025-04-23 14:43:19 +07:00
										 |  |  |         $this->base_url = $base_url ?? 'https://api.dify.ai/v1/'; | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         $this->client = new Client([ | 
					
						
							|  |  |  |             'base_uri' => $this->base_url, | 
					
						
							|  |  |  |             'headers' => [ | 
					
						
							|  |  |  |                 'Authorization' => 'Bearer ' . $this->api_key, | 
					
						
							|  |  |  |                 'Content-Type' => 'application/json', | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function send_request($method, $endpoint, $data = null, $params = null, $stream = false) { | 
					
						
							|  |  |  |         $options = [ | 
					
						
							|  |  |  |             'json' => $data, | 
					
						
							|  |  |  |             'query' => $params, | 
					
						
							|  |  |  |             'stream' => $stream, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $response = $this->client->request($method, $endpoint, $options); | 
					
						
							|  |  |  |         return $response; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function message_feedback($message_id, $rating, $user) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'rating' => $rating, | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2023-05-24 21:05:05 +08:00
										 |  |  |         return $this->send_request('POST', "messages/{$message_id}/feedbacks", $data); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function get_application_parameters($user) { | 
					
						
							|  |  |  |         $params = ['user' => $user]; | 
					
						
							| 
									
										
										
										
											2023-05-24 21:05:05 +08:00
										 |  |  |         return $this->send_request('GET', 'parameters', null, $params); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function file_upload($user, $files) { | 
					
						
							|  |  |  |         $data = ['user' => $user]; | 
					
						
							|  |  |  |         $options = [ | 
					
						
							|  |  |  |             'multipart' => $this->prepareMultipart($data, $files) | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-23 14:43:19 +07:00
										 |  |  |         return $this->client->request('POST', 'files/upload', $options); | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function prepareMultipart($data, $files) { | 
					
						
							|  |  |  |         $multipart = []; | 
					
						
							|  |  |  |         foreach ($data as $key => $value) { | 
					
						
							|  |  |  |             $multipart[] = [ | 
					
						
							|  |  |  |                 'name' => $key, | 
					
						
							|  |  |  |                 'contents' => $value | 
					
						
							|  |  |  |             ]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($files as $file) { | 
					
						
							|  |  |  |             $multipart[] = [ | 
					
						
							|  |  |  |                 'name' => 'file', | 
					
						
							|  |  |  |                 'contents' => fopen($file['tmp_name'], 'r'), | 
					
						
							|  |  |  |                 'filename' => $file['name'] | 
					
						
							|  |  |  |             ]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $multipart; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-08-15 19:26:59 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function text_to_audio($text, $user, $streaming = false) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'text' => $text, | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |             'streaming' => $streaming | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->send_request('POST', 'text-to-audio', $data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function get_meta($user) { | 
					
						
							|  |  |  |         $params = [ | 
					
						
							|  |  |  |             'user' => $user | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $this->send_request('GET', 'meta',null, $params); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class CompletionClient extends DifyClient { | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  |     public function create_completion_message($inputs, $response_mode, $user, $files = null) { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'inputs' => $inputs, | 
					
						
							|  |  |  |             'response_mode' => $response_mode, | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  |             'files' => $files, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2023-05-24 21:05:05 +08:00
										 |  |  |         return $this->send_request('POST', 'completion-messages', $data, null, $response_mode === 'streaming'); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ChatClient extends DifyClient { | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  |     public function create_chat_message($inputs, $query, $user, $response_mode = 'blocking', $conversation_id = null, $files = null) { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'inputs' => $inputs, | 
					
						
							|  |  |  |             'query' => $query, | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |             'response_mode' => $response_mode, | 
					
						
							| 
									
										
										
										
											2023-11-20 17:54:01 +08:00
										 |  |  |             'files' => $files, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         if ($conversation_id) { | 
					
						
							|  |  |  |             $data['conversation_id'] = $conversation_id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-24 21:05:05 +08:00
										 |  |  |         return $this->send_request('POST', 'chat-messages', $data, null, $response_mode === 'streaming'); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-29 18:04:33 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |     public function get_suggestions($message_id, $user) { | 
					
						
							|  |  |  |         $params = [ | 
					
						
							|  |  |  |             'user' => $user | 
					
						
							| 
									
										
										
										
											2025-04-23 14:43:19 +07:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |         return $this->send_request('GET', "messages/{$message_id}/suggested", null, $params); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-29 18:04:33 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |     public function stop_message($task_id, $user) { | 
					
						
							|  |  |  |         $data = ['user' => $user]; | 
					
						
							|  |  |  |         return $this->send_request('POST', "chat-messages/{$task_id}/stop", $data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function get_conversations($user, $first_id = null, $limit = null, $pinned = null) { | 
					
						
							|  |  |  |         $params = [ | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |             'first_id' => $first_id, | 
					
						
							|  |  |  |             'limit' => $limit, | 
					
						
							|  |  |  |             'pinned'=> $pinned, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         return $this->send_request('GET', 'conversations', null, $params); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function get_conversation_messages($user, $conversation_id = null, $first_id = null, $limit = null) { | 
					
						
							|  |  |  |         $params = ['user' => $user]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($conversation_id) { | 
					
						
							|  |  |  |             $params['conversation_id'] = $conversation_id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($first_id) { | 
					
						
							|  |  |  |             $params['first_id'] = $first_id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($limit) { | 
					
						
							|  |  |  |             $params['limit'] = $limit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-24 21:05:05 +08:00
										 |  |  |         return $this->send_request('GET', 'messages', null, $params); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-29 18:04:33 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |     public function rename_conversation($conversation_id, $name,$auto_generate, $user) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'name' => $name, | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |             'user' => $user, | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |             'auto_generate' => $auto_generate | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |         return $this->send_request('PATCH', "conversations/{$conversation_id}", $data); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |     public function delete_conversation($conversation_id, $user) { | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |         $data = [ | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  |         return $this->send_request('DELETE', "conversations/{$conversation_id}", $data); | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-08-15 19:26:59 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function audio_to_text($audio_file, $user) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         $options = [ | 
					
						
							| 
									
										
										
										
											2025-04-23 14:43:19 +07:00
										 |  |  |             'multipart' => $this->prepareMultipart($data, $audio_file) | 
					
						
							| 
									
										
										
										
											2024-08-15 19:26:59 +08:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2025-04-23 14:43:19 +07:00
										 |  |  |         return $this->client->request('POST', 'audio-to-text', $options); | 
					
						
							| 
									
										
										
										
											2024-08-15 19:26:59 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-15 08:51:32 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2024-08-16 20:21:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class WorkflowClient extends DifyClient{ | 
					
						
							|  |  |  |     public function run($inputs, $response_mode, $user) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'inputs' => $inputs, | 
					
						
							|  |  |  |             'response_mode' => $response_mode, | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         return $this->send_request('POST', 'workflows/run', $data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function stop($task_id, $user) { | 
					
						
							|  |  |  |         $data = [ | 
					
						
							|  |  |  |             'user' => $user, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |         return $this->send_request('POST', "workflows/tasks/{$task_id}/stop",$data); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-29 18:04:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | } |