solax-py-library 0.1.0.7__tar.gz → 0.1.0.10__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/PKG-INFO +1 -1
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/pyproject.toml +1 -1
- solax_py_library-0.1.0.10/solax_py_library/upload/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/api/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/api/__pycache__/service.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/__pycache__/base.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/__pycache__/csv.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/csv.py +26 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/upload_service/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/upload_service/__pycache__/base.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/core/upload_service/__pycache__/ftp.cpython-38.pyc +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/upload_service/base.py +2 -2
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/upload_service/ftp.py +4 -5
- solax_py_library-0.1.0.10/solax_py_library/upload/errors/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/errors/__pycache__/base.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/errors/__pycache__/upload_error.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/test/__pycache__/test_ftp.cpython-38.pyc +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/test/test_ftp.py +3 -2
- solax_py_library-0.1.0.10/solax_py_library/upload/types/__pycache__/__init__.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/types/__pycache__/client.cpython-38.pyc +0 -0
- solax_py_library-0.1.0.10/solax_py_library/upload/types/__pycache__/ftp.cpython-38.pyc +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/types/client.py +6 -1
- solax_py_library-0.1.0.7/solax_py_library/upload/core/data_adapter/csv.py +0 -19
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/README.md +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/api/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/api/service.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/data_adapter/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/data_adapter/base.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/upload_service/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/errors/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/errors/base.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/errors/upload_error.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/test/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/types/__init__.py +0 -0
- {solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/types/ftp.py +0 -0
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/__pycache__/base.cpython-38.pyc
ADDED
Binary file
|
solax_py_library-0.1.0.10/solax_py_library/upload/core/data_adapter/__pycache__/csv.cpython-38.pyc
ADDED
Binary file
|
@@ -0,0 +1,26 @@
|
|
1
|
+
import csv
|
2
|
+
import tempfile
|
3
|
+
from typing import Any, Union, List, Dict
|
4
|
+
|
5
|
+
from solax_py_library.upload.core.data_adapter.base import BaseDataAdapter
|
6
|
+
|
7
|
+
|
8
|
+
class CSVDataAdapter(BaseDataAdapter):
|
9
|
+
@classmethod
|
10
|
+
def parse_data(cls, data: Union[List[List[Any]], List[Dict[str, Any]]]):
|
11
|
+
with tempfile.NamedTemporaryFile(
|
12
|
+
delete=False, mode="w", newline="", encoding="utf8"
|
13
|
+
) as temp_file:
|
14
|
+
|
15
|
+
if isinstance(data[0], list):
|
16
|
+
writer = csv.writer(temp_file)
|
17
|
+
writer.writerows(data)
|
18
|
+
else:
|
19
|
+
headers = list(data[0].keys())
|
20
|
+
writer = csv.DictWriter(temp_file, fieldnames=headers)
|
21
|
+
writer.writerows(data)
|
22
|
+
|
23
|
+
temp_file_path = temp_file.name
|
24
|
+
temp_file.seek(0)
|
25
|
+
|
26
|
+
return open(temp_file_path, "rb")
|
Binary file
|
Binary file
|
solax_py_library-0.1.0.10/solax_py_library/upload/core/upload_service/__pycache__/ftp.cpython-38.pyc
ADDED
Binary file
|
@@ -14,8 +14,8 @@ class BaseUploadService(metaclass=ABCMeta):
|
|
14
14
|
def connect(self):
|
15
15
|
...
|
16
16
|
|
17
|
-
def upload(self, data):
|
18
|
-
upload_data = self._parse(data)
|
17
|
+
def upload(self, data: UploadData):
|
18
|
+
upload_data = self._parse(data.build_data())
|
19
19
|
return self._upload(upload_data)
|
20
20
|
|
21
21
|
@abstractmethod
|
@@ -54,14 +54,13 @@ class FTPUploadService(BaseUploadService):
|
|
54
54
|
self._is_connect = False
|
55
55
|
print("Connection closed.")
|
56
56
|
|
57
|
-
def _parse(self, upload_data:
|
58
|
-
|
59
|
-
|
60
|
-
parsed_data = CSVDataAdapter.parse_data(data.data)
|
57
|
+
def _parse(self, upload_data: FTPData) -> FTPParsedData:
|
58
|
+
if upload_data.file_type == FTPFileType.CSV:
|
59
|
+
parsed_data = CSVDataAdapter.parse_data(upload_data.data)
|
61
60
|
else:
|
62
61
|
raise NotImplementedError
|
63
62
|
return FTPParsedData(
|
64
|
-
file_name=
|
63
|
+
file_name=upload_data.build_full_path(self.remote_path), data=parsed_data
|
65
64
|
)
|
66
65
|
|
67
66
|
def _upload(self, data: FTPParsedData):
|
Binary file
|
Binary file
|
solax_py_library-0.1.0.10/solax_py_library/upload/errors/__pycache__/upload_error.cpython-38.pyc
ADDED
Binary file
|
Binary file
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/test/test_ftp.py
RENAMED
@@ -9,7 +9,7 @@ class FTPTest(unittest.TestCase):
|
|
9
9
|
def test_ftp_upload(self):
|
10
10
|
ftp_config = {
|
11
11
|
"host": "10.1.31.181", # 测试host
|
12
|
-
"
|
12
|
+
"user": "solax",
|
13
13
|
"password": "sly402",
|
14
14
|
"remote_path": "/xixi",
|
15
15
|
}
|
@@ -17,7 +17,8 @@ class FTPTest(unittest.TestCase):
|
|
17
17
|
upload_type=UploadType.FTP,
|
18
18
|
configuration=ftp_config,
|
19
19
|
upload_data=UploadData(
|
20
|
-
|
20
|
+
upload_type=UploadType.FTP,
|
21
|
+
data=dict(
|
21
22
|
file_type=FTPFileType.CSV,
|
22
23
|
file_name="new_file.csv",
|
23
24
|
data=[["curry", 37, "男"], ["james", 40, "男"], ["lily", 16, "女"]],
|
Binary file
|
Binary file
|
Binary file
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/types/client.py
RENAMED
@@ -10,5 +10,10 @@ class UploadType(str, Enum):
|
|
10
10
|
|
11
11
|
|
12
12
|
class UploadData(BaseModel):
|
13
|
-
data: Optional[Union[FTPData]]
|
13
|
+
data: Optional[Union[dict, FTPData]]
|
14
14
|
upload_type: Optional[UploadType]
|
15
|
+
|
16
|
+
def build_data(self):
|
17
|
+
dict_obj_data = self.data if isinstance(self.data, dict) else self.data.dict()
|
18
|
+
if self.upload_type == UploadType.FTP:
|
19
|
+
return FTPData(**dict_obj_data)
|
@@ -1,19 +0,0 @@
|
|
1
|
-
import csv
|
2
|
-
import tempfile
|
3
|
-
|
4
|
-
from solax_py_library.upload.core.data_adapter.base import BaseDataAdapter
|
5
|
-
|
6
|
-
|
7
|
-
class CSVDataAdapter(BaseDataAdapter):
|
8
|
-
@classmethod
|
9
|
-
def parse_data(cls, data):
|
10
|
-
with tempfile.NamedTemporaryFile(
|
11
|
-
delete=False, mode="w", newline="", encoding="utf8"
|
12
|
-
) as temp_file:
|
13
|
-
writer = csv.writer(temp_file)
|
14
|
-
writer.writerows(data)
|
15
|
-
|
16
|
-
temp_file_path = temp_file.name
|
17
|
-
temp_file.seek(0)
|
18
|
-
|
19
|
-
return open(temp_file_path, "rb")
|
File without changes
|
File without changes
|
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/api/__init__.py
RENAMED
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/api/service.py
RENAMED
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/core/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/errors/__init__.py
RENAMED
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/errors/base.py
RENAMED
File without changes
|
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/test/__init__.py
RENAMED
File without changes
|
{solax_py_library-0.1.0.7 → solax_py_library-0.1.0.10}/solax_py_library/upload/types/__init__.py
RENAMED
File without changes
|
File without changes
|