Skip to main content

Python wrapper around linkurious API

Project description

Description

linkurious is a tortilla based python wrapper around the Linkurious HTTP REST API that allows users to remotely manage a Linkurious instance, performing the same tasks that can be done through the web application.

This can be useful to:

  • automate some of the most tedious tasks
  • integrate the Linkurious instance within a wider multi-services application

Linkurious Enterprise is a copyrighted graph visualization and analysis platform, that allows users to perform queries and build visualizations on multiple graph databases (Neo4j, CosmosDB, JanusGraph).

Installation

Python versions from 3.6 are supported.

The package is hosted on pypi, and can be installed, for example using pip:

pip install linkurious

Usage

The package only has one class (and one exception), creating a Linkurious instance passing username and password will connect to the instance. All following operations will be performed using the same user session.

from linkurious import Linkurious

# login
l = Linkurious(
    host='https://linkurious.example.org', 
    username='user@mail.org', 
    password='****', 
    debug=False
)

# query execution
query = """
MATCH (p:Person)-[i]-(m:Movie) where m.id=12
return p, i, m
limit 100
"""
r = l.run_cypher_query(sourcekey='ae46c2f7', query=query)

# nodes and edges are transformed before being sent to the visualization 
r_nodes = [
    {
        'id': n.data.properties.id, 
        'data': {
            'geo': {}
        }, 
        'attributes': {
            'layoutable': True, 
            'x': 0, 'y': 0
        }
    } 
    for n in r['nodes']
]
r_edges = [
    {
        'id': e.data.properties.id, 
        'attributes': {}
    } 
    for e in r.edges
]

# visualization creation
v = l.create_visualization(
    sourcekey='ae46c2f7', 
    title="Test from API", 
    nodes=r_nodes, 
    edges=r_edges
)
# server-side auto layouting, in order to spread the nodes
l.patch_visualization(
    sourcekey='ae46c2f7', id=v.id, 
    do_layout=True,
)

# visualization styles are reset
v.design.styles.node = []
v.design.styles.edge = []
l.patch_visualization(
    sourcekey='ae46c2f7', id=v.id,     
    visualization={'design': dict(v.design)},
    force_lock=True
)

# so that they can now be built anew
# see https://doc.linkurio.us/server-sdk/latest/apidoc/#api-Visualization-createVisualization
# and the links on INodeStyle and IEdgeStyle
v.design.styles.node = [
    { ... }
] 
v.design.styles.edges = [
    { ... }
] 
# design is updated in the visualization
# it must be transformed into a dict, as v is a Bunch (from tortilla),
# and it may causes all sorts of bad requests responses from Linkurious API
l.patch_visualization(
    sourcekey='ae46c2f7', id=v.id,     
    visualization={'design': dict(v.design)},
    force_lock=True
)

# the same can be done for 
# - visualization filters (v.filters)
# - visualization captions (v.nodeFields, v.edgeFields)

Support

There is no guaranteed support available, but authors will try to keep up with issues and merge proposed solutions into the code base.

Project Status

This project is funded by the European Commission and is currently (2021) under active developement.

Contributing

In order to contribute to this project:

  • verify that python 3.6+ is being used (or use pyenv)
  • verify or install poetry, to handle packages and dependencies in a leaner way, with respect to pip and requirements
  • clone the project git clone git@github.com:openpolis/linkurious.git
  • install the dependencies in the virtualenv, with poetry install, this will also install the dev dependencies
  • develop
  • create a pull request
  • wait for the maintainers to review and eventually merge your pull request into the main repository

Testing

As this is a tiny utility wrapper around an already tested and quite simple package (tortilla), there are no tests.

Authors

Guglielmo Celata - guglielmo@openpolis.it

Licensing

This package is released under an MIT License, see details in the LICENSE.txt file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

linkurious-0.1.1.tar.gz (7.0 kB view details)

Uploaded Source

Built Distribution

linkurious-0.1.1-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file linkurious-0.1.1.tar.gz.

File metadata

  • Download URL: linkurious-0.1.1.tar.gz
  • Upload date:
  • Size: 7.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.9 Darwin/20.5.0

File hashes

Hashes for linkurious-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a047bbb61561bfe7845383f98a430a3ef7ccf542993385a29908a15131de0410
MD5 5b69b2516dcc442279dade1ee282ca23
BLAKE2b-256 bd5615b40b6f76812c0899eeec2f8a3a1431bce308eeaa419abbb31d872d0a72

See more details on using hashes here.

File details

Details for the file linkurious-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: linkurious-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.9 Darwin/20.5.0

File hashes

Hashes for linkurious-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 34bf629669717190f81ceac2c30d6a4d5452268ae57106e9c964f3f7e6a221d2
MD5 537e6d6a3186370bd96a9e62e6855109
BLAKE2b-256 a56d380013b9dd00d8d00a564eb2a371cdc66b3d96d771055a0af5d7d5f665d4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page