Compare commits

..

No commits in common. "7532b475a7db2179b87ce700841e762fccea2529" and "949d44e8533a9275e8d3c9d14aeb0dbf6a0e4d21" have entirely different histories.

4 changed files with 5 additions and 44 deletions

View file

@ -154,7 +154,3 @@ Contributions to the project are welcome. If you find any issues or have suggest
# Inspiration and Stolen Code
The premise behind this came from the [pyConnectWise](https://github.com/HealthITAU/pyconnectwise) package and I stole **most** of the code and adapted it to the Huntress API endpoints.
# How to Build
> python -m build
> python -m twine upload dist/*

View file

@ -1,6 +1,6 @@
[project]
name = "pyhuntress"
version = "0.2.16"
version = "0.2.14"
authors = [
{ name="Peter Annabel", email="peter.annabel@gmail.com" },
]

View file

@ -1,3 +1,3 @@
requests
pydantic
typing_extensions
requests==2.32.4
pydantic==2.11.7
typing_extensions==4.14.1

View file

@ -1,10 +1,8 @@
from pyhuntress.endpoints.base.huntress_endpoint import HuntressEndpoint
from pyhuntress.interfaces import (
IGettable,
IPaginateable,
)
from pyhuntress.models.managedsat import SATPhishingCampaignAttempts
from pyhuntress.responses.paginated_response import PaginatedResponse
from pyhuntress.types import (
JSON,
HuntressSATRequestParams,
@ -14,43 +12,10 @@ from pyhuntress.types import (
class PhishingCampaignsIdAttemptsEndpoint(
HuntressEndpoint,
IGettable[SATPhishingCampaignAttempts, HuntressSATRequestParams],
IPaginateable[SATPhishingCampaignAttempts, HuntressSATRequestParams],
):
def __init__(self, client, parent_endpoint=None) -> None:
HuntressEndpoint.__init__(self, client, "attempts", parent_endpoint=parent_endpoint)
IGettable.__init__(self, SATPhishingCampaignAttempts)
IPaginateable.__init__(self, SATPhishingCampaignAttempts)
def paginated(
self,
page: int,
limit: int,
params: HuntressSATRequestParams | None = None,
) -> PaginatedResponse[SATPhishingCampaignAttempts]:
"""
Performs a GET request against the /phishing-campaign-scenarios/{id}/attempts endpoint and returns an initialized PaginatedResponse object.
Parameters:
page (int): The page number to request.
limit (int): The number of results to return per page.
params (dict[str, int | str]): The parameters to send in the request query string.
Returns:
PaginatedResponse[SATPhishingCampaignAttempts]: The initialized PaginatedResponse object.
"""
if params:
params["page[number]"] = page
params["page[size]"] = limit
else:
params = {"page[number]": page, "page[size]": limit}
return PaginatedResponse(
super()._make_request("GET", params=params),
SATPhishingCampaignAttempts,
self,
"data",
page,
limit,
params,
)
def get(
self,