CNMCyber Usable
CNM Cloud Usable (in the Russian-language version, known as Работы над Облаком) is the fourth, current, phase of the CNM Cloud Project. CNM Cloud (hereinafter - the Cloud) is a set of technologies that supports CNM Cyber. This very wikipage presents the primary list of those endeavors that are included in that phase. CNM Cyber Project Coordinators (hereinafter, the Coordinators) are invited to organize work on its endeavors.
Trivia
Projects vs operations
- The endeavors include:
- Projects undertaken to develop new systems to be deployed at the Cloud.
- Operations undertaken to sustain productive functions of deployed systems of the Cloud.
Cloud layers
- CNM Farms. The Cloud infrastructure or, in other words, ecosystem of computing servers and cloud OS to support both Opplet and CNM apps.
- Opplet. The enterprise-wide utility software that supports CNM apps regardless of their location of those applications in the Cloud.
- CNM apps. End-user applications of the Cloud.
Farms
CNM Farms (hereinafter, the Farms) present the infrastructure for the functioning of both the CNM apps and Opplet that serves those apps. The Farms are assembled using commercial off-the-shelf (COTS) software only.
Farms' administration
- For the purposes of this wikipage, the Farms' administration refers to those endeavors that are utilized or can be used on several rather than one individual Farm.
Authorized endeavors related to the Farms' administration Progress Integration (work) Configuration (work) Statistics (work) Revisions (farms) Business requirements Done Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed Integration (product) (product) (product) (product) Software under consideration Jenkins, Kafka, OpenVPN Terraform, Ansible ZooKeeper N/A
Farms' monitoring
- For the purposes of this wikipage, the Farms' monitoring refers to those systems that monitor one or more Farms.
Authorized endeavors related to the Farms' monitoring Progress Grafana (work) Zabbix (work) Nagios (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) Software under consideration Grafana Zabbix Nagios
Database management
- For the purposes of this wikipage, database management refers to those endeavors that are related to databases of the Cloud.
Authorized endeavors related to database management Работы MariaDB (work) PostgreSQL (work) Opplet (DBs) Ceph (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) Software under consideration MariaDB PostgeSQL Cassandra, MuleESB, Hadoop Ceph
DNS management
- For the purposes of this wikipage, DNS management refers to those endeavors that are utilized or can be used to manage DNS of the Cloud.
Authorized endeavors related to DNS management Progress CDN DNSSEC Geocast IPv6 Revisions (DNS) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) (product) Software under consideration N/A N/A N/A N/A N/A
Support tools
- For the purposes of this wikipage, support tools refer to those software development and sysadmin administrative tools that are (a) listed at https://github.com/kahun/awesome-sysadmin and (b) not mentioned in other sections of the endeavors.
Authorized endeavors related to support tools Progress Panels Workspaces Nextcloud (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) Software under consideration VestaCP, Cachet Eclipse Nextcloud
Node clusters
- For the purposes of this wikipage, node clusters refers to clusters of nodes that are utilized or can be used to build the Farms. The four Farms are made up of clustered nodes. Each cluster must have at least one (a) DNS entry point, which for highly available Farms includes a load balancer on a public web address, (b) synchronization of resources of common individual nodes, at least databases, (c) monitoring, ( d) security, including firewalls; and (e) backup and recovery systems.
Authorized endeavors related to node clusters Progress Bureau (farm) Campus (farm) Lab (farm) Opplet (farm) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) Software under consideration ProxmoxVE HAProxy OpenStack CloudStack
Opplet
Opplet represents (a) enterprise-wide middleware that serves the Cloud and (b) a group of end-user applications that allows end-users to utilize it. Therefore, the Opplet's functionalities can be divided into two groups:
- Services for CNM apps. Those federation services that Opplet provides to CNM apps.
- Services for end-users. Those services that Opplet provides to its end-users.
Some endeavors that are related to Opplet are included in the Farm for Opplet project (section Node clusters of this very wikipage) and DBs for Opplet project (section Database management). The core of Opplet is written specifically for the Cloud using Yii framework. Its periphery devices are assembled using commercial off-the-shelf (COTS) software.
App-oriented
- For the purposes of this wikipage, app-oriented Opplet refers to those endeavors to build Opplet that support CNM apps rather than its end-users.
Authorized endeavors related to app-oriented Opplet Progress WSO2 IS (work) Enrollment IAM Mail (Cloud) Exams Warehouse Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) (product) (product) Software under consideration WSO2 IS Yii Yii N/A Yii N/A
User-oriented
- For the purposes of this wikipage, user-oriented Opplet refers to those endeavors to build Opplet that support its end-users rather than CNM apps.
Authorized endeavors related to user-oriented Opplet Progress Interface (Opplet) Events (Opplet) Mailboxes (Opplet) Newsletters (Opplet) Calendar (Opplet) Registration Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) (product) (product) Software under consideration Yii Yii N/A N/A N/A Yii
CNM apps
CNM apps (hereinafter, the Apps) present end-user applications that are available to users of the Cloud. The Apps include:
- CNM stable apps that have at least 2 installations -- one is used for its target purposes and another is available for hands-on training. Any stable App needs to be able to work with our future Opplet WSO2 IS and, possibly, existing OpenLDAP. The Apps are assembled using commercial off-the-shelf (COTS) software only. Those endeavors that need to be undertaken for every stable App, must encompass (a) updating the Apps to the latest stable versions and install the latest patches if and when they become available and (b) documenting what we have and identify problems.
- CNM future apps that are installed on the CNM Lab Farm only. These apps represent either popular COTS packages or end-user application that can be deployed in the Cloud as CNM stable apps in the future.
This section lists both (a) those Apps that are incorporated, both CNM stable and future apps, as well as (b) some applications that may be potentially incorporated in the Cloud. Some endeavors that are related to the Apps are included in projects listed in DNS management and App-oriented sections of this very wikipage.
Utilizing MariaDB
- For the purposes of this wikipage, utilizing MariaDB apps refer to those CNM stable apps that utilize MariaDB as its database management system. The Cloud incorporates at least five of them.
Authorized endeavors related to utilizing MariaDB apps Progress AVideo (work) WordPress (work) MediaWiki (work) HumHub (work) Moodle (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) (product) Software under consideration AVideo WordPress MediaWiki HumHub Moodle
Utilizing non-MariaDB
- For the purposes of this wikipage, utilizing non-MariaDB apps refer to those CNM stable apps that don't utilize MariaDB as its database management system. The Cloud incorporates at least four of those Apps:
Authorized endeavors related to utilizing non-MariaDB apps Progress GitLab (work) SuiteCRM (work) Odoo (work) Jitsi (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) Software under consideration GitLab SuiteCRM Odoo Jitsi
Experimental
- For the purposes of this wikipage, experimental apps refer to (a) CNM future apps, (b) some applications that have been installed to be analyzed and evaluated, (c) those applications that are to be utilized during short hands-on training sessions, and (d) legacy applications that are retired from CNM stable app, but are still kept as "museum" exhibits.
Authorized endeavors related to experimental apps Progress OpenEdX (work) ProjecQtOr (work) Redmine (work) Taiga (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product) Software under consideration OpenEdX ProjecQtOr Redmine Taiga
Enterprise
Venture administration
- For the purposes of this wikipage, venture administration refers to human administration of the Cloud enterprise.
Authorized endeavors related to enterprise administration Progress Personnel Agency Finance Legal Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed (product) (product) (product) (product)
External operations
- For the purposes of this wikipage, enterprise external operations refer to those endeavors that are utilized or can be used outside of the enterprise behind the Cloud.
Authorized endeavors related to enterprise external operations Progress Industry Developers Technologies (work) Help Desk (work) Operators (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed Industry (product) Developers (product) Technologies (product) Help Desk (product) Operators (product)
Stakeholder groups
- For the purposes of this wikipage, stakeholder groups refer to those endeavors that are utilized or can be used to manage groups of the Cloud stakeholders.
Authorized endeavors related to stakeholder groups Progress Councils (work) Committees (work) Users (work) Sysadmins (work) Business requirements Prototypes Stakeholder requirements Deliverable specifications Work specifications Certainty Utility Applicability Controllability Products to be developed Councils (product) Committees (product) Users (product) Sysadmins (product)
Name yours
CNM Cloud integration that is based on exploring the possibilities of integrating the Cloud, such as using Jenkins and Kafka, and adding VPNs, such as integrating email services across the Farms.
- Configuration for CNM Farms. New development of CNM Cloud configuration that is based on exploring the possibilities of adding the ability to automatically create virtual machines, possibly using Terraform and Ansible.
- Statistics for CNM Farms. New development of CNM Cloud statistics that is based on exploring the possibilities of using ZooKeeper and log management.
- Revisions for CNM Farms. New development of CNM Cloud revisions that aim to build the system of periodic revisions of the Farms.
- Grafana for CNM Farms. New development of CNM Grafana
- Zabbix for CNM Farms. New development of CNM Zabbix
- Nagios for CNM Farms. New development of CNM Nagios
- MariaDB for CNM Farms. Further development of CNM MariaDB
- PostgreSQL for CNM Farms. New development of CNM PostgreSQL
- DBs for Opplet. Further development of Opplet DB
- Ceph for CNM Farms. Further development of CNM Ceph
- For the purposes of this wikipage, DNS management refers to those endeavors that are utilized or can be used to manage DNS of the Cloud:
- CDN for CNM Farms. New development of CNM Farm CDN to explore building one or more content delivery networks (CDNs) at least for some of CNM apps.
- DNSSEC for CNM Farms. New development of CNM Farm DNSSEC to explore utilizing DNSSEC in the Cloud.
- Geocast for CNM Farms. New development of CNM Farm Geocast to explore adding Geocast or similar functionality to some part or parts of the Cloud.
- IPv6 for CNM Farms. Further development of CNM Farm IPv6 to explore migration of the Cloud's DNS, except for public access, to IPv6.
- Revisions for CNM DNS. New development of CNM DNS revisions
- Panels for CNM Farms. New development of Panels in CNM Farms to explore adding control panels such as VestaCP, as well as status systems such as Cachet to the Cloud.
- Workspaces for CNM Cloud. New development of Workspaces in CNM Cloud to explore adding personal tools and development environments such as Eclipse to the Cloud.
- Nextcloud for CNM Cloud. New development of CNM Nextcloud to explore adding Nextcloud as a set of personal management tools to the Cloud.
- WSO2 IS for Opplet. New development of Opplet WSO2 IS to add WSO2 Identity Server (WSO2 IS) services to Opplet. Currently, Opplet utilizes OpenLDAP as its authorization and identity connector. However, OpenLDAP does not allow single sign-on (SSO) services. In addition, the Opplet developers faced troubles in changing roles and in connecting some end-user applications such as MediaWiki with OpenLDAP. Adding WSO2 IS also aims to introduce user registration in Opplet within CNM apps. Currently, the users must first register with Opplet in order to use those CNM app's services that are available for the registered users only. It is unclear at the moment whether OpenLDAP shall be kept in Opplet after WSO2 IS addition and, if so, how.
- Enrollment to Opplet. New development of Opplet Enrollment to transfer the course registration (which Moodle in Australian way calls "enrolment") from CNM Cert to Opplet. Beyond visibility of user enrollment status on Opplet dashboard, this transfer shall resolve several problems: (a) speed. The current enrollment is carried out through the cron tool, which has a response delay, (b) enrollment in LMSes other than CNM Cert. The Cert accommodates only first 3 levels of the educational programs, (c) automatic unenrollment from those courses that have successfully been completed.
- IAM to Opplet. Further development of Opplet IAM to (a) automatically add new federated Opplet roles based on the course progress and (b) communicate those roles to CNM apps. Currently, Opplet user roles can only be changed manually by Opplet administrators.
- Mail for CNM Cloud. Further development of CNM Mail Server to make sure that all CNM apps can send and, when applicable, receive emails through it.
- Exams to Opplet. New development of Opplet Exams to move test banks from CNM Moodle to Opplet.
- Warehouse for CNM Cloud. New development of Opplet Warehouse to create a federated object storage in order to make illustrations and other files available for various CNM apps. The Cloud developers earlier also discussed an idea was to utilize CNM GitLab as a file storage.
- Interface for Opplet. Further development of Opplet interface to improve its usability and graphic design.
- Events for Opplet. New development of Opplet Events to (a) organize events on the administrative side and (b) manage own participation on the end-user side in the Cloud.
- Mailboxes to Opplet. Further development of Opplet Mailboxes to accommodate its automatic creation, management, and cancelation in order to upgrade this feature from its minimum viable product (MVP) state up to the marketable one.
- Newsletters to Opplet. New development of Opplet Newsletters to add mailing list and subscription functionalities.
- Calendar for Opplet. New development of Opplet Calendar to add a federated calendar to Opplet.
- CNM Registration Project. Further development of Opplet profiles.
- AVideo for CNM Cloud. Further development of CNM AVideo to upgrade this app from its minimum viable product (MVP) state up to the marketable one. Previously, several test videos were recorded and posted there, but their fate is currently unknown. At this moment, it is unclear where and how this app will be finally installed since its HA and storage solutions haven't been designed yet.
- WordPress for CNM Cloud. Further development of CNM WordPress to upgrade this app from its minimum viable product (MVP) state up to the marketable one. WordPress and MariaDB as its database management system are used under the hood of this app. Previously, the Cloud developers struggled with the viruses, so an effective anti-virus strategy must be found.
- MediaWiki for CNM Cloud. Further development of CNM MediaWiki to upgrade this app from its minimum viable product (MVP) state up to the marketable one. MediaWiki and MariaDB as its database management system are used under the hood of this app. For a few years, the stable version of MediaWiki has not been updated due to new versions' conflict with our LDAP plugin. However, a decision has been made to migrate the integration to WSO2 IS and it is not clear whether LDAP will remain necessary. Also periodically there are problems with pictures, which the Warehouse for CNM Cloud project shall address.
- HumHub for CNM Cloud. Further development of CNM HumHub to upgrade this app from its minimum viable product (MVP) state up to the marketable one. HumHub and MariaDB as its database management system are used under the hood of this app.
- Moodle for CNM Cloud. Further development of CNM Moodle to upgrade this app from its minimum viable product (MVP) state up to the marketable one. Moodle and MariaDB as its database management system are used under the hood of this app.
- GitLab for CNM Cloud. Further development of CNM GitLab to upgrade this app from its minimum viable product (MVP) state up to the marketable one. GitLab and PostgreSQL as its database management system are used under the hood of this app. Initially, the Cloud developers utilized Redmine instead of GitLab; some projects haven't been moved yet. The Redmine instance shall be moved to CNM Lab Farm.
- SuiteCRM for CNM Cloud. Further development of CNM SuiteCRM to upgrade this app from its minimum viable product (MVP) state up to the marketable one. SuiteCRM and PostgreSQL as its database management system are used under the hood of this app.
- Odoo for CNM Cloud. Further development of CNM Odoo to upgrade this app from its minimum viable product (MVP) state up to the marketable one. Odoo and PostgreSQL as its database management system are used under the hood of this app. Its HR and recruiting modules are planned to be used as soon as possible.
- Jitsi for CNM Cloud. Further development of CNM Jitsi to upgrade this app from its minimum viable product (MVP) state up to the marketable one. Jitsi is used under the hood of this app. Its database management system is unknown. At this moment, it is unclear where and how this app will be finally installed since its HA and storage solutions haven't been designed yet.
- OpenEdX for CNM Cloud. New development of CNM OpenEdX to explore OpenEdX and evaluate it in comparison with Moodle. CNM Cert hosts only first three levels of WorldOpp program; other courses, including language courses, are planned to be done on the OpenEdX platform.
- ProjecQtOr for CNM Cloud. New development of CNM ProjecQtOr to explore ProjecQtOr and evaluate it in comparison with other project management software that is deployed in the Cloud.
- Redmine for CNM Cloud. Further development of CNM Redmine to keep Redmine in the Cloud as a legacy app.
- Taiga for CNM Cloud. New development of CNM Taiga to explore Taiga software and evaluate it in comparison with other project management software that is deployed in the Cloud.
- Personnel for CNM Cloud. Further development of CNM Cyber personnel to advance human resource management for those human resources that work on the Cloud.
- Agency for CNM Cloud. New development of CNM Cyber agency to build an organizational structure behind the Cloud.
- Finance for CNM Cloud. New development of CNM Cyber finance to build financial accounting, reporting, and management behind the Cloud.
- Legal for CNM Cloud. New development of CNM Cyber legal to build legal activities behind the Cloud.