
    hp'                        d Z ddlmZ ddlZddlmZmZmZmZ ddl	m
Z
 ddlmZ ddlmZ ddlmZ dd	lmZ dd
lmZ ddlmZmZmZ ddlmZ  G d de
      Zy)z Question answering over a graph.    )annotationsN)AnyDictListOptional)ChainLLMChain)CallbackManagerForChainRun)BaseLanguageModel)BasePromptTemplate)Field)AQL_FIX_PROMPTAQL_GENERATION_PROMPTAQL_QA_PROMPT)ArangoGraphc                  P    e Zd ZU dZ ed      Zded<   ded<   ded<   ded	<   d
Zded<   dZded<   dZ	ded<   dZ
ded<   dZded<   dZded<   dZded<   dZded<   	 d" fdZed#d       Zed#d       Zed$d       Zeeeed	 	 	 	 	 	 	 	 	 	 	 d%d        Z	 d&	 	 	 	 	 d'd!Z xZS )(ArangoGraphQAChaina  Chain for question-answering against a graph by generating AQL statements.

    *Security note*: Make sure that the database connection uses credentials
        that are narrowly-scoped to only include necessary permissions.
        Failure to do so may result in data corruption or loss, since the calling
        code may attempt commands that would result in deletion, mutation
        of data if appropriately prompted or reading sensitive data if such
        data is present in the database.
        The best way to guard against such negative outcomes is to (as appropriate)
        limit the permissions granted to the credentials used with this tool.

        See https://python.langchain.com/docs/security for more information.
    T)excluder   graphr
   aql_generation_chainaql_fix_chainqa_chainquerystr	input_keyresult
output_key
   inttop_k aql_examplesFboolreturn_aql_queryreturn_aql_result   max_aql_generation_attemptsallow_dangerous_requestsc                V    t        |   di | | j                  durt        d      y)zInitialize the chain.Ta  In order to use this chain, you must acknowledge that it can make dangerous requests by setting `allow_dangerous_requests` to `True`.You must narrowly scope the permissions of the database connection to only include necessary permissions. Failure to do so may result in data corruption or loss or reading sensitive data if such data is present in the database.Only use this chain if you understand the risks and have taken the necessary precautions. See https://python.langchain.com/docs/security for more information.N )super__init__r)   
ValueError)selfkwargs	__class__s     j/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/langchain_community/chains/graph_qa/arangodb.pyr-   zArangoGraphQAChain.__init__K   s9    "6"((4W
 
 5    c                    | j                   gS N)r   r/   s    r2   
input_keyszArangoGraphQAChain.input_keys[   s    r3   c                    | j                   gS r5   )r   r6   s    r2   output_keyszArangoGraphQAChain.output_keys_   s      r3   c                     y)Ngraph_aql_chainr+   r6   s    r2   _chain_typezArangoGraphQAChain._chain_typec   s     r3   )	qa_promptaql_generation_promptaql_fix_promptc               h    t        ||      }t        ||      }t        ||      } | d|||d|S )zInitialize from LLM.)llmprompt)r   r   r   r+   r	   )	clsrA   r=   r>   r?   r0   r   r   r   s	            r2   from_llmzArangoGraphQAChain.from_llmg   sO     I6'C8MN S@ 
!5'
 	
 	
r3   c                   |xs t        j                         }|j                         }|| j                     }| j                  j                  | j                  j                  | j                  |d|      }d}d}d}	d}
|	|
| j                  dz   k  rd}t        j                  ||t        j                        }|sK|j                  dd| j                  	       |j                  |d
d| j                         t        d|       |d   }|j                  d|
 d| j                         |j                  |dd| j                         ddlm} 	 | j                  j%                  || j&                        }	|
dz  }
|	|
| j                  dz   k  r|	d| d}t        |      |j                  dd| j                  	       |j                  t-        |	      dd| j                         | j/                  | j                  j                  |||	d|      }| j0                  || j.                  j0                     i}| j2                  r||d<   | j4                  r|	|d<   |S # |$ r}|j(                  }|j                  dd| j                  	       |j                  |dd| j                         | j*                  j                  | j                  j                  ||d|      }Y d}~rd}~ww xY w)aw  
        Generate an AQL statement from user input, use it retrieve a response
        from an ArangoDB Database instance, and respond to the user input
        in natural language.

        Users can modify the following ArangoGraphQAChain Class Variables:

        :var top_k: The maximum number of AQL Query Results to return
        :type top_k: int

        :var aql_examples: A set of AQL Query Examples that are passed to
            the AQL Generation Prompt Template to promote few-shot-learning.
            Defaults to an empty string.
        :type aql_examples: str

        :var return_aql_query: Whether to return the AQL Query in the
            output dictionary. Defaults to False.
        :type return_aql_query: bool

        :var return_aql_result: Whether to return the AQL Query in the
            output dictionary. Defaults to False
        :type return_aql_result: bool

        :var max_aql_generation_attempts: The maximum amount of AQL
            Generation attempts to be made prior to raising the last
            AQL Query Execution Error. Defaults to 3.
        :type max_aql_generation_attempts: int
        )
adb_schemar#   
user_input)	callbacksr"   N   z```(?i:aql)?(.*?)```zInvalid Response: 
)endverbosered)colorrK   rL   zResponse is Invalid: r   zAQL Query (z):)rL   green)AQLQueryExecuteErrorzAQL Query Execution Error: yellowz

)rF   	aql_query	aql_errorz
                Maximum amount of AQL Query Generation attempts reached.
                Unable to execute the AQL Query due to the following error:
                z
            zAQL Result:)rF   rG   rR   
aql_resultrR   rT   )r   get_noop_manager	get_childr   r   runr   schemar#   r(   refindallDOTALLon_textrL   r.   arangorP   r   r!   error_messager   r   r   r   r%   r&   )r/   inputsrun_manager_run_managerrH   rG   aql_generation_outputrR   rS   rT   aql_generation_attemptpatternmatchesrP   emr   s                    r2   _callzArangoGraphQAChain._call}   sA   B #S&@&Q&Q&S **,	DNN+
 !% 9 9 = ="jj// $ 1 1(
   !> !
 		
!" &)I)IA)MM .Gjj*?KG$$(dDLL %  $$)D$,, %  !#89N8O!PQQ
I   45R8$,, !    dDLL !  4!ZZ--iD
2 #a'"q &)I)IA)MMr   A
 Q-]dllK
O7dll 	 	
 "jj//(&(	    
 //6$--*B*B#CD  "+F;!!#-F< { ( OO	$$1tT\\ %  $$X64<< %  )-(:(:(>(>&*jj&7&7%.%.
 ( )? )%s   &I$ $K2)A>K--K2)r0   r   returnNone)ri   z	List[str])ri   r   )rA   r   r=   r   r>   r   r?   r   r0   r   ri   r   r5   )r_   Dict[str, Any]r`   z$Optional[CallbackManagerForChainRun]ri   rk   )__name__
__module____qualname____doc__r   r   __annotations__r   r   r!   r#   r%   r&   r(   r)   r-   propertyr7   r9   r<   classmethodr   r   r   rD   rh   __classcell__)r1   s   @r2   r   r      sR    t,E;,""IsJ E3O L# #d" $t# ()(%*d*      ! ! ! ! 
 )64I-;

 &	

  2
 +
 
 

 
0 =ATT :T 
	Tr3   r   )ro   
__future__r   rY   typingr   r   r   r   langchain.chains.baser   langchain.chains.llmr
   langchain_core.callbacksr   langchain_core.language_modelsr   langchain_core.promptsr   pydanticr   +langchain_community.chains.graph_qa.promptsr   r   r   )langchain_community.graphs.arangodb_graphr   r   r+   r3   r2   <module>r~      sD    & " 	 , , ' ) ? < 5  
 Bz zr3   