\documentclass[12pt]{article} \usepackage{euler} \usepackage[english]{babel} \usepackage{lipsum} \usepackage{multirow} \usepackage[colorlinks=true, urlcolor=blue, linkcolor=red]{hyperref} \newcounter{Chapcounter} \newcommand\showmycounter{\addtocounter{Chapcounter}{1}\themycounter} \newcommand{\chapter}[1] {{\centering \addtocounter{Chapcounter}{1} \Large \underline{\textbf{ \color{blue} Chapter \theChapcounter: ~#1}} } \addcontentsline{toc}{section}{ \color{blue} Chapter:~\theChapcounter~~ #1} } \hypersetup{colorlinks=true} \hypersetup{linkcolor=black} \title{Update PTU} \author{Gerhard Hoffmann} \date{\today} \begin{document} \maketitle % \chapter{Introduction} \section{Motivation} The two main components of a PSA are \begin{itemize} \item PTU software. \item Device controller (DC) firmware. \end{itemize} While the DC firmware is basically the same for each PSA (even for different customers), the PTU software is highly dependent on customer requirements.\par Hence, each customer is assigned an own git-repository, which will be loaded ("cloned") on the PSA when configuring the machine for the first time.\par Two special tools, the {\bf UpdateController} (a \href{https://doc.qt.io/qt-5/}{Qt} binary [{\bf \nameref{UpdateTool}}]) and the {\bf UpdateScript} (a \href{https://www.gnu.org/software/bash/manual/bash.html}{bash} script [{\bf \nameref{UpdateScript}}]), work together to finish a PSA installation.\par \section{PSA: Initial configuration} For the initial configuration, a PSA loads a customer-specific git-repository, which structure is detailed below [{\bf \nameref{repostructure}}].\par The "git clone" for the repository is done by the UpdateScript [{\bf \nameref{UpdateScript}}]. It updates the file \begin{center} \fbox{ /opt/app/tools/atbupdate/update\_log.csv } \end{center} which will be interpreted by the UpdateController [{\bf \nameref{UpdateTool}}]. The structure of [{\bf \nameref{updatelogcsv}}] is detailed below.\par Each line of update\_log.csv represents a command for the UpdateController, which will either download certain files to the DC or execute some \href{https://openwrt.org/docs/guide-user/additional-software/opkg}{opkg} commands [{\bf \nameref{opkg}}]. \section{PSA: Update} The update of a PSA is basically managed by \href{https://git-scm.com/}{git}, a free and open source distributed version control system. Like many other Version Control Systems, git has a way to fire off custom scripts when certain important actions occur, so-called \href{https://git-scm.com/book/en/v2/Customizing-Git-Git-Hooks}{hooks}. The hooks used for a PSA update are called {\bf post-checkout} and {\bf post-merge}.\par The post-checkout hook is called when checking out some branch of the customer-repository (for instance when cloning the customer repository for the first time). In contrast, the post-merge hook is called when a \href{https://www.git-scm.com/docs/git-pull}{git pull} operation has been issued (more precisely, a \href {https://www.git-scm.com/docs/git-fetch}{git-fetch} followed by a \href{https://www.git-scm.com/docs/git-merge}{git-merge}).\par Both hooks update the file [{\bf \nameref{updatelogcsv}}], which is interpreted by the UpdateController in a second step. % \chapter{Update-Tool "up\_dev\_ctrl"} \section{up\_dev\_ctrl} \label{UpdateTool} The update-tool is a Qt binary ("up\_dev\_ctrl") and called by the system-controller application. It is installed under \begin{center} \fbox{ /opt/app/tools/atbupdate/up\_dev\_ctrl } \end{center} and has two responsibilities: \begin{itemize} \item Call update-script "update\_psa". \item Update the device controller firmware. \end{itemize} \subsection{Calling the update-script "update\_psa"} The update-script "update\_psa" is about executing all git-commands necessary to clone and pull a customer repository. \newpage % \chapter{Update-Script "update\_psa"} \section{update\_psa} \label{UpdateScript} Inside of such a repository, there are at least the following directories: \begin{itemize} \item {\bf etc} \item {\bf etc/dc}\newline Contains the device controller firmware as binary file. \item {\bf etc/psa\_config}\newline Contains the printer template files (JSON). \item {\bf etc/psa\_tariff}\newline Contains the tariff files (JSON). \item {\bf etc/psa\_update}\newline Contains a single file for opkg-commands. \end{itemize} \newpage %\chapter{Annex} \section{Structure of a customer git-repository} \label{repostructure} \subsection{The post-checkout hook} TODO: checkout\_history \subsection{The post-merge hook} They are both located under the {\bf .githooks}-directory \section{update\_log.csv} \label{updatelogcsv} \begin{table}[h!] \begin{center} \caption{Initial state of update\_log.csv} \label{tab:initial_state} \begin{tabular}{llll} \textbf{Request} & \textbf{Name} & \textbf{Date} & \textbf{Status}\\ \hline \multicolumn{4}{c}{}\\ DOWNLOAD & /etc/dc/dc2c4.21.bin & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print01.json & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print02.json & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print03.json & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print04.json & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print29.json & 2023-05-01T12:00:00 & N/A\\ DOWNLOAD & /etc/psa\_config/DC2C\_print32.json & 2023-05-01T12:00:00 & N/A\\ EXECUTE & opkg update & 2023-05-01T12:00:00 & N/A\\ \end{tabular} \end{center} \end{table} \begin{table}[h!] \begin{center} \caption{State of update\_log.csv after updating} \label{tab:initial_state} \begin{tabular}{llll} \textbf{Request} & \textbf{Name} & \textbf{Date} & \textbf{Status}\\ \hline \multicolumn{4}{c}{}\\ DONE & /etc/dc/dc2c4.21.bin & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print01.json & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print02.json & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print03.json & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print04.json & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print29.json & 2023-05-01T12:00:00 & N/A\\ DONE & /etc/psa\_config/DC2C\_print32.json & 2023-05-01T12:00:00 & N/A\\ DONE & opkg update & 2023-05-01T12:00:00 & N/A\\ \end{tabular} \end{center} \end{table} \newpage \section{The package manager "opkg"} \label{opkg} \section{Known problems} \end{document}