
    Ng                         d dl Z d dlmZ d dlmZmZmZmZ  G d d          Z	 	 	 	 ddee	         dee	         dee	         d	ee	         d
ef
dZ
dS )    N)ceil)AnyDictListOptionalc                      e Zd ZdZdeddfdZedefd            Zedee	ef         fd            Z
deddfdZdd	eee	ef                  ddfd
Z	 ddedee	eee	ef                  f         fdZ	 dde	dee         dedeee	ef                  fdZe	 	 	 	 ddee	         dee	         dee	         dee	         def
d            ZdS )ArangoGrapha  ArangoDB wrapper for graph operations.

    *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.
    dbreturnNc                 X    |                      |           |                                  dS )z-Create a new ArangoDB graph wrapper instance.N)set_db
set_schema)selfr
   s     e/var/www/html/ai-engine/env/lib/python3.11/site-packages/langchain_community/graphs/arangodb_graph.py__init__zArangoGraph.__init__   s'    B    c                     | j         S N)_ArangoGraph__dbr   s    r   r
   zArangoGraph.db   s
    yr   c                     | j         S r   )_ArangoGraph__schemar   s    r   schemazArangoGraph.schema   s
    }r   c                     ddl m} t          ||          sd}t          |          || _        |                                  d S )Nr   )Databasez;**db** parameter must inherit from arango.database.Database)arango.databaser   
isinstance	TypeErrorr   r   )r   r
   r   msgs       r   r   zArangoGraph.set_db"   sT    ,,,,,,"h'' 	!OCC..  	r   r   c                 @    ||                                  n|| _        dS )zo
        Set the schema of the ArangoDB Database.
        Auto-generates Schema if **schema** is None.
        N)generate_schemar   )r   r   s     r   r   zArangoGraph.set_schema,   s$    
 39.,,...fr   r   sample_ratioc                    d|cxk    rdk    sn t          d          d | j                                        D             }g }| j                                        D ]}|d         r|d         }|d         }| j                            |                                          }|dk    rNt          ||z            pd}d| d	| d
}	g }
| j        j        	                    |	          D ]F}|
                                D ]/\  }}|
                    |t          |          j        d           0G|                    d|d|| d|
d| |i           ||dS )a	  
        Generates the schema of the ArangoDB Database and returns it
        User can specify a **sample_ratio** (0 to 1) to determine the
        ratio of documents/edges used (in relation to the Collection size)
        to render each Collection Schema.
        r      z0**sample_ratio** value must be in between 0 to 1c                 0    g | ]}|d          |d         dS )nameedge_definitions)
graph_namer'    ).0gs     r   
<listcomp>z/ArangoGraph.generate_schema.<locals>.<listcomp>@   s:     .
 .
 .
 V9!<N:OPP.
 .
 .
r   systemr&   typez
                FOR doc in z
                    LIMIT z,
                    RETURN doc
            )r&   r.   collection_namecollection_type_propertiesexample_)zGraph SchemazCollection Schema)
ValueErrorr
   graphscollections
collectioncountr   r   aqlexecuteitemsappendr.   __name__)r   r"   graph_schemacollection_schemar6   col_namecol_typecol_sizelimit_amountr8   
propertiesdockeyvalues                 r   r!   zArangoGraph.generate_schema3   s    L%%%%A%%%%OPPP.
 .
W^^%%.
 .
 .
 35'--// #	 #	J(#  'v.H&v.H G..x88>>@@H 1}}  x 788=AL$ '  C 02Jy},,S11 S S"%))++ S SJC%%sDKK<P&Q&QRRRRS $$%x%x,,,j)x))3	    !-CTUUUr   querytop_kkwargsc                 z    ddl } | j        j        j        |fi |}d |                    ||          D             S )zQuery the ArangoDB database.r   Nc                     g | ]}|S r)   r)   )r*   rD   s     r   r,   z%ArangoGraph.query.<locals>.<listcomp>v   s    ??????r   )	itertoolsr   r8   r9   islice)r   rG   rH   rI   rL   cursors         r   rG   zArangoGraph.queryo   sR     	&&u7777??y//>>????r   urldbnameusernamepasswordc                 >    t          ||||          } | |          S )a  Convenience constructor that builds Arango DB from credentials.

        Args:
            url: Arango DB url. Can be passed in as named arg or set as environment
                var ``ARANGODB_URL``. Defaults to "http://localhost:8529".
            dbname: Arango DB name. Can be passed in as named arg or set as
                environment var ``ARANGODB_DBNAME``. Defaults to "_system".
            username: Can be passed in as named arg or set as environment var
                ``ARANGODB_USERNAME``. Defaults to "root".
            password: Can be passed ni as named arg or set as environment var
                ``ARANGODB_PASSWORD``. Defaults to "".

        Returns:
            An arango.database.StandardDatabase.
        )rO   rP   rQ   rR   )get_arangodb_client)clsrO   rP   rQ   rR   r
   s         r   from_db_credentialszArangoGraph.from_db_credentialsx   s0    . !FX
 
 
 s2wwr   r   )r   NNNN)r<   
__module____qualname____doc__r   r   propertyr
   r   strr   r   r   r   floatr   r!   intrG   classmethodrV   r)   r   r   r	   r	      s        3 4    
 C    X S#X    X     M M$sCx.!9 MT M M M M %&:V :V!:V	c4S#X''	(:V :V :V :Vz 26@ @@!)#@AD@	d38n	@ @ @ @  " $"&"& c]  3-	
 3- 
   [  r   r	   rO   rP   rQ   rR   r   c                    	 ddl m} n"# t          $ r}t          d          |d}~ww xY w| pt          j                            dd          }|pt          j                            dd          }|pt          j                            d	d
          }|pt          j                            dd          }	 ||                              |||	d          S )a  Get the Arango DB client from credentials.

    Args:
        url: Arango DB url. Can be passed in as named arg or set as environment
            var ``ARANGODB_URL``. Defaults to "http://localhost:8529".
        dbname: Arango DB name. Can be passed in as named arg or set as
            environment var ``ARANGODB_DBNAME``. Defaults to "_system".
        username: Can be passed in as named arg or set as environment var
            ``ARANGODB_USERNAME``. Defaults to "root".
        password: Can be passed ni as named arg or set as environment var
            ``ARANGODB_PASSWORD``. Defaults to "".

    Returns:
        An arango.database.StandardDatabase.
    r   )ArangoClientzIUnable to import arango, please install with `pip install python-arango`.NARANGODB_URLzhttp://localhost:8529ARANGODB_DBNAME_systemARANGODB_USERNAMErootARANGODB_PASSWORD T)verify)arangora   ImportErrorosenvirongetr
   )
rO   rP   rQ   rR   ra   e_url_dbname	_username	_passwords
             r   rT   rT      s    *'''''''   W
 
	
 Nrz~~n6MNNDIRZ^^,=yIIGL0CV!L!LIH0CR!H!HI<  )Yt LLLs   	 
(#(rW   )rl   mathr   typingr   r   r   r   r	   r\   rT   r)   r   r   <module>rv      s    				       , , , , , , , , , , , ,L L L L L L L L`  ""	!M !M	#!MSM!M sm!M sm	!M
 	!M !M !M !M !M !Mr   