Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 34 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
name: Build and test

on:
push:
pull_request:

jobs:
build:
runs-on: ubuntu-latest

strategy:
matrix:
python-version: ["3.13"]
fail-fast: false

steps:
- uses: actions/checkout@v4

- name: Install uv
uses: astral-sh/setup-uv@v5
with:
python-version: ${{ matrix.python-version }}

- name: Install dependencies
run: uv sync

- name: Lint (ruff)
run: uv run ruff check src/ tests/

- name: Type check (mypy)
run: uv run mypy src/

- name: Test (pytest)
run: uv run pytest --cov=src --cov-report=term-missing
29 changes: 29 additions & 0 deletions .github/workflows/publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
name: Publish to PyPI

on:
release:
types: [published]

jobs:
publish:
runs-on: ubuntu-latest

permissions:
id-token: write # required for OIDC trusted publisher

steps:
- uses: actions/checkout@v4

- name: Install uv
uses: astral-sh/setup-uv@v5
with:
python-version: "3.13"

- name: Install dependencies
run: uv sync

- name: Build wheel and sdist
run: uv build

- name: Publish to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
4 changes: 2 additions & 2 deletions CITATION.cff
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@ abstract: "Python client for Puzzel SMS Gateway."
authors:
- family-names: "Lie Uberg"
given-names: Lewi
version: 2.0.4
date-released: 2024-03-06
version: 3.0.0
date-released: 2026-04-13
repository-code: "https://github.com/PuzzelSolutions/smsgw-client-python"
license: MIT
keywords:
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[project]
name = "puzzel-sms-gateway-client"
version = "2.0.4"
version = "3.0.0"
description = "Puzzel SMS Gateway Python Client (Kiota-generated)"
requires-python = ">=3.13"
license = {text = "MIT"}
Expand Down
33 changes: 33 additions & 0 deletions src/gw/gw_request_builder.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
from __future__ import annotations
from collections.abc import Callable
from kiota_abstractions.base_request_builder import BaseRequestBuilder
from kiota_abstractions.get_path_parameters import get_path_parameters
from kiota_abstractions.request_adapter import RequestAdapter
from typing import Any, Optional, TYPE_CHECKING, Union

if TYPE_CHECKING:
from .rs.rs_request_builder import RsRequestBuilder

class GwRequestBuilder(BaseRequestBuilder):
"""
Builds and executes requests for operations under /gw
"""
def __init__(self,request_adapter: RequestAdapter, path_parameters: Union[str, dict[str, Any]]) -> None:
"""
Instantiates a new GwRequestBuilder and sets the default values.
param path_parameters: The raw url or the url-template parameters for the request.
param request_adapter: The request adapter to use to execute the requests.
Returns: None
"""
super().__init__(request_adapter, "{+baseurl}/gw", path_parameters)

@property
def rs(self) -> RsRequestBuilder:
"""
The rs property
"""
from .rs.rs_request_builder import RsRequestBuilder

return RsRequestBuilder(self.request_adapter, self.path_parameters)


33 changes: 33 additions & 0 deletions src/gw/rs/rs_request_builder.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
from __future__ import annotations
from collections.abc import Callable
from kiota_abstractions.base_request_builder import BaseRequestBuilder
from kiota_abstractions.get_path_parameters import get_path_parameters
from kiota_abstractions.request_adapter import RequestAdapter
from typing import Any, Optional, TYPE_CHECKING, Union

if TYPE_CHECKING:
from .send_messages.send_messages_request_builder import SendMessagesRequestBuilder

class RsRequestBuilder(BaseRequestBuilder):
"""
Builds and executes requests for operations under /gw/rs
"""
def __init__(self,request_adapter: RequestAdapter, path_parameters: Union[str, dict[str, Any]]) -> None:
"""
Instantiates a new RsRequestBuilder and sets the default values.
param path_parameters: The raw url or the url-template parameters for the request.
param request_adapter: The request adapter to use to execute the requests.
Returns: None
"""
super().__init__(request_adapter, "{+baseurl}/gw/rs", path_parameters)

@property
def send_messages(self) -> SendMessagesRequestBuilder:
"""
The sendMessages property
"""
from .send_messages.send_messages_request_builder import SendMessagesRequestBuilder

return SendMessagesRequestBuilder(self.request_adapter, self.path_parameters)


148 changes: 148 additions & 0 deletions src/gw/rs/send_messages/send_messages_request_builder.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,148 @@
from __future__ import annotations
from collections.abc import Callable
from dataclasses import dataclass, field
from kiota_abstractions.base_request_builder import BaseRequestBuilder
from kiota_abstractions.base_request_configuration import RequestConfiguration
from kiota_abstractions.default_query_parameters import QueryParameters
from kiota_abstractions.get_path_parameters import get_path_parameters
from kiota_abstractions.method import Method
from kiota_abstractions.request_adapter import RequestAdapter
from kiota_abstractions.request_information import RequestInformation
from kiota_abstractions.request_option import RequestOption
from kiota_abstractions.serialization import Parsable, ParsableFactory
from typing import Any, Optional, TYPE_CHECKING, Union
from warnings import warn

if TYPE_CHECKING:
from ....models.gateway_request import GatewayRequest
from ....models.gateway_response import GatewayResponse
from ....models.problem_details import ProblemDetails

class SendMessagesRequestBuilder(BaseRequestBuilder):
"""
Builds and executes requests for operations under /gw/rs/sendMessages
"""
def __init__(self,request_adapter: RequestAdapter, path_parameters: Union[str, dict[str, Any]]) -> None:
"""
Instantiates a new SendMessagesRequestBuilder and sets the default values.
param path_parameters: The raw url or the url-template parameters for the request.
param request_adapter: The request adapter to use to execute the requests.
Returns: None
"""
super().__init__(request_adapter, "{+baseurl}/gw/rs/sendMessages?Message={Message}&Password={Password}&Username={Username}{&BatchReference*,ServiceId*}", path_parameters)

async def get(self,request_configuration: Optional[RequestConfiguration[SendMessagesRequestBuilderGetQueryParameters]] = None) -> Optional[bytes]:
"""
param request_configuration: Configuration for the request such as headers, query parameters, and middleware options.
Returns: bytes
"""
request_info = self.to_get_request_information(
request_configuration
)
if not self.request_adapter:
raise Exception("Http core is null")
return await self.request_adapter.send_primitive_async(request_info, "bytes", None)

async def post(self,body: GatewayRequest, request_configuration: Optional[RequestConfiguration[QueryParameters]] = None) -> Optional[GatewayResponse]:
"""
param body: The request body
param request_configuration: Configuration for the request such as headers, query parameters, and middleware options.
Returns: Optional[GatewayResponse]
"""
if body is None:
raise TypeError("body cannot be null.")
request_info = self.to_post_request_information(
body, request_configuration
)
from ....models.problem_details import ProblemDetails

error_mapping: dict[str, type[ParsableFactory]] = {
"401": ProblemDetails,
}
if not self.request_adapter:
raise Exception("Http core is null")
from ....models.gateway_response import GatewayResponse

return await self.request_adapter.send_async(request_info, GatewayResponse, error_mapping)

def to_get_request_information(self,request_configuration: Optional[RequestConfiguration[SendMessagesRequestBuilderGetQueryParameters]] = None) -> RequestInformation:
"""
param request_configuration: Configuration for the request such as headers, query parameters, and middleware options.
Returns: RequestInformation
"""
request_info = RequestInformation(Method.GET, self.url_template, self.path_parameters)
request_info.configure(request_configuration)
return request_info

def to_post_request_information(self,body: GatewayRequest, request_configuration: Optional[RequestConfiguration[QueryParameters]] = None) -> RequestInformation:
"""
param body: The request body
param request_configuration: Configuration for the request such as headers, query parameters, and middleware options.
Returns: RequestInformation
"""
if body is None:
raise TypeError("body cannot be null.")
request_info = RequestInformation(Method.POST, '{+baseurl}/gw/rs/sendMessages', self.path_parameters)
request_info.configure(request_configuration)
request_info.headers.try_add("Accept", "application/json")
request_info.set_content_from_parsable(self.request_adapter, "application/json", body)
return request_info

def with_url(self,raw_url: str) -> SendMessagesRequestBuilder:
"""
Returns a request builder with the provided arbitrary URL. Using this method means any other path or query parameters are ignored.
param raw_url: The raw URL to use for the request builder.
Returns: SendMessagesRequestBuilder
"""
if raw_url is None:
raise TypeError("raw_url cannot be null.")
return SendMessagesRequestBuilder(self.request_adapter, raw_url)

@dataclass
class SendMessagesRequestBuilderGetQueryParameters():
def get_query_parameter(self,original_name: str) -> str:
"""
Maps the query parameters names to their encoded names for the URI template parsing.
param original_name: The original query parameter name in the class.
Returns: str
"""
if original_name is None:
raise TypeError("original_name cannot be null.")
if original_name == "batch_reference":
return "BatchReference"
if original_name == "message":
return "Message"
if original_name == "password":
return "Password"
if original_name == "service_id":
return "ServiceId"
if original_name == "username":
return "Username"
return original_name

batch_reference: Optional[str] = None

message: Optional[list[str]] = None

password: Optional[str] = None

service_id: Optional[int] = None

username: Optional[str] = None


@dataclass
class SendMessagesRequestBuilderGetRequestConfiguration(RequestConfiguration[SendMessagesRequestBuilderGetQueryParameters]):
"""
Configuration for the request such as headers, query parameters, and middleware options.
"""
warn("This class is deprecated. Please use the generic RequestConfiguration class generated by the generator.", DeprecationWarning)

@dataclass
class SendMessagesRequestBuilderPostRequestConfiguration(RequestConfiguration[QueryParameters]):
"""
Configuration for the request such as headers, query parameters, and middleware options.
"""
warn("This class is deprecated. Please use the generic RequestConfiguration class generated by the generator.", DeprecationWarning)


39 changes: 39 additions & 0 deletions src/kiota-lock.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
{
"descriptionHash": "5269EB413FDAB685C5F9A1648ECEDC5DE1ECA2E7A96AD20E95A0228BD8A43C50637B565F8218237F045B6EFBC307B8ECB1D11194478A84638417F7B1DB0B3414",
"descriptionLocation": "../../../source-generator/swagger.json",
"lockFileVersion": "1.0.0",
"kiotaVersion": "1.31.0",
"clientClassName": "MtHttpClient",
"typeAccessModifier": "Public",
"clientNamespaceName": "Puzzel.SmsGateway.Clients.MtHttp",
"language": "Python",
"usesBackingStore": false,
"excludeBackwardCompatible": false,
"includeAdditionalData": true,
"disableSSLValidation": false,
"serializers": [
"Microsoft.Kiota.Serialization.Json.JsonSerializationWriterFactory",
"Microsoft.Kiota.Serialization.Text.TextSerializationWriterFactory",
"Microsoft.Kiota.Serialization.Form.FormSerializationWriterFactory",
"Microsoft.Kiota.Serialization.Multipart.MultipartSerializationWriterFactory"
],
"deserializers": [
"Microsoft.Kiota.Serialization.Json.JsonParseNodeFactory",
"Microsoft.Kiota.Serialization.Text.TextParseNodeFactory",
"Microsoft.Kiota.Serialization.Form.FormParseNodeFactory"
],
"structuredMimeTypes": [
"application/json",
"text/plain;q=0.9",
"application/x-www-form-urlencoded;q=0.2",
"multipart/form-data;q=0.1"
],
"includePatterns": [],
"excludePatterns": [
"/v4/**",
"/mgmt/**",
"/chimera/**",
"/smsgw/**"
],
"disabledValidationRules": []
}
Loading
Loading