forked from 0x1D8/nure
423 lines
58 KiB
Typst
423 lines
58 KiB
Typst
#import "template.typ": *
|
||
#import "@preview/indenta:0.0.3": fix-indent
|
||
|
||
#let author = (
|
||
name: "Білоус А. А.",
|
||
full_name_gen: "Білоуса Антона Андрійовича",
|
||
group: "ПЗПІ-23-3",
|
||
gender: "m",
|
||
)
|
||
|
||
#let mentors = (
|
||
(
|
||
name: "Широкопетлєва М. С.",
|
||
gender: "f",
|
||
degree: "Ст. викл. каф. ПІ",
|
||
),
|
||
(
|
||
name: "Черепанова Ю. Ю.",
|
||
gender: "f",
|
||
degree: "Ст. викл. каф. ПІ",
|
||
),
|
||
(
|
||
name: "Русакова Н. Є.",
|
||
gender: "f",
|
||
degree: "Доц. каф. ПІ",
|
||
),
|
||
)
|
||
|
||
#let task_list = (
|
||
done_date: datetime(year: 2024, month: 12, day: 27),
|
||
initial_data: datetime(year: 2024, month: 9, day: 15),
|
||
source: "методичні вказівки до виконання курсової роботи, вимоги до інформаційної системи, предметна область, що пов’язана з пакунковим репозиторієм та його менеджментом.",
|
||
content: "вступ, аналіз предметної області; постановка задачі; проектування бази даних; опис програми; висновки; перелік джерел посилання.",
|
||
graphics: "загальна діаграма класів, ER-діаграма, UML-діаграми, DFD-діаграма, схема БД в 1НФ, 2НФ, 3НФ, копії екранів (“скриншоти”) прикладної програми, приклади звітів прикладної програми.",
|
||
)
|
||
|
||
#let calendar_plan = (
|
||
plan_table: [],
|
||
approval_date: datetime(year: 2024, month: 12, day: 27),
|
||
)
|
||
|
||
#let abstract = (
|
||
keywords: (
|
||
"БАЗА ДАНИХ",
|
||
// "АВТОМАТИЗАЦІЯ",
|
||
"РЕПОЗИТОРІЙ",
|
||
"ПАКУНОК",
|
||
"RUST",
|
||
"MYSQL",
|
||
"SQL",
|
||
),
|
||
text: [
|
||
Мета даної роботи -- проєктування та розробка інформаційної системи "Репозиторій пакунків. Колаборація над пакунками", яка спрямована на створення ефективного середовища для спільної розробки та управління програмними пакунками. Система забезпечує зберігання інформації про програмні пакунки, а також надає інструменти для їх вдосконалення колективною співпрацею користувачів.
|
||
|
||
Для реалізації інформаційної системи було обрано сучасний стек технологій, а саме:
|
||
Rust@rust -- як основна мова програмування для всих частин застосунку,
|
||
iced@iced -- бібліотека для побудови графічних інтерфейсів з Elm архітектурою,
|
||
SQLx@sqlx -- бібліотека для низькорівневої роботи з базою даних, що забезпечує коректність і гнучкість,
|
||
MySQL@mysql -- як СУБД для зберігання інформації про пакунки, користувачів, та їх відносини,
|
||
Neovim@neovim -- як сучасний редактор коду для швидкої і зручної розробки.
|
||
|
||
Результат розробки -- комп'ютерна програма, яка дозволяє зберігати та відображати інформацію про користувачів, пакунки та їх відносини; генерувати статистику про користувача та його пакунки. Застосунок, створений з використанням мови програмування Rust є безпечним, правильним, надійним та швидким.
|
||
],
|
||
)
|
||
|
||
#let appendices = (
|
||
/*(
|
||
title: "Приклад звіту 1",
|
||
content: [test],
|
||
),
|
||
(
|
||
title: "Приклад звіту 2",
|
||
content: [test],
|
||
),
|
||
(
|
||
title: "Приклад звіту 3",
|
||
content: [test],
|
||
),*/
|
||
)
|
||
|
||
#show: cw-template.with(
|
||
title: [Інформаційна система "Репозиторій пакунків". Колаборація над пакунками],
|
||
subject_shorthand: "БД",
|
||
department_gen: "Програмної інженерії",
|
||
edu_program_shorthand: "ПЗПІ",
|
||
author: author,
|
||
mentors: mentors,
|
||
task_list: task_list,
|
||
calendar_plan: calendar_plan,
|
||
abstract: abstract,
|
||
bib_path: "bibl.yml",
|
||
appendices: appendices,
|
||
)
|
||
|
||
#show: fix-indent()
|
||
|
||
#nheading("Вступ")
|
||
У сучасному світі істують мільйони пакунків з програмним забезпеченням, програмними бібліотеками та іншою інформацією.
|
||
Інформаційні системи управління цими пакунками стали критично важливим елементом сучасної розробки програмного забезпечення. Їх значення особливо зросло з розвитком відкритого програмного забезпечення та модульного підходу до розробки, де кожен проект може залежати від десятків, сотень, або навіть тисяч сторонніх компонентів.
|
||
|
||
Відсутність ефективних систем управління пакунками призводить до численних проблем у процесі розробки. Розробники стикаються з труднощами при пошуку потрібних бібліотек, виникають конфлікти версій, ускладнюється процес оновлення залежностей, а також з'являються проблеми з безпекою через використання застарілих версій компонентів. Це суттєво сповільнює процес розробки та може призвести до значних фінансових втрат.
|
||
|
||
Метою цієї курсової роботи є розробка інформаційної системи "Репозиторій пакунків. Колаборація над пакунками", яка спрощує процес менеджменту пакунків, створення їх відносин, керування залежностями, та надання користувачам різних ролей у розвитку репозиторію. У процесі роботи над системою було проведено детальний аналіз зхожої системи AUR@aur, котра ефективно використовується для надання користувачам дистрибутиву Arch Linux@archlinux можливості публіковати свої пакунки. Було спроектовано реляційну базу даних і розроблено комп'ютерну програму, яка дозволяє взаємодіяти з репозиторієм.
|
||
|
||
Весь застосунок написано мовою програмування Rust@rust, для графічного інтерфейсу використовується бібліотека iced@iced, для взаємодії з базою даних використвуєтсья бібліотека SQLx@sqlx. Інформація зберігається у базі даних MySQL@mysql. Розробка виконувалася у текстовому редакторі Neovim@neovim.
|
||
|
||
= АНАЛІЗ ТА КОНЦЕПТУАЛЬНЕ МОДЕЛЮВАННЯ ПРЕДМЕТНОЇ ОБЛАСТІ
|
||
#v(-spacing)
|
||
== Аналіз предметної області
|
||
Дослідження предметної області є ключовим етапом у розробці інформаційної системи "Репозиторій пакунків. Колаборація над пакунками". Основною метою даного аналізу є визначення функціональних вимог та технічних особливостей системи, необхідних для ефективного управління програмними пакунками та забезпечення продуктивної співпраці розробників.
|
||
|
||
Пакунковий репозиторій являє собою централізоване сховище інформації про програмне забезпечення, що забезпечує зберігання, версіонування та розповсюдження програмних компонентів. В сучасних умовах критично важливою є автоматизація таких процесів як управління залежностями, контроль версій, перевірка сумісності та забезпечення безпеки пакунків. Це дозволяє значно підвищити ефективність розробки програмного забезпечення та мінімізувати ризики, пов'язані з використанням сторонніх компонентів.
|
||
|
||
Для створення ефективної системи управління пакунками необхідно ретельно проаналізувати існуючі рішення та їх особливості. Такий аналіз допомагає виявити найбільш важливі функціональні можливості та уникнути потенційних проблем при проектуванні власної системи.
|
||
|
||
В якості системи-аналогу розглянемо Arch User Repository (AUR)@aur -- репозиторій користувацьких пакунків для дистрибутиву Arch Linux@archlinux. AUR є яскравим прикладом успішної реалізації концепції колаборативної розробки та управління пакунками. Система надає користувачам можливість самостійно створювати та поширювати пакунки, які не входять до офіційного репозиторію.
|
||
|
||
При відвідуванні головної сторінки AUR @aur_main можна побачити статиску свого акаунту, всього репозиторію а також останні оновлення пакунків. За допомогою поля пошуку можна перейти до сторінки пошуку пакунків @aur_search.
|
||
|
||
#img("img/aur/aur_main.png", "Головна сторінка AUR")
|
||
|
||
#img("img/aur/aur_search.png", "Сторінка пошуку AUR")
|
||
|
||
Зі сторінки пошуку пакунків можна перейти до сторінки інформації пакунку, або ж до сторінки користувача який супроводжує пакунку. На сторінці інформації пакунку @aur_package можна побачити що пакунок має базу пакунку, пошукові слова, ліцензії, різні ролі користувачів, інформацію про залежності, тощо. На сторінці інформації про користувача @aur_user можна побачити різні атрибути пов'язані з акаунтом.
|
||
|
||
#img("img/aur/aur_package.png", "Деталі пакунку в AUR")
|
||
|
||
#img("img/aur/aur_user.png", "Деталі користувача в AUR")
|
||
|
||
Навігація по репозиторію здебільного здійснюється за допомогою гіперпосилань на сторінку пошуку де можна обрати досить багато критерій пошуку. Наприклад, при натисканні посилання "View this user's packages" в профілі користувача lsf, можна побачити всі пакунки котрі цей користувач підтримує @aur_search_func.
|
||
|
||
#img("img/aur/aur_search_func.png", "Фунціонал пошуку AUR")
|
||
|
||
В контексті розробки пакункового репозиторію важливо визначити основні ролі користувачів та їхні потреби. Розробники пакунків виступають основними користувачами системи, створюючи та підтримуючи програмні компоненти, в той час як інші учасники можуть долучатися до процесу тестування, рецензування та вдосконалення пакунків.
|
||
|
||
Аналіз інформаційної системи виявив наступні ключові об'єкти предметної області: читач, супроводжуючий, пакунок, база пакунку, залежності пакунків, відносини пакунків, роль користувача. Основним користувачем виступає читач, який потребує ефективних інструментів для отримання інформації про програмні компоненти.
|
||
|
||
Основні інформаційні потреби користувачів системи включають:
|
||
- забезпечення повного циклу управління пакунками: створення, редагування, версіонування та видалення;
|
||
- надання інструментів для автоматизованої перевірки залежностей та сумісності компонентів;
|
||
- забезпечення генерації технічної документації та звітів про використання пакунків.
|
||
|
||
На основі проведеного аналізу було визначено критичні вимоги до функціоналу репозиторію пакунків. Ця інформація становитиме основу для проектування системи, яка забезпечить ефективну колаборацію над програмними компонентами та автоматизує ключові процеси їх розробки та супроводу.
|
||
|
||
Особлива увага буде приділена реалізації механізмів забезпечення якості та безпеки пакунків, оскільки ці аспекти є критичними для створення надійної екосистеми програмного забезпечення. Система також передбачатиме можливості для масштабування та інтеграції з іншими інструментами розробки.
|
||
|
||
== Концептуальне моделювання предметної області
|
||
Інформаційна система передбачає взаємодію як для читачів (неавтентифікованих користувачів), так і для автентифікованих користувачів. Система автоматизує процеси пов'язні з відстеженням залежностей пакунків, прав користувачів, пошуком пакунків і генеруванням статистик.
|
||
|
||
Кожний неавтентифікований користувач буде мати можливість ефективно:
|
||
- здійснювати пошук пакунків за різними параметрами;
|
||
- переглядати інформацію про пакунки, їх бази;
|
||
- переглядати інформацію про користувачів;
|
||
- переглядати статистику репозиторію;
|
||
- увійти у існуючий, або створити новий акаунт.
|
||
|
||
Разом з можливостями неавтентифікованих користувачів, автентифіковані користувачі повинні мати можливість ефективно:
|
||
- створювати пакунки;
|
||
- створювати бази пакунків;
|
||
- видаляти власні пакунки та бази пакунків;
|
||
- додавати, видаляти та оновлювати залежності та відносини для власних пакунків;
|
||
- додавати, видаляти та оновлювати ролі інших користувачів для власних пакунків;
|
||
- оновлювати чужі пакунки та бази пакунків до яких був наданий доступ редагування;
|
||
- переглядати статистику свого акаунту;
|
||
- змінювати інформацію своєго акаунту;
|
||
- вийти з акаунту;
|
||
- видалити свій акаунт.
|
||
|
||
Всі дані зберігатимуться в базі даних, яка містить пов'язані таблиці спроектовані таким чином, що б забезпечити цілістність і коректність даних в них. Розумне проектування бази даних забезпечить оптимізацію обробку, пошук та оновлення інформації. Кожному об'єкту предметної області, як от користувач, пакунок, база пакунку, залежності пакунків, відносини пакунків та роль користувача, буде відповідати певна таблиця. Для розуміння структури інформаційної системи спроектовано загаліну діаграму класів @class_diagram, яка є основою для проектування бази даних.
|
||
|
||
#img("img/class_diagram.png", "Загальна діаграма класів (рисунок виконаний самостійно)")
|
||
|
||
Система буде зберігати наступні дані:
|
||
- об'єкт користувача буде зберігати інформацію про користувачів системи. Він буде містити ім'я користувача, електронну пошту, пароль, час останнього використання обілкового запису, та його час створення з оновленням. Ця інформація необхідна для автентифікації та авторизації користувачів, а також для аудиту дій користувачів в системі;
|
||
- об'єкт бази пакунку буде зберігати базову інформацію про групи пакунків. Він дозволить об'єднувати пакунки зі спільними компонентами та користувачами. Містить ім'я та опис групи пакунків, а також час створення та останнього оновлення. Ця інформація дозволяє групувати пакунки за їх базовою функціональністю;
|
||
- об'єкт типу ролі користувача буде описувати ролі користувачів у контексті груп пакунків. Містить ідентифікатор ролі, її ім'я та опис. Приклади ролей: submitter (відправник), packager (пакувальник), maintainer (супроводжуючий), flagger (позначник). Цей об'єкт визначає дозволи користувачів на певні дії з групами пакунків;
|
||
- об'єкт ролі користувача буде прив'язувати користувачів до груп пакунків та визначати їх ролі в цих групах. Містить ідентифікатор групи пакунків, ідентифікатор користувача, ідентифікатор ролі та коментар від користувача. Ця інформація дозволяє визначити, хто, чому, і які права має в кожній групі пакунків;
|
||
- об'єкт пакунку буде зерігати інформацію про окремі пакунки. Містить ідентифікатор групи пакунків, ім'я пакунку, версію, опис, веб-покликання, опціональний час позначення, час створення та останнього оновлення. Ця інфрмація є основною для ідентифікації та опису кожного пакунку;
|
||
- об'єкт виду залежності буде визначати типи залежностей пакунків (наприклад, проста залежність, залежність для збірки пакунку, опціональна залежність). Містить ідентифікатор типу залежності та її назву. Цей об'єкт дозволить класифікувати залежності пакунків;
|
||
- об'єкт залежностей пакунку буде зберігати інформацію про залежності пакунків. Він буде містити архітектуру, умову, опис, ідентифікатор пакунку, ідентифікатор типу залежності та псевдонім назви залежності. Ця інформація дозволяє визначити, від яких інших пакунків залежить даний пакунок.
|
||
- об'єкт виду відносин буде визначати типи відносин між пакунками (наприклад: конфліктує, надає, замінює). Містить ідентифікатор типу відношення та його назву. Цей об'єкт дозволяє класифікувати відносини між пакунками;
|
||
- об'єкт відносин пакунків буде зберігати інформацію про відносини пакунків (конфлікти, надання, заміна). Містить архітектуру, вимоги, ідентифікатор пакунку, ідентифікатор типу відношення та ім'я пакунку-відношення. Ця інформація дозволяє визначити, які пакунки конфліктують з даним пакунком, які функції він надає, і які пакунки він замінює.
|
||
|
||
Користувач системи має можливість здійснювати пошук пакунків та перегляди їх інформацію, переходити до профілей користувачів та переглядати їх пакунки. Для наочного представлення процесів та потоків даних в системі під час виконання користувачем поставленої задачі створимо DFD-діаграму @data_diagram, що відображатиме послідовність кроків під час виконання користувачем цільової бізнес-задачі перегляду інформації про пакунок та отримання звіту з цієї інформації.
|
||
|
||
#img("img/data_diagram.png", "Діаграма потоків даних (рисунок виконано самостійно)")
|
||
|
||
Для ефективного відображення інформаційних потреб користувачів необхідно побудувати діаграму варіантів використання (Use Case). Ця діаграма /* @usecase_diagram */ демонструє взаємодію між різними акторами системи, такими як користувачі, адміністратори та інші учасники, та функціональними можливостями системи, такими як управління пакунками, їх створення, перегляд, отримання інформації та інші операції. Діаграма варіантів використання дозволяє визначити основні сценарії взаємодії користувачів з системою, ідентифікувати ключові функції та процеси, що відбуваються під час цієї взаємодії, та забезпечити розробку системи, яка відповідає реальним потребам користувачів. Крім того, діаграма варіантів використання може бути використана для визначення пріоритетів функціональних можливостей системи, виявлення потенційних проблем та слабких місць у процесах взаємодії з користувачами, а також для оптимізації архітектури системи для забезпечення максимальної ефективності та зручності використання.
|
||
|
||
//#img("img/usecase_diagram.png", "Use-Case діаграма (рисунок виконаний самостійно)")
|
||
|
||
= Постановка задачі
|
||
|
||
Метою курсової роботи є розробка інформаційної системи "Репозиторій пакунків. Колаборація над пакунками", яка забезпечить ефективне зберігання, пошук, управління та спільну розробку програмних пакунків. Після аналізу предметної області було виділено наступні вимоги щодо функціоналу інформаційної системи:
|
||
|
||
+ Підтримка основних процесів управління пакунками та їх метаданими:
|
||
+ створення пакунків, їх оновлення та видалення;
|
||
+ керування метаданими пакунків, включаючи назву, версію, веб-покликання на ресурс, ліцензію, опис та групу;
|
||
+ додання, оновлення та видалення залежностей між пакунками, а саме: обов'язкова залежність, опціональна залежність, та залежність під час збірки пакунку;
|
||
+ додання, оновлення та видалення відносин пакунків таких як: надання залежності, конфлікт з залежністю та заміна залежності.
|
||
|
||
+ Забезпечення системи користувацьких акаунтів:
|
||
+ надійний механізм реєстрації та автентифікації користувачів;
|
||
+ можливість видалення свого акаунту та передачі пакунків іншому користувачеві;
|
||
+ механізм блокування недобросовісних користувачів.
|
||
|
||
+ Система прав користувачів над пакунками:
|
||
+ мітчик пакунку -- будь-який користувач котрий знаходить проблему в пакунку та помічає його з коментарем який описує цю проблему;
|
||
+ автор пакунку -- користувач який створив пакунок, він володіє пакунком та може здійснювати всі процеси управління пакунком, в тому числі надавати права іншим користувачам;
|
||
+ пакувальник пакунку -- користувач котрий має дозвіл на завантаження нових збірок пакунку до репозиторію;
|
||
+ супроводжуючий пакунку -- користувач котрий був назначений автором як його заступник який може здійснювати всі процеси управління пакунком окрім назначення нових авторів і супроводжуючих та видалення пакунку.
|
||
|
||
+ Функції пошуку та категоризації:
|
||
+ пошук та фільтрація пакунків за веб-покликанням, назвою, групою, описом пакунку, описом групи, навзвою та описом пакунку, користувачем, помітчиком, пакувальником, подавачем та супроводжуючим пакунку;
|
||
+ можливість точного та довільного пошуку;
|
||
+ можливість вибору ліміту кількості результатів пошуку;
|
||
+ сортування результатів за назвою пакунку, його версією, назвою групи, часом створення та часом останнього оновлення.
|
||
|
||
+ Надання аналітичної інформації:
|
||
+ статистика користувачів: загальна кількість користувачів, кількість активних та неактивних користувачів;
|
||
+ статистика репозиторію: загальна кількість пакунків, кількість осиротілих пакунків, кількість пакунків доданих та оновлених за останній тиждень та кількість пакунків котрі ніколи не оновлювалися;
|
||
+ інформація про залежності та відносини кожного пакунку з іншими пакунками;
|
||
+ інформація про пакунки кожного користувача та рівень прав який цей користувач має для цих пакунків.
|
||
|
||
|
||
= Проектування бази даних
|
||
#v(-spacing)
|
||
== Побудова ER-діаграми
|
||
Проведений аналіз предметної області дозволив визначити наступні сутності та їх атрибути:
|
||
|
||
- сутність "Користувач": ім'я, електронна пошта, пароль, дата останнього використання, дата створення, дата оновлення;
|
||
- сутність "Пакунок": назва, версія, опис, веб-покликання, дата позначення, дата створення, дата оновлення;
|
||
- сутність "База пакунку": назва, опис, дата створення, дата оновлення;
|
||
- сутність "Тип ролі": назва ролі, опис;
|
||
- сутність "Роль": коментар;
|
||
- сутність "Тип залежності": назва виду залежності;
|
||
- сутність "Залежність": архітектура, умова, опис, назва залежного пакунку;
|
||
- сутність "Тип відношення": назва виду відношення;
|
||
- сутність "Відношення": архітектура, умова, назва пакунку з яким є відношення.
|
||
|
||
Між цими сутностями існують наступні зв’язки:
|
||
|
||
- "Користувач" - "Роль": один до жодного або багатьох;
|
||
- "База пакунку" - "Роль": один до жодного або багатьох;
|
||
- "Тип ролі" - "Роль": один до жодного або багатьох;
|
||
- "База пакунку" - "Пакунок": один до жодного або багатьох;
|
||
- "Пакунок" - "Залежність": один до жодного або багатьох;
|
||
- "Тип залежності" - "Залежність": один до жодного або багатьох;
|
||
- "Пакунок" - "Відношення": один до жодного або багатьох;
|
||
- "Тип відношення" - "Відношення": один до жодного або багатьох.
|
||
|
||
Зобразимо визначені сутності та відповідні зв’язки у вигляді ER-діаграми @er_diagram.
|
||
|
||
#img("img/er_diagram.png", "ER-діаграма концептуальної моделі (рисунок виконаний самостійно)")
|
||
|
||
Отримана ER-діаграма буде використана для обрання та побудови логічної моделі бази даних.
|
||
|
||
== Вибір та побудова логічної моделі бази даних на базі ER-діаграми
|
||
|
||
Для створення логічної моделі бази даних репозиторію пакунків було обрано реляційну модель. Ця модель дозволяє ефективно організувати дані у вигляді взаємопов'язаних таблиць, що забезпечує чітку структуру інформації в контексті управління пакунками та колаборації між користувачами. Вона гарантує узгодженість всіх зв'язків між сутностями, такими як "Користувач", "Пакунок", "База пакунку" та іншими, а також підтримує обмеження цілісності даних.
|
||
|
||
Реляційна модель надає потужні можливості для виконання складних запитів, що є критичним для системи управління пакунками. Це дозволяє ефективно обробляти запити користувачів щодо пошуку пакунків, аналізу залежностей та відношень між ними, а також керування правами доступу через систему ролей. На основі розробленої ER-діаграми @er_diagram було спроєктовано логічну модель бази даних @logic_model.
|
||
|
||
Для забезпечення точного розуміння відповідності між ER-діаграмою та логічною схемою створено довідник атрибутів @attributes. Цей довідник встановлює однозначну відповідність між термінами, використаними в концептуальній моделі (ER-діаграмі) та їх представленням у логічній моделі бази даних. Особливу увагу приділено відображенню зв'язків між сутностями, що реалізовані через механізм зовнішніх ключів, забезпечуючи цілісність даних та правильну роботу системи контролю версій пакунків.
|
||
|
||
Обрана модель також враховує специфіку роботи з пакунками, їх залежностями та відношеннями, що є ключовим аспектом функціонування репозиторію пакунків. Це дозволяє ефективно відстежувати зміни в пакунках, керувати правами доступу користувачів та забезпечувати надійну основу для колаборації над пакунками.
|
||
|
||
#figure(
|
||
table(
|
||
columns: 2,
|
||
table.header[ER-діаграма][Логічна модель],
|
||
[Архітектура], [arch],
|
||
[База пакунку], [base],
|
||
[База пакунку], [PackageBases],
|
||
[Веб-покликання], [url],
|
||
[Версія], [version],
|
||
[Відношення], [PackageRelations],
|
||
[Дата логіну], [last_used],
|
||
[Дата оновлення], [updated_at],
|
||
[Дата позначення], [flagged_at],
|
||
[Дата створення], [created_at],
|
||
[Електронна пошта], [email],
|
||
[Залежність], [PackageDependencies],
|
||
[Ім'я], [name],
|
||
[Коментар], [comment],
|
||
[Користувач], [user],
|
||
[Користувач], [Users],
|
||
[Назва], [name],
|
||
[Назва залежного пакунку], [dependency_package_name],
|
||
[Назва пакунку з яким є відношення], [relation_package_name],
|
||
[Опис], [description],
|
||
[Пакунок], [Packages],
|
||
[Пароль], [password],
|
||
[Роль], [PackageBaseUserRoles],
|
||
[Тип відношення], [RelationTypes],
|
||
[Тип залежності], [DependencyTypes],
|
||
[Тип ролі], [role],
|
||
[Тип ролі], [PackageBaseRoles],
|
||
[Умова], [requirement],
|
||
),
|
||
caption: [довідник атрибутів (таблиця виконана самостійно)],
|
||
) <attributes>
|
||
|
||
#img("img/logic_model.png", "Логічна модель бази даних (рисунок виконаний самостійно)")
|
||
|
||
Побудована база даних відповідає умовам третьої нормальної форм, адже кожна таблиця має первинний ключ, всі атрибути є атомарними, всі не ключові атрибути знаходяться у повній функціональній залежності від відповідних первинних ключів, та у таблицях відсутні транзитивні залежності.
|
||
|
||
|
||
+ Таблиця Users:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: name, email, password, last_used, created_at, updated_at;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця Packages:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: base, name, version, description, url, flagged_at, created_at, updated_at;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця PackageBases:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: name, description, created_at, updated_at;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця PackageBaseRoles:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: name, description;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця PackageBaseUserRoles:
|
||
+ від складеного первинного ключа (base, user, role) залежать всі неключові атрибути, а саме: comment;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від складеного первинного ключа (base, user, role), відсутні транзитивні залежності.
|
||
|
||
+ Таблиця DependencyTypes:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: name;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця PackageDependencies:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: arch, requirement, description, package, dependency_type, dependency_package_name;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця RelationTypes:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: name;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
+ Таблиця PackageRelations:
|
||
+ від первинного ключа id залежать всі неключові атрибути, а саме: arch, requirement, package, relation_type, relation_package_name;
|
||
+ таблиця відповідає всім вимогам 3НФ: всі атрибути атомарні, всі неключові атрибути залежать безпосередньо від первинного ключа id, відсутні транзитивні залежності.
|
||
|
||
== Побудова логічної моделі бази даних шляхом нормалізаці
|
||
|
||
Нормалізація структури даних відіграє фундаментальну роль у процесі проектування сучасних інформаційних систем, оскільки забезпечує створення раціональної архітектури даних, що ефективно запобігає надлишковості інформації та можливим аномаліям. В контексті розробки інформаційної системи пакункового репозиторію, нормалізація набуває особливої значущості через комплексну природу зв'зків між пакунками.
|
||
|
||
Розмір ER-діаграми інформаційної системи містить понад 25 атрибутів, тому згідно з методичними вказівками з курсового проектування було обрано частину, що охоплює 5 взаємопов'язаних сутностей: "Користувач", "Пакунок", "База пакунку", "Тип ролі" та "Роль" @normal_er_frag. Така декомпозиція дозволяє детально опрацювати найбільш критичні аспекти системи, забезпечуючи при цьому можливість подальшого масштабування.
|
||
|
||
#img("img/normal/normal_er_frag.png", "Фрагмент ER-діаграми (рисунок виконаний самостійно)")
|
||
|
||
Відповідно до теорії реляційних баз даних, відношення вважається нормалізованим до першої нормальної форми (1НФ) за умови дотримання наступних критичних вимог: атомарності даних (кожне поле містить лише одне значення), унікальності ідентифікації записів через первинні ключі, відсутності порожніх значень у ключових полях, та незалежності від фізичного порядку розташування записів.
|
||
|
||
Для практичної перевірки відповідності 1НФ, створимо універсальне відношення T @normal_t, що інтегрує атрибути всіх релевантних сутностей. Це відношення формує фундаментальну структуру для подальшої нормалізації даних.
|
||
|
||
При визначенні первинного ключа особлива увага приділяється семантичному аналізу даних. Зокрема можна помітити потребу бачити яку роль має користувач для кожного пакунку. Тому що найкращим ключовими атрибутами стануть "Пакунок id" та "Роль id". Ці атрибути надають можливість унікально ідентифікувати універсальне відношення та їх сполучення охоплює всі атрибути відношення.
|
||
|
||
#img("img/normal/normal_t.png", "Універсальне відношення T (рисунок виконаний самостійно)")
|
||
|
||
Всі визначені атрибути є неподільними, а значення атомарні. Сполучений первиний ключ який складаєтсья з "Пакунок id" та "Роль id" дозволяє унікально ідентифікувати кожний кортеж. Ключові поля не мають порожніх значень, кортежі не мають фіксованого порядку, тому, універсальне вдношення Т знаходиться в першій нормальній формі.
|
||
|
||
Щоб перевірити універсальне відношення Т на відповідність другій нормальній формі (2НФ), потрібно проаналізувати його на існування часткових функціональних залежностей неключових атрибутів від частини первинного ключа.
|
||
|
||
Для перевірки чи знаходиться відношення Т в другій нормальній формі визначимо функціональні залежності атрибутів @normal_t_dep.
|
||
|
||
Можемо зробити висновок, що відношення не знаходиться в другій нормальній формі, адже деякі атрибути мають неповні функціональні залежності (залежать лише від частини ключа). Для приведення універсального відношення Т до другої нормальної форми виділимо з нього три універсальних відношення T1 та T2 виходячи з помічених раніше неповних функціональних залежностей @normal_t12.
|
||
|
||
Відношення зберігають першу нормальну форму та не містять неповних функціональних залежностей, оскільки кожне з них має лише один ключовий атрибут. Таким чином, можна зробити висновок, що ці відношення відповідають вимогам другої нормальної форми.
|
||
|
||
#img("img/normal/normal_t_dep.png", "Універсальне відношення T із визначеними залежностями (рисунок виконаний самостійно)")
|
||
|
||
#img("img/normal/normal_t12.png", "Універсальні відношення T1 та Т2 (рисунок виконаний самостійно)")
|
||
|
||
Для досягнення третьої нормальної форми (3НФ) таблиці мають бути в другій нормальній формі, a також в відношеннях не має бути транзитивних залежностей, тобто кожен неключовий атрибут повинен залежати безпосередньо від первинного ключа, а не через інші неключові атрибути.
|
||
|
||
Проаналізувавши відношення Т1 та Т2 можемо побачити, що всі атрибути в них залежать від ключів "Пакунок id" та "Роль id" відповідно, але ще існують інші залежності:
|
||
- "База пакунку id" - "Назва", "Опис", "Дата створення", "Дата оновлення";
|
||
- "Тип ролі id" - "Назва", "Опис";
|
||
- "Користувач id" - "Ім'я", "Електронна пошта", "Пароль", "Дата логіну", "Дата створення", "Дата оновлення";
|
||
|
||
Винесемо з відношення Т1 два відношення "Тип ролі" та "Користувач" за допомогою ключів "Тип ролі id" та "Користувач id" відповідно. Після чого сформуємо відношення T3 в котрому залишимо тільки зовнішні ключі "Тип ролі id" та "Користувач id" @normal_t23.
|
||
|
||
#img("img/normal/normal_t23.png", [Відношення "Тип ролі", "Користувач", Т2 та Т3 (рисунок виконаний самостійно)])
|
||
|
||
Можна помітити, що відношення Т2 та Т3 мають спільне відношення "База пакунку id". Утворимо відношення "Пакунок" та "Роль" виділив з відношень Т2 та Т3 відповідно відношення "База пакунку", залишимо на його місці ключ "База пакунку id".
|
||
|
||
#img("img/normal/normal.png", [Відношення "Користувач", "Пакунок", "База пакунку", "Тип ролі" та "Роль" (рисунок виконаний самостійно)])
|
||
|
||
Тепер необхідно перевірити отримані відношення на відповідність третій нормальній формі.
|
||
|
||
Всі відношення мають первинні ключі, їх атрибути є атомарними, тому відношення відповідають вимогам першої нормальної форми. Крім того, всі атрибути кожного відношення повністю функціонально залежать від первинного ключа, що у поєднанні з відповідністю першій нормальній формі дозволяє зробити висновок, що відношення відповідають другій нормальній формі. Оскільки жодне відношення не містить транзитивних залежностей, а також відповідає вимогам другої нормальної форми, можна зробити висновок, що відношення знаходяться у третій нормальній формі.
|
||
|
||
Побудуємо схему даних та позначимо зв'язки між сутностями @normal_link. Після цього порівняємо отриману схему даних з початковою ER-діаграмою для подальшого аналізу.
|
||
|
||
#img("img/normal/normal_link.png", "Побудована схема даних (рисунок виконаний самостійно)")
|
||
|
||
Порівняння отриманої схеми даних з початковою ER-діаграмою @er_diagram показує їхню повну відповідність, що свідчить про успішну нормалізацію схеми даних до третьої нормальної форми. Це значить, що всі сутності, атрибути та зв'язки між ними були правильно ідентифіковані, а всі непотрібні залежності та повторення даних були усунуті. Це забезпечить ефективність та масштабованість інформаційної системи.
|
||
|
||
|
||
= Опис програми
|
||
#v(-spacing)
|
||
== Загальні відомості
|
||
...
|
||
== Виклик і завантаження
|
||
...
|
||
== Призначення і логічна структура
|
||
...
|
||
== Опис фізичної моделі бази даних
|
||
...
|
||
== Опис програмної реалізації
|
||
|
||
|
||
#nheading("Висновки")
|
||
|
||
В результаті виконання курсової роботи було розроблено інформаційну систему "Репозиторій пакунків" для організації ефективної колаборації над програмними пакунками. В процесі розробки було проведено ґрунтовний аналіз предметної області, визначено ключові вимоги до системи та спроектовано оптимальну структуру бази даних для зберігання інформації про пакунки, їх версії, залежності, користувачів та їхні ролі.
|
||
|
||
Створена система забезпечує зручний інтерфейс для пошуку пакунків, управління пакунками та колаборації між розробниками. Реалізовано функціонал створення та оновлення пакунків, відстеження залежностей та взаємозв'язків між пакунками, а також систему ролей для контролю доступу.
|
||
|
||
База даних спроектована на основі реляційної моделі та нормалізована до третьої нормальної форми, що забезпечує оптимальну структуру даних та відсутність їх надлишковості. Під час розробки було використано мову програмування Rust@rust, систему управління базами даних MySQL@mysql та графічну бібліотеку iced@iced. Крім того використовуєтсья контейнеризація за допомогою Docker@docker та Docker Compose@compose що забезпечує надійність роботи системи, її масштабованість та простоту розгортання в різних середовищах.
|
||
|
||
Розроблена інформаційна система значно спрощує процес управління та отримання інформації про програмні пакунки. Вона відповідає поставленим завданням та має потенціал подальшої реалізації завдяки використанню дуже модульної архітектури моделювання програмного забеспечення, відомої як Гексагональна архітектура@hexagonal.
|