قم بتثبيت TaskServer (taskd) على CentOS 7

TaskWarrior هو أداة إدارة وقت مفتوحة المصدر تُعد تحسينًا على تطبيق Todo.txt ونسخه. نظرًا لحقيقة أن الشخص العادي يستخدم العديد من الأجهزة / الأنظمة الأساسية في جدوله اليومي ، فمن الضروري أن يكون لديك القدرة على الحصول على مستودع مركزي حيث يمكن الوصول إلى البيانات وتحديثها من أي جهاز. سيركز هذا البرنامج التعليمي على إعداد كل من الخادم ، يسمى TaskServer (taskd) ، والعميل ، يسمى TaskWarrior (مهمة) ، مما يسمح لأجهزة عميل متعددة بالوصول إلى البيانات وتبادلها بشكل آمن.

لديه الميزات التالية:

  • مهام غير محدودة
  • تحديد أولويات المهمة
  • تصفية البحث
  • وضع العلامات
  • المزامنة التلقائية
  • النسخ الاحتياطي التلقائي
  • السيطرة الكاملة والخصوصية
  • اتصال مشفر

المتطلبات الأساسية

  • مثيل خادم CentOS 7 x64.
  • A سودو المستخدم.
  • يشير اسم المجال إلى مثيل Vultr (taskd.example.com)

الخطوة 1: تحديث النظام

قم بتسجيل الدخول كمستخدم sudo لتثبيت مستودع EPEL وتحديث النظام على النحو التالي:

sudo yum install epel-release -y
sudo yum clean all && sudo yum update -y

الخطوة 2: تثبيت RPM Build وأدوات البناء

لا يحتوي مستودع EPEL على RPM لـ TaskServer (taskd) ، لذلك يجب علينا بنائه من المصدر إلى حزمة RPM بأنفسنا.

  1. تثبيت أدوات GCC ، Make ، RPM Build ، التطوير والتوقيع.

    sudo yum install gcc gcc-c++ make rpmdevtools rpm-sign rpm-build -y
    
  2. قم بإنشاء دليل GnuPG الذي سيحتوي على ملفات GPG اللازمة لتوقيع RPM.

    mkdir .gnupg
    
  3. عند إنشاء مفتاح ، نطلب إنتروبيا في النظام لتوزيعه بشكل عشوائي. و rngdيولد الخفي في الكون اللازم من /dev/urandom. لذا دعنا نثبت ذلك الآن.

    yum install rngd -y
    
  4. ابدأ البرنامج rngdالخفي لتوليد الإنتروبيا. و -r نقاط خيار /dev/urandomبدلا من الافتراضي /dev/hwrng.

    sudo rngd -r /dev/urandom
    
  5. توليد مفتاح. و ---gen مفتاح الخيار يروي المنافع العامة العالمية لإنشاء زوج مفتاح جديد.

    gpg --gen-key
    
  6. بالنسبة للخيار " يرجى تحديد نوع المفتاح الذي تريده " ، حدد " (1) RSA و RSA (افتراضي) " لنوع المفتاح عن طريق إدخال 1 والضغط على مفتاح العودة / الإدخال .

  7. بالنسبة للخيار " ما هو حجم المفاتيح الذي تريده؟ (2048) " ، اختر الافتراضي بالضغط على مفتاح الإرجاع / الإدخال .

  8. بالنسبة للخيار " يرجى تحديد المدة التي يجب أن يكون فيها المفتاح صالحًا " ، اختر الافتراضي بالضغط على مفتاح الإرجاع / الإدخال .

  9. بالنسبة للخيار " هل هذا صحيح؟ (ص / N) " ، أدخل y واضغط على مفتاح العودة / الإدخال .

  10. ضمن " Real name: " ، أدخل اسمًا من اختيارك واضغط على مفتاح Return / Enter .

  11. ضمن " عنوان البريد الإلكتروني: " ، أدخل عنوان بريد إلكتروني من اختيارك واضغط على مفتاح الإرجاع / الإدخال .

  12. و تعليق: قسم يمكن ترك فارغا إذا اخترت ذلك.

  13. قم بإجراء أية تغييرات ضرورية إذا لم تقم بإدخال معلوماتك بشكل صحيح. إذا كنت راضيًا عن معلومات معرّف المستخدم المعروضة ، فأدخل O (الحرف الكبير O ، وليس صفر) واضغط على مفتاح الإرجاع / الإدخال .

  14. سيطالبك GnuPG الآن بإنشاء كلمة مرور والتحقق منها لزوج المفاتيح.

  15. بعد إدخال كلمات المرور الخاصة بك ، سيتم إنشاء زوج مفاتيح GnuPG الخاص بك تحت .gnupgالدليل في دليل المستخدم الخاص بك.

  16. قم بتشغيل هذا الأمر لعرض محتويات .gnupgالدليل. يجب أن يحتوي على الدليل private-keys-v1.dوالملفات التالية pubring.gpg، pubring.gpg~، random_seed، secring.gpg، S.gpg-agent، trustdb.gpg.

    ls -la .gnupg
    
  17. تصدير زوج المفاتيح الذي تم إنشاؤه. و --export الخيار يرشد GnuPG لتصدير زوج المفاتيح. و -a يرشد الخيار GnuPG لإخراج زوج المفاتيح في شكل أسكي دروع . استبدل " Joe Q. Public " بالاسم الذي أدخلته عند إنشاء زوج المفاتيح في الخطوة رقم 10 أعلاه. استبدل " jqpublic " بأي نص تختاره.

    gpg --export -a 'Joe Q. Public' > RPM-GPG-KEY-jqpublic
    
  18. استيراد زوج المفاتيح إلى مخزن مفاتيح RPM. استبدل " jqpublic " بالنص الذي اخترته في الخطوة رقم 17.

    sudo rpm --import RPM-GPG-KEY-jqpublic
    
  19. تحقق من إضافة زوج المفاتيح إلى مخزن مفاتيح RPM. و --q المنافع العامة العالمية-pubkey يستعلم خيار RPM GnuPG تخزين المفاتيح. يعرض ٪ {name} -٪ {version} -٪ {release} ->٪ {Summary} \ n النتيجة بتنسيق يمكن قراءته بشريًا.

    rpm -q gpg-pubkey --qf '%{name}-%{version}-%{release} --> %{summary}\n'
    
  20. من خلال إنشاء .rpmmacros file، يمكن تخصيص RPM لأداء السلوكيات المعينة (مثال: تسهيل التوقيع التلقائي على RPMs). استخدم nanoالبرنامج لإنشاء الملف.

    nano .rpmmacros
    
  21. ثم أضف النص التالي أدناه إلى .rpmmacrosالملف.

    %_gpg_name  Joe Q. Public
    %_query_all_fmt %%{name}-%%{version}-%%{release}.%%{arch}
    %_signature gpg
    %_topdir %(echo $HOME)/rpmbuild
    
  22. احفظ المستند بإدخال تركيبات لوحة المفاتيح التالية. على CTRL + X مفاتيح. ثم ، مفتاح S. وأخيرًا ، مفتاح الإرجاع / الإدخال .

  23. سيقوم هذا الأمر أدناه بإعداد بيئة بناء RPM الخاصة بك. سيؤدي ذلك إلى إلحاق وحدات ماكرو إضافية .rpmmacrosبالملف الذي قمت بإنشائه في الخطوة رقم 20 وإنشاء الدلائل المطلوبة لإنشاء وتخزين العائد لكل ألف ظهور.

    rpmdev-setuptree
    
  24. قم بتشغيل هذا الأمر لعرض محتويات دليل rpmbuild. وينبغي أن تتضمن الدلائل التالية مصادر ، RPMS ، BUILD ، SRPMS و المواصفات .

    find rpmbuild
    
  25. قم بتنزيل التعليمات البرمجية المصدر TaskServer (taskd) إلى rpmbuild/SOURCESالدليل.

    wget https://taskwarrior.org/download/taskd-1.1.0.tar.gz -P rpmbuild/SOURCES/
    
  26. اقتل rgndعملية التشغيل .

    sudo kill -9 rngd
    

الخطوة 3: بناء RPM TaskServer (taskd) من المصدر

  1. من أجل بناء RPM جديد من المصدر ، يجب إنشاء ملف SPEC TaskServer (taskd).

    nano rpmbuild/SPECS/taskd.spec
    
  2. أضف النص التالي أدناه إلى taskd.specالملف.

    Name:           taskd
    Version:        1.1.0
    Release:        1%{?dist}
    Summary:        Secure server providing multi-user, multi-client access to task data
    Group:          Applications/Productivity
    License:        MIT
    URL:            http://tasktools.org/projects/taskd.html
    Source0:        http://taskwarrior.org/download/%{name}-%{version}.tar.gz
    Source1:        taskd.service
    Source2:        taskd-config
    Source3:        taskd.xml
    
    BuildRequires:  cmake
    BuildRequires:  libuuid-devel
    BuildRequires:  gnutls-devel
    BuildRequires:  shadow-utils
    
    
    %if 0%{?rhel} && 0%{?rhel} <= 6
    # On rhel, we don't need systemd to build.  but we do on centos.        
    # ...just to define some macros
    %else
    BuildRequires:  systemd
    %endif
    
    # For certificate generation        
    Requires:       gnutls-utils
    
    # Systemd requires
    Requires(post):    systemd
    Requires(preun):   systemd
    Requires(postun):  systemd
    
    %description
    The TaskServer is a lightweight, secure server providing multi-user,
    multi-client access to task data.  This allows true syncing between desktop and
    mobile clients.
    
    Users want task list access from multiple devices running software of differing
    sophistication levels to synchronize data seamlessly.  Synchronization requires
    the ability to exchange transactions between devices that may not have
    continuous connectivity, and may not have feature parity.
    
    The TaskServer provides this and builds a framework to go several steps beyond
    merely synchronizing data.
    
    %prep
    %setup -q %{name}-%{version}
    
    %build
    %cmake
    make %{?_smp_mflags}
    
    %install
    make install DESTDIR=%{buildroot}
    
    mkdir -p %{buildroot}%{_sharedstatedir}/taskd/
    
    # Users will keep their keys here, but we copy some helpful scripts too.
    mkdir -p %{buildroot}%{_sysconfdir}/pki/taskd/
    cp -a pki/generate* %{buildroot}%{_sysconfdir}/pki/taskd/.
    
    mkdir -p %{buildroot}%{_localstatedir}/log/taskd/
    
    %if 0%{?rhel} && 0%{?rhel} <= 6
    # EL6 and earlier needs a sysvinit script
    # Also, no firewalld on old EL
    %else
    mkdir -p %{buildroot}%{_unitdir}/
    cp -a %{SOURCE1} %{buildroot}%{_unitdir}/taskd.service
    
    mkdir -p %{buildroot}%{_prefix}/lib/firewalld/services
    cp -a %{SOURCE3} %{buildroot}%{_prefix}/lib/firewalld/services/taskd.xml
    %endif
    
    mkdir -p %{buildroot}%{_sharedstatedir}/taskd/orgs/
    cp -a %{SOURCE2} %{buildroot}%{_sharedstatedir}/taskd/config
    
    rm -r %{buildroot}%{_datadir}/doc/taskd/
    
    %pre
    getent group taskd >/dev/null || groupadd -r taskd
    getent passwd taskd >/dev/null || \
        useradd -r -g taskd -d %{_sharedstatedir}/taskd/ -s /usr/bin/sh \
        -c "Task Server system user" taskd
    exit 0
    
    # Systemd scriptlets
    %if 0%{?rhel} && 0%{?rhel} <= 6
    # No systemd for el6
    %else
    
    %post
    %systemd_post taskd.service
    
    %preun
    %systemd_preun taskd.service
    
    %postun
    %systemd_postun_with_restart taskd.service
    
    %endif
    
    
    %files
    %doc AUTHORS COPYING ChangeLog NEWS README
    %{_bindir}/taskd
    %{_bindir}/taskdctl
    %{_mandir}/man1/taskd.1.*
    %{_mandir}/man1/taskdctl.1.*
    %{_mandir}/man5/taskdrc.5.*
    
    %{_sysconfdir}/pki/taskd/generate*
    
    %dir %attr(0750, taskd, taskd) %{_sysconfdir}/pki/taskd/
    %dir %attr(0750, taskd, taskd) %{_localstatedir}/log/taskd/
    
    %dir %attr(0750, taskd, taskd) %{_sharedstatedir}/taskd/
    %config(noreplace) %attr(0644, taskd, taskd) %{_sharedstatedir}/taskd/config
    %dir %attr(0750, taskd, taskd) %{_sharedstatedir}/taskd/orgs/
    
    %if 0%{?rhel} && 0%{?rhel} <= 6
    # No sysvinit files for el6
    %else
    %{_unitdir}/taskd.service
    %{_prefix}/lib/firewalld/services/taskd.xml
    %endif
    
    %changelog
    * Thu Aug 17 2017 Jarrett Graham <[email protected]> - 1.1.0
    - Initial packaging.
    
  3. تتطلب RPM أيضًا ثلاثة ملفات إضافية يجب إنشاؤها في rpmbuild/SOURCESالدليل. استخدم nanoالبرنامج لإنشاء taskd-configالملف.

    nano rpmbuild/SOURCES/taskd-config
    
  4. أضف النص التالي أدناه إلى taskd-configالملف.

    # taskd configuration file
    confirmation=1
    verbose=1
    ip.log=on
    extensions=/usr/libexec/taskd
    queue.size=10
    request.limit=1048576
    server=0.0.0.0:53589
    root=/var/lib/taskd
    log=/var/log/taskd/taskd.log
    pid.file=/var/run/taskd.pid
    ca.cert=/etc/pki/taskd/ca.cert.pem
    server.cert=/etc/pki/taskd/server.cert.pem
    server.key=/etc/pki/taskd/server.key.pem
    server.crl=/etc/pki/taskd/server.crl.pem
    
  5. استخدم nanoالبرنامج لإنشاء taskd.serviceالملف.

    nano rpmbuild/SOURCES/taskd.service
    
  6. أضف النص التالي أدناه إلى taskd.serviceالملف.

    [Unit]
    Description=Secure server providing multi-user, multi-client access to task data
    After=network.target
    Documentation=https://tasktools.org/projects/taskd.html
    
    [Service]
    ExecStart=/usr/bin/taskd server --data /var/lib/taskd
    Type=simple
    User=taskd
    Group=taskd
    
    [Install]
    WantedBy=multi-user.target
    
  7. استخدم nanoالبرنامج لإنشاء taskd.xmlالملف.

    nano rpmbuild/SOURCES/taskd.xml
    
  8. أضف النص التالي أدناه إلى taskd.xmlالملف.

    <?xml version="1.0" encoding="utf-8"?>
    <service>
      <short>Task-warrior server</short>
      <description>This option allows you to connect to the task warrior server.</description>
      <port protocol="tcp" port="53589"/>
    </service>
    
  9. من أجل بناء RPM TaskServer (taskd) ، هناك حاجة إلى ثلاث حزم للبناء. قم بتشغيل الأمر أدناه لتثبيت هذه الحزم.

    sudo yum install cmake libuuid-devel gnutls-devel gnutls-utils -y
    
  10. حان الوقت الآن للبناء من المصدر وإنشاء RPM لـ TaskServer (taskd). قم بتشغيل الأوامر أدناه للبدء. يجب أن يستغرق الأمر أقل من دقيقة على مثيل Vultr CPU 1x لإنشاء RPMs. أدخل كلمة مرور GnuPG التي أنشأتها في الخطوة رقم 14 لتوقيع RPM عند مطالبتك بذلك.

    cd rpmbuild/SPECS/
    rpm -ba -sign taskd.spec
    
  11. تثبيت RPM TaskServer (taskd).

    cd
    sudo rpm -ivh rpmbuild/RPMS/x86_64/taskd-1.1.0-1.el7.centos.x86_64.rpm
    

الخطوة 4: تكوين TaskServer (مهمة)

  1. لكي يتمكن TaskServer (taskd) من الاتصال والمزامنة مع عملاء TaskWarrior (task) ، ستحتاج إلى استخدام البرامج النصية للإنشاء الموجودة أسفل /etc/pki/taskd/لإنشاء شهادات / مفاتيح الخادم والعميل. ارتق إلى المستخدم الجذر باستخدام الأمر أدناه وقم بتغيير الدليل إلى /etc/pki/taskd.

    sudo su -
    cd /etc/pki/taskd/
    
  2. استخدم nanoالبرنامج لإنشاء varsملف من أجل إنشاء مرجع جذري موقّع ذاتيًا.

    nano vars
    

    أضف النص التالي أدناه إلى ملف vars. قم بتغيير المنظمة ، CN ، COUNTRY ، STATE و LOCALITY بشكل يرضيك.

    BITS=4096
    EXPIRATION_DAYS=365
    ORGANIZATION="Vultr.com Inc."
    CN=taskd.example.com
    COUNTRY=US
    STATE="New York"
    LOCALITY="New York"
    
  3. قم بإنشاء المرجع المصدق الجذر والشهادة ومفتاح الخادم وقائمة إبطال الخادم الموقعة ذاتيًا (اختياري).

    ./generate.ca
    ./generate.server
    ./generate.crl
    

    ستقوم هذه الأوامر بإنشاء الملفات التالية ( ca.cert.pem، ca.key.pemو server.cert.pem، server.key.pemو server.crl.pem) داخل /etc/pki/taskd/الدليل. لكي يبدأ TaskServer (taskd) ، يجب تعديل الملكية والأذونات الخاصة بالشهادات والمفاتيح التي تم إنشاؤها في الخطوة # 37 للسماح لـ TaskServer (taskd) بالوصول إليها. قم بتشغيل الأوامر أدناه لتغييرها.

    chown taskd.taskd ca.cert.pem ca.key.pem server.cert.pem server.crl.pem server.key.pem
    chmod 400 ca.cert.pem ca.key.pem server.cert.pem server.crl.pem server.key.pem
    
  4. تمكين وبدء البرنامج الخفي TaskServer (taskd).

    systemctl enable taskd
    systemctl start taskd
    
  5. افتح المنفذ في جدار الحماية يعمل TaskServer (taskd).

    firewall-cmd --permanent --zone=public --add-port=53589/tcp
    firewall-cmd --reload
    

    يتم الآن تثبيت TaskServer (taskd) وإعداده على مثيل CentOS 7.

الخطوة 5: تكوين شهادة ومفتاح عميل TaskWarrior

  1. يجب عليك إنشاء شهادات العميل ومفتاح لتشفير الاتصالات بين TaskServer (taskd) و TaskWarrior (task). قم بتشغيل الأمر أدناه لإنشاء شهادة عميل ومفتاح. استبدل NAMEباسم يمكنك التعرف عليه بسهولة لعميلك.

    generate.client NAME
    

    سيقوم هذا الأمر بإنشاء الملفات التالية ( NAME.cert.pem، NAME.key.pem) داخل /etc/pki/taskd/الدليل.

  2. انسخ الملفات التالية إلى دليل المستخدم الخاص بك ، وقم بتغيير الملكية والأذونات. استبدل joeqpublic أدناه بدليل اسم المستخدم الفعلي.

    cp ca.cert.pem NAME.cert.pem NAME.key.pem /home/joeqpublic/
    chown joeqpublic.joeqpublic /home/joeqpublic/*.pem
    chmod 400 /home/joeqpublic/*.pem
    
  3. إنشاء أرشيف مضغوط من الشهادات والمفتاح.

    zip certficates.zip ca.cert.pem NAME.cert.pem NAME.key.pem
    
  4. استخدم scp(سطر الأوامر) أو WinSCP (واجهة المستخدم الرسومية لـ SCP) لتنزيل certificates.zipالملف من مثيل CentOS إلى جهاز العميل (كمبيوتر / كمبيوتر محمول / هاتف ذكي).

  5. إسقاط امتيازات الجذر وقم بتنفيذ بقية الأوامر كمستخدم عادي.

    exit
    

    تم الآن إعداد TaskServer (taskd) وهو جاهز لعملاء TaskWarrior (task) للاتصال.

الخطوة 6: إنشاء أول مجموعة ومستخدم TaskWarrior

  1. لإنشاء مهامك وحذفها وتعديلها ومزامنتها ، ستحتاج إلى حساب مستخدم. ومع ذلك ، قبل أن تتمكن من إضافة مستخدمين ، ستحتاج أولاً إلى إنشاء مجموعة تنظيمية. قم بتشغيل الأمر أدناه لإنشاء مجموعتك الأولى. استبدل GROUP باسم يسهل التعرف عليه.

  2. مهم! يجب تشغيل taskdالأمر لإنشاء مجموعات / مستخدمين taskdكمستخدم. يعمل كمستخدم /var/lib/taskd/orgsأساسي لإنشاء الدلائل والملفات المملوكة للمستخدم الجذر والتي ستمنع بموجبه عملاء TaskWarrior (المهمة) من الوصول إلى أي شيء في المجموعة التي تم تعيينهم إليها أو تعديلها. سيتم رفض الوصول.

    sudo -u taskd taskd add org GROUP --data /var/lib/taskd
    
  3. الآن ، بعد أن أنشأت مجموعتك الأولى ، فلنقم بإنشاء مستخدمك الأول. قم بتشغيل الأمر أدناه لإنشاء مستخدم تم تعيينه للمجموعة التي تم إنشاؤها في الخطوة رقم 1. انسخ والصق مفتاح المستخدم الذي تم إنشاؤه والمستخدم والمجموعة في ملف نصي. كرر العملية لإضافة مستخدمين إضافيين.

    sudo -u taskd taskd add user GROUP 'Joe. Q. Public' --data /var/lib/taskd
    

الخطوة 7: تثبيت عملاء TaskWarrior

Windows 10 (الإصدار الأحدث من 1607+)

لاستخدام TaskWarrior (task) على Windows 10 ، تحتاج إلى تثبيت Windows Subsystem For Linux من متجر Windows.

  1. لتثبيت WSL ، مطلوب موجه Powershell مرتفعة. اضغط على مفتاح النافذة واكتب powershell . انقر بزر الماوس الأيمن على Windows Powershell في أعلى النتائج وحدد " تشغيل كمسؤول ". في موجه التحكم بحساب المستخدم ، انقر فوق " نعم" . انسخ والصق النص الموجود أدناه في نوافذ Powershell. عند انتهاء تثبيت WSL ، اضغط على مفتاح Y لإعادة تشغيل Windows.

    Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux
    
  2. بعد إعادة التشغيل ، افتح موجه الأوامر واكتب باش الأوامر التالي . سيؤدي هذا إلى تثبيت Ubuntu على Windows. اضغط على مفتاح Y . سيتم تنزيله واستخراجه الآن. اختر اسم مستخدم وكلمة مرور.

    bash
    
  3. حان الوقت الآن لتثبيت TaskWarrior (مهمة). اكتب الأمر التالي داخل وحدة التحكم.

    sudo apt-get install task -y
    
  4. اكتب exit مرتين للخروج من bash Terminal وموجه أوامر Windows.

  5. انقر فوق الزر "قائمة ابدأ". اكتب أوبونتو . انقر بزر الماوس الأيمن على Bash على Ubuntu على Windows . حدد تثبيت على شريط المهام . وهذا يوفر الراحة للوصول بسرعة إلى bash للوصول إلى TaskWarrior (مهمة).

  6. انقر على أيقونة Ubuntu التي أنشأتها للتو على شريط المهام. سيؤدي هذا إلى فتح نافذة طرفية تعمل باش. اكتب الأمر التالي أدناه لإنشاء دليل بيانات TaskWarrior (مهمة) ( ~/.task/) وملف التكوين ( .taskrc).

    task version
    yes
    
  7. تحتاج إلى نقل certificates.zipالملف الذي قمت بحفظه في وقت سابق أثناء إعداد TaskServer إلى ~/.taskd/الدليل داخل دليل المستخدم الخاص بك. لاستخراج الملفات من ملف مضغوط ، قم بتثبيت unzipالبرنامج أولاً. انسخ والصق الأوامر التالية أدناه لتحل محل الموقع الفعلي لنسختك من certificates.zip.

    sudo apt-get install unzip -y
    cp /mnt/c/User/WINDOWSUSER/Desktop/certificates.zip .
    cd .task
    unzip ../certificates.zip
    cd
    
  8. اكتب الأوامر التالية لتعيين TaskWarrior (task) للتواصل مع TaskServer (taskd). استبدل NAME بما سميت شهادتك ومفتاحك ، GROUP بالمجموعة التي أنشأتها ، Joe Q. Public باسم المستخدم الذي قمت بإنشائه و XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXX بالمفتاح المعين عند قيام المستخدم تم إنشاؤه على خادم TaskWarrior (taskd).

    task config taskd.ca -- ~/.task/ca.cert.pem
    task config taskd.certificate -- ~/.task/**NAME**.cert.pem
    task config taskd.key -- ~/.task/**NAME**.key.pem
    task config taskd.server -- taskd.example.com:53589
    task config taskd.credentials -- GROUP/Joe Q. Public/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXX
    
  9. حان الوقت الآن لمزامنة TaskWarrior (task) مع TaskServer (taskd). قم بتشغيل الأمر أدناه لتهيئة قاعدة البيانات.

    task sync init
    

    المزامنة بين عميل TaskWarrior (task) و TaskServer (taskd) تم إعدادها الآن على نظام Windows 10 الأساسي.

ذكري المظهر

لاستخدام TaskWarrior (task) على Android ، تحتاج إلى تثبيت TaskWarrior For Android من متجر Google Play.

  1. قم بتثبيت TaskWarrior (task) لتطبيق Android على متجر Google Play.

  2. افتح TaskWarrior (task) لتطبيق Android.

  3. سيُطلب منك التطبيق إنشاء حساب باسم الحساب المرغوب . أدخل الاسم الذي اخترته عند إنشاء اسم مستخدم لمستخدم TaskServer (taskd).

  4. اترك مجلد البيانات للإعداد الافتراضي << إنشاء جديد >> واضغط على زر موافق . استخدم تطبيق مدير الملفات لإنشاء مجلد في جذر التخزين (على سبيل المثال:) /storage/emulate/0/Certs. أرسل التطبيق إلى الخلفية.

  5. انسخ certificates.zipالملف الذي أنشأته سابقًا واستخرج محتوياته في الدليل الذي أنشأته في الخطوة رقم 4.

  6. قم بتقديم تطبيق "TaskWarrior (task) For Android" واضغط على القائمة الموجودة في الزاوية اليسرى العليا من التطبيق لفتحه.

  7. مرر لأسفل إلى أسفل القائمة وانقر على خيار الإعدادات .

  8. سيؤدي ذلك إلى فتح محرر نصوص بسيط مدمج TaskWarrior For Android.

  9. أدخل الخيارات التالية لإعداد المزامنة مع TaskServer (taskd). استبدل متغيرات taskd.ca/ taskd.certificate/ taskd.key` بمسارات / مسارات دليل ca / ​​Certificate / key الفعلية ، NAME بما سمته الشهادة والمفتاح ، GROUP بالمجموعة التي أنشأتها ، Joe Q. Public باسم المستخدم الذي أنشأته و XXXXXXXX-XXXX-XXXX-XXXX-XXXX XXXXX مع المفتاح المعين عند إنشاء المستخدم على خادم TaskWarrior (taskd).

    taskd.ca=/storage/emulate/0/Certs/ca.cert.pem
    taskd.certificate=/storage/emulate/0/Certs/NAME.cert.pem
    taskd.credentials=GROUP/Joe Q. Public/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
    taskd.key=/storage/emulate/0/Certs/NAME.key.pem
    taskd.server=taskd.example.com:53589
    
  10. اضغط على أيقونة القرص المرن لحفظ إعداداتك.

المزامنة بين عميل TaskWarrior (task) الخاص بك و TaskServer (taskd) تم إعدادها الآن على نظام Android الأساسي.

لينكس

  1. ارجع إلى قسم توزيع TaskWarrior (مهمة) للتثبيت لتوزيع Linux الخاص بك .

  2. افتح نافذة طرفية. اكتب الأمر التالي أدناه لإنشاء دليل بيانات TaskWarrior (مهمة) ( ~/.task/) وملف التكوين ( .taskrc).

    task version
    yes
    
  3. تحتاج إلى نقل certificates.zipالملف الذي قمت بحفظه مسبقًا في إعداد TaskServer إلى ~/.taskd/الدليل داخل دليل المستخدم الخاص بك. لاستخراج الملفات من ملف مضغوط ، قم بتثبيت unzipالبرنامج أولاً لتوزيعك الخاص. انسخ والصق الأوامر التالية أدناه ، مع استبدال الموقع الفعلي لنسختك من certificates.zip.

    cp /location/of/certificates.zip .
    cd .task
    unzip ../certificates.zip
    cd
    
  4. اكتب الأوامر التالية لتعيين TaskWarrior (task) للتواصل مع TaskServer (taskd). استبدل NAME بما سميت شهادتك ومفتاحك ، GROUP بالمجموعة التي أنشأتها ، Joe Q. Public باسم المستخدم الذي قمت بإنشائه و XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXX بالمفتاح الذي تم تعيينه عند قيام المستخدم تم إنشاؤه على خادم TaskWarrior (taskd).

    task config taskd.ca -- ~/.task/ca.cert.pem
    task config taskd.certificate -- ~/.task/**NAME**.cert.pem
    task config taskd.key -- ~/.task/**NAME**.key.pem
    task config taskd.server -- taskd.example.com:53589
    task config taskd.credentials -- GROUP/Joe Q. Public/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXX
    
  5. حان الوقت الآن لمزامنة TaskWarrior (task) مع TaskServer (taskd). قم بتشغيل الأمر أدناه لتهيئة قاعدة البيانات.

    task sync init
    

إضافة: إذا قمت بتشغيل Gnome Shell ، فهناك امتداد يسمى TaskWhisper يتكامل مع TaskWarrior (مهمة).

المزامنة بين عميل TaskWarrior (task) و TaskServer (taskd) تم إعدادها الآن على توزيعة Linux المفضلة لديك.



Leave a Comment

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت CMS أكتوبر على CentOS 7

كيفية تثبيت CMS أكتوبر على CentOS 7

أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة

كيفية تثبيت المجدول المحجوز على CentOS 7

كيفية تثبيت المجدول المحجوز على CentOS 7

استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th

تثبيت Netdata على CentOS 7

تثبيت Netdata على CentOS 7

استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:

كيفية تثبيت DreamFactory Open Source على CentOS 7

كيفية تثبيت DreamFactory Open Source على CentOS 7

DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي

كيفية تثبيت خادم Starbound على CentOS 7

كيفية تثبيت خادم Starbound على CentOS 7

استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Django على CentOS 7

كيفية تثبيت Django على CentOS 7

Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها

تثبيت Revive Adserver على CentOS 7

تثبيت Revive Adserver على CentOS 7

Revive Adserver هو نظام عرض إعلانات مجاني ومفتوح المصدر يمكن استخدامه لإدارة الإعلانات على مواقع الويب و / أو التطبيقات و / أو مشغلات الفيديو. في هذه المقالة ،

قم بتثبيت Elgg على CentOS 7

قم بتثبيت Elgg على CentOS 7

استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po

نشر Kubernetes مع Kubeadm على CentOS 7

نشر Kubernetes مع Kubeadm على CentOS 7

نظرة عامة تهدف هذه المقالة إلى مساعدتك في إنشاء مجموعة Kubernetes وتشغيلها باستخدام kubeadm في لمح البصر. سيقوم هذا الدليل بنشر خادمين في

قم بإعداد Sails.js للتطوير على CentOS 7

قم بإعداد Sails.js للتطوير على CentOS 7

استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver

كيفية تجميع Nginx من المصدر على CentOS 7

كيفية تجميع Nginx من المصدر على CentOS 7

استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت

كيفية تثبيت dotCMS على CentOS 7

كيفية تثبيت dotCMS على CentOS 7

استخدام نظام مختلف؟ dotCMS هو نظام إدارة محتوى من فئة مفتوحة المصدر مفتوح بلغة جافا. أنه يحتوي تقريبا على كل ميزة مطلوبة ر

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد