Skip to main content

Enerplex API Client

Project description

Enerplex API Client

The Enerplex API Client is a Python package designed to interact with the Enerplex platform, providing functionality to manage and retrieve data related to target proteins, ligands, and their embeddings. This package facilitates authentication, data retrieval, and file management through a user-friendly interface.

Features

  • Authentication: Securely authenticate with the Enerplex API using user credentials.
  • Target Proteins: Retrieve and manage information about target proteins.
  • Ligands: Fetch ligands associated with specific proteins and upload new ligands.
  • Embeddings: Retrieve embeddings for proteins and ligands.
  • File Management: Download and manage files related to proteins, ligands, and embeddings.

Installation

Install the package using pip:

pip install enerplex

Setup

The package uses environment variables for configuration. Either set environment variable or create a .env file in your project directory with the following variables:

ENERPLEX_API_URL=<your-api-url>
ENERPLEX_API_USER=<your-username>
ENERPLEX_API_USER_PASSWORD=<your-password>

Usage

Authentication

The package automatically handles authentication. Tokens are refreshed as needed to ensure seamless interaction with the API.

Fetch Target Proteins

from enerplex import get_target_proteins

proteins = get_target_proteins()
for protein in proteins:
    print(protein.name)

Fetch Ligands

from enerplex import get_ligands

ligands = get_ligands(protein_identifier=123)
for ligand in ligands:
    print(ligand.id, ligand.name)

Download Files

from enerplex import download_target_protein_file
from pathlib import Path

protein = ...  # A DBTargetProtein object
download_target_protein_file(protein, path=Path("/path/to/save/file"))

Upload Ligands

from enerplex import upload_ligand
from pathlib import Path

ligand = upload_ligand(
    target_name="ProteinX",
    score=92.5,
    scoring_function="Docking",
    ligand_structure_file_path=Path("/path/to/ligand/file")
)
print(ligand.id, ligand.name)

Contributing

Contributions are welcome! If you'd like to contribute, please fork the repository and submit a pull request. Ensure your code adheres to the existing style and is well-documented.

License

This package is licensed under the MIT License. See the LICENSE file for more details.

Support

For any issues or questions, please open an issue on the GitHub repository or contact the maintainer directly.


Example Workflow

Here's a complete example that retrieves a target protein, downloads its associated file, and uploads a new ligand:

from enerplex import get_target_proteins, download_target_protein_file, upload_ligand, DBProteinLigandComplex, DBTargetProtein
from pathlib import Path

# Retrieve proteins
proteins: list[DBTargetProtein] = get_target_proteins()
selected_protein: DBTargetProtein = proteins[0]

# Download protein file
download_target_protein_file(selected_protein, path=Path("protein_file.pdb"))

# Build a ligand with some workflow
# ...

# Upload the new ligand
new_ligand: DBProteinLigandComplex  = upload_ligand(
    target_name=selected_protein.name,
    score=-9.3,
    scoring_function="Vina",
    ligand_structure_file_path=Path("ligand_structure.pdb")
)
print(f"Uploaded ligand: {new_ligand.id}, {new_ligand.name}")

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

enerplex-0.2.0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

enerplex-0.2.0-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file enerplex-0.2.0.tar.gz.

File metadata

  • Download URL: enerplex-0.2.0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for enerplex-0.2.0.tar.gz
Algorithm Hash digest
SHA256 c4bdf78af5143fc4d044dbed379edc2c70039859b2a31196ec1b7dc6df9a6465
MD5 9b46e65935adc93088c6571a18e08b4c
BLAKE2b-256 c19e847a0ba29d1558fbefa5475b379b8741b78fbefc8b8a631b00f4e27e92a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for enerplex-0.2.0.tar.gz:

Publisher: publish.yml on NoxelS/enerplex-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file enerplex-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: enerplex-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 11.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for enerplex-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7fbbf6a7ebb717e7386a27f9c461d9d0a0cb69f67aeb95792437373294818e20
MD5 5687f35dc7dbbecae6afd317e1c923fa
BLAKE2b-256 8d27635b1c72d0e62280be44022f830ece8e988aa1aca137905ec64363691fd6

See more details on using hashes here.

Provenance

The following attestation bundles were made for enerplex-0.2.0-py3-none-any.whl:

Publisher: publish.yml on NoxelS/enerplex-api-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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