البرامج النصية / استيراد البيانات القديمة
"Scripts" هي الحل الشامل الذي تقدمه SKOOR لإنشاء البرامج النصية وتحريرها وتشغيلها، مع العديد من الخيارات لتخصيصها.
صفحة Scripts
تنقسم الصفحة إلى ثلاثة أقسام رئيسية:
الإعدادات
يتضمن هذا القسم الإعدادات العامة للنص البرمجي، مثل:
الاسم والوصف.
الوقت المحدد الافتراضي (بالثواني)
نسخ رمز Webhook أو إعادة تعيينه (متاح للمسؤولين فقط)
تكوينات الجدولة: تسمح بجدولات متعددة مع تكوينات تشغيل مخصصة.
تكوينات التشغيل: يسمح بتخصيص مهلة الانتظار ومتغيرات البيئة.
الملفات
يقدم هذا القسم حلاً كاملاً لإدارة الملفات للنص البرمجي، بما في ذلك محرر متطور للبيانات النصية.
سيتم عرض رابط تنزيل إذا كانت البيانات ثنائية (غير قابلة للتحرير في شكل نصي).
التشغيل
هذا القسم مسؤول عن تشغيل ومراقبة عمليات تشغيل البرنامج النصي. ويوفر منطقة سحب وإفلات صغيرة لتحميل الملفات المصدرية إذا لزم الأمر.
إنشاء برنامج نصي
يمكن إنشاء البرامج النصية يدويًا أو تحميلها عبر ملفات Zip كما هو موضح أدناه:
استيراد البرنامج النصي باستخدام ملف Zip
عند استيراد ملف zip الخاص بالنص البرمجي، يتم إجراء تحليل، وعليه تظهر علامات مختلفة قبل إتمام الاستيراد الفعلي.
هذه العلامات هي:
أركان البرنامج النصي
تشغيل البرنامج النصي
يتضمن الملف الرئيسي منطق البرنامج النصي. وهذا يحدد نوع المشغل للبرنامج النصي:
يتوقع برنامج تشغيل Python ملف
main.py.يتوقع برنامج تشغيل Talend وجود ملف
<scriptName>_run.sh.يتوقع Shell Runner ملف
run.sh.
ضع البرنامج النصي الرئيسي في مستوى واحد أسفل الجذر (أو أعلى)، لأن المسح من حيث العرض يستخدم دائمًا البرنامج النصي الأقل عمقًا الذي يعثر عليه.
تظهر الرسالة التالية عند محاولة تشغيل برنامج نصي بدون برنامج نصي رئيسي.
.env
إنه ملف نصي بسيط يتضمن متغيرات البيئة. وبهذه الطريقة يمكن تعديل المتغيرات المستخدمة في البرنامج النصي بناءً على حالة الاستخدام.
يجب أن يكون ملف .env في نفس المجلد الذي يوجد فيه البرنامج النصي للـ runner (main.py، run.sh، ... إلخ)
سيؤدي ملف .env التالي إلى ظهور متغيرات البيئة الموضحة، مما يسمح بتعديلها في تكوينات التشغيل المخصصة.
متغيرات البيئة المُقدمة مسبقًا
يتم تمرير بعض التفاصيل حول تشغيل البرنامج النصي إلى بيئة البرنامج النصي كمتغيرات بيئة، وهي:
UserId كـ
SKOOR_USER_IDاسم المستخدم كـ
SKOOR_USER_USERNAMEUser’s Fullname كـ
SKOOR_USER_FULLNAME
توضح لقطات الشاشة أدناه كيفية استرداد هذه المتغيرات في مثال بلغة Python مع النتيجة في البرنامج النصي:
import os
source_file = os.environ.get('SKOOR_SOURCE_FILE')
user_id = os.environ.get('SKOOR_USER_ID')
username = os.environ.get('SKOOR_USER_USERNAME')
userFullname = os.environ.get('SKOOR_USER_FULLNAME')
userGroup_id = os.environ.get('SKOOR_USER_USERGROUP_IDS')
userGroup_names = os.environ.get('SKOOR_USER_USERGROUP_NAMES')
print("sourceFile: ", source_file)
print("User ID: ", user_id)
print("Username: ", username)
print("Fullname: ", userFullname)
print("UserGroup ID: ", userGroup_id)
print("UserGroup name: ", userGroup_names)
مثال باستخدام .env
يقرأ البرنامج النصي التالي المتغير foo في .env ويطبعها على وحدة التحكم، وفيما يلي لقطات شاشة لـ .env وتكوينات التشغيل ذات الصلة.
ملفات المصدر
يمكن تصميم البرامج النصية لقبول الملفات الخارجية (ملفات المصدر) ومعالجتها كجزء من منطق البرنامج النصي.
يمكن الإشارة إلى الملفات المصدرية في البرنامج النصي باستخدام المتغير البيئي SKOOR_SOURCE_FILE كما هو موضح في مقتطف الشفرة التالي:
# IN PYTHON
import os
source_file = os.environ.get('SKOOR_SOURCE_FILE')
print(source_file)
#IN SHELL echo $SKOOR_SOURCE_FILE
يتم دعم أنواع الملفات التالية:
نص (منظم)
text/plaintext/csvtext/tab-separated-valuestext/tsvtext/markdowntext/vttapplication/jsonapplication/x-ndjsonapplication/jsonlapplication/xmltext/xmlapplication/yamltext/yamlapplication/x-yamlapplication/sqltext/sql
المستندات
application/pdfapplication/mswordapplication/vnd.openxmlformats-officedocument.wordprocessingml.documentapplication/vnd.ms-excelapplication/vnd.openxmlformats-officedocument.spreadsheetml.sheetapplication/vnd.ms-powerpointapplication/vnd.openxmlformats-officedocument.presentationml.presentationapplication/vnd.oasis.opendocument.textapplication/vnd.oasis.opendocument.spreadsheetapplication/vnd.oasis.opendocument.presentationapplication/rtfapplication/epub+zip
الأرشيفات
application/parquetapplication/x-parquetapplication/avroapplication/x-avroapplication/vnd.apache.arrow.fileapplication/vnd.apache.arrow.streamapplication/orcapplication/x-orcapplication/zipapplication/x-zip-compressedapplication/gzipapplication/x-gzipapplication/x-bzip2application/x-xzapplication/zstdapplication/x-zstdapplication/x-tarapplication/x-7z-compressed
تشغيل البرامج النصية الفرعية
إذا كانت البرامج النصية الفرعية مطلوبة، فيجب وضعها داخل مجلد bin. حيث إنها ستكون قابلة للتشغيل.
تأكد من وضع البرامج النصية الفرعية دائمًا في مجلد "bin".
فيما يلي مثال في Shell:
ناتج هذا الملف run.sh هو:
ناتج هذا الملف run.sh هو:
QuickRun
يوفر هذا الخيار زر "تشغيل سريع" (QuickRun) الذي يقوم بتشغيل البرنامج النصي بدون ملف مصدر وبالقيم الافتراضية لمتغيرات البيئة.
وهو يتيح تشغيل البرنامج النصي بسرعة أثناء تطويره أو استكشاف الأخطاء وإصلاحها، ويُظهر زر "عرض" (Latest Job Overview) ناتج وحدة التحكم.
التشغيل
بدء التشغيل
في قسم التشغيل، حدد التكوين المطلوب (وقم بتحميل ملف المصدر إذا لزم الأمر) ثم انقر فوق "تشغيل البرنامج النصي"
إلغاء التشغيل
يمكن إلغاء عمليات التشغيل الجارية وكذلك عمليات التشغيل المعلقة بالنقر فوق رمز إلغاء المهمة في قسم "History" (السجل).
إلغاء الاشتراك في Poetry
Poetry هي أداة قوية تُستخدم لإدارة التبعيات وإدارة البيئة الافتراضية في لغة Python. ويتم ذلك عن طريق تعريف ملف pyproject.toml في نفس المجلد الذي يوجد فيه البرنامج النصي للتشغيل (main.py، run.sh، إلخ).
سيؤدي إزالة/إعادة تسمية ملف pyproject.toml تلقائيًا إلى إلغاء الاشتراك في استخدام Poetry، واستخدام skoor-python بدلاً من ذلك.
نظرة عامة على المهمة
لعرض التفاصيل الكاملة للمهمة، انقر على أحد العناصر في قائمة "History" كما هو موضح أدناه:
سجل التشغيل
يعرض قسم "السجل" قائمة بجميع عمليات تشغيل البرنامج النصي. يمكن العثور على تفاصيل كل عملية تشغيل بالنقر عليها.
يعرض قسم مخصص السجل التفصيلي لأحدث تشغيل للبرنامج النصي (يتخطى عمليات التشغيل المعلقة/الملغاة)
استخدام رموز Webhook لتشغيل المحول
يتيح هذا الخيار تشغيل البرنامج النصي دون الحاجة إلى تسجيل الدخول، وهو الخيار المفضل للمستخدمين التقنيين.
لكل برنامج نصي رمز Webhook فريد، وسيتم نسخ عنوان URL إلى الحافظة بالنقر فوق "Copy Webhook Token" (حفظ رمز Webhook).
مثال على استخدام رموز Webhook
انسخ رمز Webhook من صفحة البرنامج النصي بالنقر فوق "Copy Webhook Token" (طلب Webhook)، وفي هذا المثال يبدو عنوان URL لـ Webhook كما يلي:
http://localhost:8090/scripts/8925cfd4-2063-4b07-9d56-956f2b754b47/run?token=6ae51c9f-d292-4d55-b512-4537121b37f5
استخدم عنوان URL لإرسال طلب POST:
استخدام برنامج واجهة برمجة تطبيقات مثل POSTMAN
تشير استجابة 200 مع كيان المهمة الأولي إلى أن التشغيل قد تم تشغيله كما هو موضح في لقطة الشاشة أدناه:
استخدام cURL في المحطة الطرفية
curl -X POST http://localhost:8090/scripts/8925cfd4-2063-4b07-9d56-956f2b754b47/run?token=6ae51c9f-d292-4d55-b512-4537121b37f5
سيبدو الرد كما يلي
يمكن ملاحظة هذا التشغيل في لوحة معلومات SKOOR، ويظهر التشغيل الذي أنشأه مستخدم الرمز المميز في السجل.
الحذف
انقر على أيقونة سلة المهملات لحذف البرنامج النصي. ستظهر الأيقونة عند تمرير مؤشر الماوس فوق اسم البرنامج النصي.
تصدير البرنامج النصي كملف Zip
انقر على أيقونة الأرشيف لتصدير البرنامج النصي. ستظهر الأيقونة عند تمرير مؤشر الماوس فوق اسم البرنامج النصي.
يتم تصدير ملف script_metadata.json داخل ملف ZIP الذي تم تصديره، والذي يحتوي على الوصف، ووقت الانتظار الافتراضي، وتكوين التشغيل، وتكوين الجدول الزمني للنص البرمجي.
في Safari: قم بتعطيل الإعدادات → عام → "فتح الملفات 'الآمنة' بعد التنزيل" لمنع الاستخراج التلقائي لملفات ZIP.
































