Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use dataclasses for ChargingProfile usage #648

Merged
Merged
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
86a773d
Add dataclasses for ChargingProfile and it's constituents
grutts Jan 26, 2021
3b91490
Fix flake8 line length
grutts Jan 26, 2021
689cd1e
Merge branch 'master' into adrian/add_charging_profile_types
grutts Feb 28, 2021
19bfe11
remove_nones now handles nested dicts and lists of dicts
grutts Feb 28, 2021
10c968f
Fix flake8
grutts Feb 28, 2021
282e99e
Accept Dict for backwards compatibility
grutts Feb 28, 2021
9a714e4
Address review comments
grutts Mar 11, 2021
4c82c8c
Fix flake8 line too long
grutts Mar 11, 2021
9429467
Merge branch 'master' into adrian/add_charging_profile_types
grutts Mar 29, 2021
dc17b77
Merge branch 'master' of https://github.com/mobilityhouse/ocpp into a…
jerome-benoit Jun 12, 2024
10e25ae
fix merge issues
jerome-benoit Jun 12, 2024
4fa2727
Merge branch 'master' into charging_profile_types
jerome-benoit Jun 18, 2024
8a954ec
Merge branch 'master' into charging_profile_types
proelke Oct 15, 2024
5fee7c0
Merge branch 'master' into charging_profile_types
jerome-benoit Nov 26, 2024
3e5ab68
Merge branch 'master' into charging_profile_types
jerome-benoit Dec 9, 2024
5be966a
fix: use already defined charging profile types
jerome-benoit Dec 9, 2024
401b78b
Merge branch 'master' into charging_profile_types
jerome-benoit Dec 9, 2024
f5f1ded
Merge branch 'master' into charging_profile_types
jerome-benoit Dec 9, 2024
e8f6259
Merge branch 'master' into charging_profile_types
jerome-benoit Dec 18, 2024
d09fcfd
Update ocpp/v16/call.py
jerome-benoit Dec 18, 2024
f55a501
Update ocpp/v16/call.py
jerome-benoit Dec 18, 2024
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
Prev Previous commit
Next Next commit
Address review comments
* Change Decimal to float
* Move dataclasses to separate charging_profile module
* Add ChargingProfile type to RemoteStartTransaction payload
grutts committed Mar 11, 2021
commit 9a714e416ffc5d0badf2d74f2edc3a177a0643d0
43 changes: 3 additions & 40 deletions ocpp/v16/call.py
Original file line number Diff line number Diff line change
@@ -1,19 +1,17 @@
from decimal import Decimal
from typing import Any, Dict, List, Optional, Union
from dataclasses import dataclass, field

from ocpp.v16.charging_profile import ChargingProfile
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved
from ocpp.v16.enums import (
AvailabilityType,
ChargePointErrorCode,
ChargePointStatus,
ChargingProfileKindType,
ChargingProfilePurposeType,
ChargingRateUnitType,
DiagnosticsStatus,
FirmwareStatus,
MessageTrigger,
Reason,
RecurrencyKind,
ResetType,
UpdateType,
)
@@ -96,7 +94,8 @@ class GetLocalListVersionPayload:
class RemoteStartTransactionPayload:
id_tag: str
connector_id: Optional[int] = None
charging_profile: Optional[Dict] = None
# Accept Dict for backwards compatibility
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved
charging_profile: Union[ChargingProfile, Dict, None] = None
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved


@dataclass
@@ -125,42 +124,6 @@ class SendLocalListPayload:
local_authorization_list: List = field(default_factory=list)


@dataclass
class ChargingSchedulePeriod:
"""Charging schedule period structure defines a time period
in a charging schedule, as used in: ChargingSchedule."""
start_period: int
limit: Decimal
number_phases: Optional[int] = None


@dataclass
class ChargingSchedule:
"""Charging schedule structure defines a list of charging periods,
as used in: GetCompositeSchedule.conf and ChargingProfile."""

charging_rate_unit: ChargingRateUnitType
charging_schedule_period: List[ChargingSchedulePeriod]
duration: Optional[int] = None
start_schedule: Optional[str] = None
min_charging_rate: Optional[Decimal] = None


@dataclass
class ChargingProfile:
"""A ChargingProfile consists of a ChargingSchedule, describing the
amount of power or current that can be delivered per time interval."""
charging_profile_id: int
stack_level: int
charging_profile_purpose: ChargingProfilePurposeType
charging_profile_kind: ChargingProfileKindType
charging_schedule: ChargingSchedule
transaction_id: Optional[int] = None
recurrency_kind: Optional[RecurrencyKind] = None
valid_from: Optional[str] = None
valid_to: Optional[str] = None


@dataclass
class SetChargingProfilePayload:
connector_id: int
40 changes: 40 additions & 0 deletions ocpp/v16/charging_profile.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
from dataclasses import dataclass
from typing import Optional, List

from ocpp.v16.enums import ChargingRateUnitType, ChargingProfilePurposeType, ChargingProfileKindType, RecurrencyKind


@dataclass
class ChargingSchedulePeriod:
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved
"""Charging schedule period structure defines a time period
in a charging schedule, as used in: ChargingSchedule."""
start_period: int
limit: float
number_phases: Optional[int] = None


@dataclass
class ChargingSchedule:
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved
"""Charging schedule structure defines a list of charging periods,
as used in: GetCompositeSchedule.conf and ChargingProfile."""

charging_rate_unit: ChargingRateUnitType
charging_schedule_period: List[ChargingSchedulePeriod]
duration: Optional[int] = None
start_schedule: Optional[str] = None
min_charging_rate: Optional[float] = None


@dataclass
class ChargingProfile:
jerome-benoit marked this conversation as resolved.
Show resolved Hide resolved
"""A ChargingProfile consists of a ChargingSchedule, describing the
amount of power or current that can be delivered per time interval."""
charging_profile_id: int
stack_level: int
charging_profile_purpose: ChargingProfilePurposeType
charging_profile_kind: ChargingProfileKindType
charging_schedule: ChargingSchedule
transaction_id: Optional[int] = None
recurrency_kind: Optional[RecurrencyKind] = None
valid_from: Optional[str] = None
valid_to: Optional[str] = None