构建自己的moOde播放器

tomosak1年前HIFI1148


本文档解释了如何moOde-player从源代码构建包。

1. Pre conditions

Assumed you performing the build from a running Raspberry Pi OS bullseye.

You should have both the moode main source and the pkgbuild repo cloned.

git clone https://github.com/moode-player/moode.git
git clone https://github.com/moode-player/pkgbuild.git

For bullseye some changes are required to the moode project itself, because php is bumped from 7.3 to version 7.4 and some services had another name.

You have the following enviroment settings set:

export DEBFULLNAME=Fooexport DEBEMAIL=foo@bar.orgexport MOODE_DIR=~/yourpathto/moode

2. Building the package

2.1. Where and how to make changes to the package

The current content and actions of the package can be found it the follow two scripts:

  • pkgbuild/packages/moode-player/build.sh

  • pkgbuild/packages/moode-player/postinstall.sh

2.1.1. build.sh

This one creates the package and does the following:

  1. Responsible for what files are copied by coping the required files to a fake root dir ($PKG_ROOT_DIR).

  2. List dependencies (multiple fpm --depends argument) to be installed.

  3. Create a package (with fpm ) containing the files from the fake root dir (the fpm command on the bottom of the file)

Almost all configuration files aren't copied to /etc and /lib but to /usr/share/moode-player.

2.1.2. postinstall.sh

This one is included by the package and executed after install as part of the deb install process (fpm --after-install argument).

This file should fix things like:

  • file rights

  • disable/enable services

  • create links

  • create dir structure / touch files etc

  • update setting in files etc

  • when needed copy files /usr/share/moode-player to the correct location in /etc|/lib. This part is far from finsished.

2.1.3. Background information:

Especially the last part is far from finished. I followed for the other stuff most of mosbuild script, but not everything in the mosbuild is needed any more. (Attached it the mosbuild status, everything that is made comment is ... covered I think ;-)

A lot of the third-party packages provide now their own defaults files and or file structure (and by this not always correct for moode). But how more we can adapt to that the less painful software upgrades and migration to new distro version will become.

Package don't allow that a files is owned by two packages. That is why I copies the config files to /usr/share/moode-player. Then we can updates postinstall.sh to copy those, selective, to the correct location. Also updates to files in /etc are treated different then in other locations.

But when a config (for example because the default is already ok) is not needed we shouldn't copy it. And when possible I prefer changing (with sed or so) the default config file as opposed to replacing it. But that is only possible when a limited number of changes are required.

In case we need to 'own' an already existing file we can use the dpkg-divert command.

2.2. Build options

Default (at least it should become default, currently it is turned off see the two vars below) it also:

  1. if not already present installs npm for building the front end app

  2. installs clean required npm modules (in $MOODE_DIR/.npm_modules)

  3. build the frontend app

Step 2 and 3 can take some time.

You can change this in build.sh by changing the two vars below to 0.

# sync required npm modules for gulp buildNPM_CI=0# build web app with gulpBUILD_APP=0

2.3. Building

The build process install required dependencies the first it runs.

cd pkgbuild/packages/moode-player
./build.sh

3. Installing the moode-player package

3.1. Local Installation on a fresh running debian image

The current package is prepared to be updated or reinstalled, this will come when we have a working package. To be sure it you ar developing first remove the package:

sudo apt remove moode-player

Installation

sudo apt update
sudo apt upgrade

sudo apt install ./dist/binary/moode-player_*_armhf.deb
sudo reboot

When install

3.2. Installation from a repo on a fresh running debian image :

If the package is deployed to Cloudsmith you can installed as below:

curl -1sLf \'https://dl.cloudsmith.io/public/moodeaudio/m8y/setup.deb.sh' \| sudo -E distro=raspbian codename=bullseye bash

sudo apt update
sudo apt upgrade

sudo apt install moode-player
sudo reboot




相关文章

彻底删除.user.ini文件的方法

.user.ini是干什么的?其实这个文件是军哥LNMP一键包中的文件,根据军哥的官方解释:LNMP 1.2及更高版本防跨目录功能使用.user.ini,该文件在网站根目录下,可以修改.user.ini 里面的open_basedir的值来设置限制访问的目录或删除来移除防跨目录的设置。怎么删除?其实...

Apple电脑安装Windows双系统

安装Windows7的以下几个条件:1.关闭sip系统完整性保护:关闭方法1.开机按住command+r键不松手,直到出现苹果logo标志松手 2.选择下语言继续 3.打开实用工具-终端 4.输入 csrutil disable 让后按下回车键 5.出现如图显示...

Linux安装配置Zerotier客户端

1、在线安装└─$ curl -s https://install.zerotier.com/ | sudo bash...

kali系统常用命令汇总

1、系统命令 uname -a 查看内核/操作系统/CPU信息 head -n 1 /etc/issue 查看操作系统版本 cat /proc/cpuinfo 查看CPU信息 hostname 查看计算机名 lspci -tv 列出所有PCI设备 lsusb -tv...

Linux命令行设置时区

使用timedatectl查找当前设置的时区timedatectl输出示例:                Local time:&nbs...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。