| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | import json | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | from collections.abc import Mapping, Sequence | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  | from typing import Any | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from pydantic import BaseModel, ConfigDict, field_validator | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from .types import SegmentType | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Segment(BaseModel): | 
					
						
							|  |  |  |     model_config = ConfigDict(frozen=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     value_type: SegmentType | 
					
						
							|  |  |  |     value: Any | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @field_validator('value_type') | 
					
						
							|  |  |  |     def validate_value_type(cls, value): | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         This validator checks if the provided value is equal to the default value of the 'value_type' field. | 
					
						
							|  |  |  |         If the value is different, a ValueError is raised. | 
					
						
							|  |  |  |         """
 | 
					
						
							|  |  |  |         if value != cls.model_fields['value_type'].default: | 
					
						
							|  |  |  |             raise ValueError("Cannot modify 'value_type'") | 
					
						
							|  |  |  |         return value | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def text(self) -> str: | 
					
						
							|  |  |  |         return str(self.value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def log(self) -> str: | 
					
						
							|  |  |  |         return str(self.value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def markdown(self) -> str: | 
					
						
							|  |  |  |         return str(self.value) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |     @property | 
					
						
							|  |  |  |     def size(self) -> int: | 
					
						
							|  |  |  |         return sys.getsizeof(self.value) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-23 16:22:06 +08:00
										 |  |  |     def to_object(self) -> Any: | 
					
						
							|  |  |  |         return self.value | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-23 17:59:32 +08:00
										 |  |  | class NoneSegment(Segment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.NONE | 
					
						
							|  |  |  |     value: None = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def text(self) -> str: | 
					
						
							|  |  |  |         return 'null' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def log(self) -> str: | 
					
						
							|  |  |  |         return 'null' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def markdown(self) -> str: | 
					
						
							|  |  |  |         return 'null' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  | class StringSegment(Segment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.STRING | 
					
						
							|  |  |  |     value: str | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | class FloatSegment(Segment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.NUMBER | 
					
						
							|  |  |  |     value: float | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IntegerSegment(Segment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.NUMBER | 
					
						
							|  |  |  |     value: int | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | class ObjectSegment(Segment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.OBJECT | 
					
						
							| 
									
										
										
										
											2024-08-07 16:20:22 +08:00
										 |  |  |     value: Mapping[str, Any] | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def text(self) -> str: | 
					
						
							|  |  |  |         return json.dumps(self.model_dump()['value'], ensure_ascii=False) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def log(self) -> str: | 
					
						
							|  |  |  |         return json.dumps(self.model_dump()['value'], ensure_ascii=False, indent=2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def markdown(self) -> str: | 
					
						
							|  |  |  |         return json.dumps(self.model_dump()['value'], ensure_ascii=False, indent=2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ArraySegment(Segment): | 
					
						
							|  |  |  |     @property | 
					
						
							|  |  |  |     def markdown(self) -> str: | 
					
						
							| 
									
										
										
										
											2024-08-15 13:09:49 +08:00
										 |  |  |         items = [] | 
					
						
							|  |  |  |         for item in self.value: | 
					
						
							|  |  |  |             if hasattr(item, 'to_markdown'): | 
					
						
							|  |  |  |                 items.append(item.to_markdown()) | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 items.append(str(item)) | 
					
						
							|  |  |  |         return '\n'.join(items) | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | class ArrayAnySegment(ArraySegment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.ARRAY_ANY | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |     value: Sequence[Any] | 
					
						
							| 
									
										
										
										
											2024-07-26 15:03:56 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class ArrayStringSegment(ArraySegment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.ARRAY_STRING | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |     value: Sequence[str] | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ArrayNumberSegment(ArraySegment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.ARRAY_NUMBER | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |     value: Sequence[float | int] | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ArrayObjectSegment(ArraySegment): | 
					
						
							|  |  |  |     value_type: SegmentType = SegmentType.ARRAY_OBJECT | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |     value: Sequence[Mapping[str, Any]] | 
					
						
							| 
									
										
										
										
											2024-07-27 14:43:51 +08:00
										 |  |  | 
 |