Adding Base class files for source, transform and sink functions of data-extraction... 98/9198/1
authorjosephthaliath <jo.thaliath@samsung.com>
Fri, 7 Oct 2022 09:01:14 +0000 (14:31 +0530)
committerjosephthaliath <jo.thaliath@samsung.com>
Fri, 7 Oct 2022 09:03:38 +0000 (14:33 +0530)
Issue-Id: AIMLFW-3

Signed-off-by: josephthaliath <jo.thaliath@samsung.com>
Change-Id: I67b1dd48439b715ac0a09c2bb769848688de6089

src/sink/Base.py [new file with mode: 0644]
src/source/Base.py [new file with mode: 0644]
src/transform/Base.py [new file with mode: 0644]

diff --git a/src/sink/Base.py b/src/sink/Base.py
new file mode 100644 (file)
index 0000000..bb627e7
--- /dev/null
@@ -0,0 +1,43 @@
+# ==================================================================================
+#
+#       Copyright (c) 2022 Samsung Electronics Co., Ltd. All Rights Reserved.
+#
+#   Licensed under the Apache License, Version 2.0 (the "License");
+#   you may not use this file except in compliance with the License.
+#   You may obtain a copy of the License at
+#
+#          http://www.apache.org/licenses/LICENSE-2.0
+#
+#   Unless required by applicable law or agreed to in writing, software
+#   distributed under the License is distributed on an "AS IS" BASIS,
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+#   See the License for the specific language governing permissions and
+#   limitations under the License.
+#
+# ==================================================================================
+
+"""
+@Module Base
+"""
+from abc import abstractmethod
+class Sink():
+    """
+    @Class Sink Base Class
+    """
+    def __init__(self):
+        """
+        @Method": No Args Constructor
+        """
+        self.ClassType="Custom"
+    @abstractmethod
+    def init(self, sparkhelper, confighelper, inputdict):
+        """
+        @Methond: astract
+        """
+    @abstractmethod
+    def write(self, sparksession, sparkdf):
+        """
+        @Method: write
+        @inputs: sparksession, sparkdf
+        """
+        
diff --git a/src/source/Base.py b/src/source/Base.py
new file mode 100644 (file)
index 0000000..5249c3b
--- /dev/null
@@ -0,0 +1,41 @@
+# ==================================================================================
+#
+#       Copyright (c) 2022 Samsung Electronics Co., Ltd. All Rights Reserved.
+#
+#   Licensed under the Apache License, Version 2.0 (the "License");
+#   you may not use this file except in compliance with the License.
+#   You may obtain a copy of the License at
+#
+#          http://www.apache.org/licenses/LICENSE-2.0
+#
+#   Unless required by applicable law or agreed to in writing, software
+#   distributed under the License is distributed on an "AS IS" BASIS,
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+#   See the License for the specific language governing permissions and
+#   limitations under the License.
+#
+# ==================================================================================
+
+"""
+@Module:BaseClass
+"""
+from abc import abstractmethod
+class Source():
+    """
+    @Class: Base Class
+    """
+    def __init__(self):
+        """
+        @Constructor No Args
+        """
+        self.ClassType="Custom"
+    @abstractmethod
+    def init(self,sparkhelper,confighelper,inputdict):
+        """
+        @Method: Abstract init
+        """
+    @abstractmethod
+    def load(self,sparksession):
+        """
+        @Method:Abstract load
+        """
diff --git a/src/transform/Base.py b/src/transform/Base.py
new file mode 100644 (file)
index 0000000..2243dfc
--- /dev/null
@@ -0,0 +1,44 @@
+# ==================================================================================
+#
+#       Copyright (c) 2022 Samsung Electronics Co., Ltd. All Rights Reserved.
+#
+#   Licensed under the Apache License, Version 2.0 (the "License");
+#   you may not use this file except in compliance with the License.
+#   You may obtain a copy of the License at
+#
+#          http://www.apache.org/licenses/LICENSE-2.0
+#
+#   Unless required by applicable law or agreed to in writing, software
+#   distributed under the License is distributed on an "AS IS" BASIS,
+#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+#   See the License for the specific language governing permissions and
+#   limitations under the License.
+#
+# ==================================================================================
+
+"""
+@Module : Base
+"""
+from abc import abstractmethod
+
+class Transform():
+    """
+    @Class: Transform class
+    """
+    def __init__(self):
+        """
+        @Method: No Args Constructor
+        """
+        self.ClassType="Custom"
+    @abstractmethod
+    def init(self, sparkhelper, confighelper, inputdict):
+        """
+        @Methond: init
+        """
+    @abstractmethod
+    def transform(self,sparksession, sparkdf):
+        """
+        @Methond: transform
+        @Inpuuts: spark
+        """
+