Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
04b6c5de6c | |||
35a33a7ca6 | |||
862dca006b | |||
f396610305 | |||
cd9472d18a | |||
74c7d3b1bb | |||
c3330a75d9 | |||
f1c3874ed2 |
@ -1,9 +1,17 @@
|
||||
name: Build and Push Image
|
||||
on: [ push ]
|
||||
name: build and push image
|
||||
|
||||
on:
|
||||
schedule:
|
||||
- cron: '0 12 * * *'
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
paths:
|
||||
- '!README.md'
|
||||
|
||||
env:
|
||||
USERNAME: ai
|
||||
TAG: latest
|
||||
IMAGE_ID: aios
|
||||
IMAGE_NAME: ${{ gitea.repository }}
|
||||
APP_TOKEN: ${{ secrets.APP_TOKEN }}
|
||||
REGISTRY: localhost:8088
|
||||
@ -13,13 +21,14 @@ jobs:
|
||||
name: Release
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: archlinux
|
||||
image: syui/aios
|
||||
options: --privileged
|
||||
steps:
|
||||
- name: Initialize
|
||||
run: |
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git curl
|
||||
docker pull syui/aios
|
||||
docker tag syui/aios ${{ env.REGISTRY }}/${{ env.USERNAME }}/${{ env.IMAGE_NAME }}:latest
|
||||
docker tag syui/aios ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}
|
||||
echo "${{ env.APP_TOKEN }}" | docker login ${{ env.REGISTRY }} -u syui --password-stdin
|
||||
docker push ${{ env.REGISTRY }}/${{ env.USERNAME }}/${{ env.IMAGE_NAME }}:latest
|
||||
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}
|
||||
|
||||
|
8
.github/workflows/release.yml
vendored
8
.github/workflows/release.yml
vendored
@ -4,8 +4,6 @@ on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
schedule:
|
||||
- cron: "0 0 * * *"
|
||||
|
||||
permissions:
|
||||
contents: write
|
||||
@ -28,7 +26,7 @@ jobs:
|
||||
uses: actions/checkout@v4
|
||||
- name: Initialize
|
||||
run: |
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs bc
|
||||
git clone https://gitlab.archlinux.org/archlinux/archiso
|
||||
cp -rf ./cfg/profiledef.sh /usr/share/archiso/configs/releng/
|
||||
cp -rf ./cfg/profiledef.sh ./archiso/configs/releng/profiledef.sh
|
||||
@ -43,7 +41,9 @@ jobs:
|
||||
sed -i s/CheckSpace/#CheckeSpace/ root.x86_64/etc/pacman.conf
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --init'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --populate archlinux'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs docker podman'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'mkdir -p /etc/containers/registries.conf.d'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'curl -sL -o /etc/containers/registries.conf.d/ai.conf https://git.syui.ai/ai/os/raw/branch/main/cfg/ai.conf'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'chsh -s /bin/zsh'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'git clone https://git.syui.ai/ai/bot && cd bot && cargo build && cp -rf ./target/debug/ai /bin/ && ai ai'
|
||||
tar -zcvf aios-bootstrap.tar.gz root.x86_64/
|
||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +1,2 @@
|
||||
.config/ai
|
||||
**.DS_Store
|
||||
|
100
README.md
100
README.md
@ -1,34 +1,104 @@
|
||||
## ai `os`
|
||||
# <img src="./icon/ai.png" width="30"> ai `os`
|
||||
|
||||
<img src="./icon/ai.png" width="100">
|
||||
`aios` is a simple linux distribution based on `archlinux`.
|
||||
|
||||
- name : ai os
|
||||
- image : [aios-bootstrap.tar.gz](https://github.com/syui/aios/releases/tag/latest)
|
||||
- base : [archlinux](https://gitlab.archlinux.org/archlinux)
|
||||
|
||||
### docker
|
||||
|rule|var|
|
||||
|---|---|
|
||||
|name|ai os|
|
||||
|code|aios|
|
||||
|id|ai|
|
||||
|container|[git.syui.ai/ai/os](https://git.syui.ai/ai/-/packages/container/os/latest)|
|
||||
|image|[aios-bootstrap.tar.gz](https://github.com/syui/aios/releases/download/latest/aios-bootstrap.tar.gz)|
|
||||
|
||||
```sh
|
||||
$ docker run -it syui/aios ai
|
||||
$ docker run -it git.syui.ai/ai/os ai
|
||||
```
|
||||
|
||||
> Dockerfile
|
||||
## link
|
||||
|
||||
|host|command|url|
|
||||
|---|---|---|
|
||||
|docker|syui/aios|https://hub.docker.com/r/syui/aios|
|
||||
|github|ghcr.io/syui/aios|https://github.com/users/syui/packages/container/package/aios|
|
||||
|syui|git.syui.ai/ai/os|https://git.syui.ai/ai/-/packages/container/os|
|
||||
|
||||
## base
|
||||
|
||||
```sh
|
||||
FROM syui/aios
|
||||
# https://gitlab.archlinux.org/archlinux
|
||||
$ git clone https://gitlab.archlinux.org/archlinux/archiso
|
||||
```
|
||||
|
||||
- https://hub.docker.com/r/syui/aios
|
||||
|
||||
### github
|
||||
## docker
|
||||
|
||||
```sh
|
||||
# https://git.syui.ai/ai/-/packages/container/os
|
||||
$ docker run -it git.syui.ai/ai/os ai
|
||||
|
||||
# https://hub.docker.com/r/syui/aios
|
||||
$ docekr run -it syui/aios ai
|
||||
|
||||
# https://github.com/users/syui/packages/container/package/aios
|
||||
$ docker run -it ghcr.io/syui/aios ai
|
||||
```
|
||||
|
||||
- https://github.com/users/syui/packages/container/package/aios
|
||||
## token
|
||||
|
||||
### link
|
||||
|env|body|
|
||||
|---|---|
|
||||
|${{ github.repository }}|syui/aios|
|
||||
|${{ secrets.DOCKER_USERNAME }}|syui|
|
||||
|${{ secrets.DOCKER_TOKEN }}|[token](https://matsuand.github.io/docs.docker.jp.onthefly/docker-hub/access-tokens/)|
|
||||
|${{ secrets.APP_TOKEN }}|[token](https://docs.github.com/ja/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens), pacakge|
|
||||
|
||||
## podman
|
||||
|
||||
```sh
|
||||
$ podman pull aios
|
||||
|
||||
$ podman machine init
|
||||
$ podman machine start
|
||||
```
|
||||
|
||||
https://github.com/containers/shortnames
|
||||
|
||||
> /etc/containers/registries.conf.d/ai.conf
|
||||
>
|
||||
> ~/.config/containers/registries.conf
|
||||
|
||||
```sh
|
||||
unqualified-search-registries = ['docker.io', 'git.syui.ai', 'ghcr.io']
|
||||
|
||||
[aliases]
|
||||
"aios" = "git.syui.ai/ai/os"
|
||||
```
|
||||
|
||||
```sh
|
||||
$ podman pull aios
|
||||
Resolved "aios" as an alias (/etc/containers/registries.conf.d/ai.conf)
|
||||
Trying to pull git.syui.ai/ai/os:latest...
|
||||
Getting image source signatures
|
||||
Copying blob c7e55fecf0be [====================>-----------------] 917.4MiB / 1.7GiB
|
||||
```
|
||||
|
||||
## cron
|
||||
|
||||
stop
|
||||
|
||||
```sh
|
||||
schedule:
|
||||
- cron: "0 0 * * *"
|
||||
```
|
||||
|
||||
## update action
|
||||
|
||||
```sh
|
||||
$ vim build.zszh
|
||||
$ ./scpt/gh-actions.zsh
|
||||
```
|
||||
|
||||
## link
|
||||
|
||||
- https://git.syui.ai/ai/os
|
||||
- https://github.com/syui/aios
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
#!/bin/zsh
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs bc
|
||||
git clone https://gitlab.archlinux.org/archlinux/archiso
|
||||
cp -rf ./cfg/profiledef.sh /usr/share/archiso/configs/releng/
|
||||
cp -rf ./cfg/profiledef.sh ./archiso/configs/releng/profiledef.sh
|
||||
@ -14,7 +14,9 @@ Server = https://geo.mirror.pkgbuild.com/$repo/os/$arch' >> ./root.x86_64/etc/pa
|
||||
sed -i s/CheckSpace/#CheckeSpace/ root.x86_64/etc/pacman.conf
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --init'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --populate archlinux'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs docker podman'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'mkdir -p /etc/containers/registries.conf.d'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'curl -sL -o /etc/containers/registries.conf.d/ai.conf https://git.syui.ai/ai/os/raw/branch/main/cfg/ai.conf'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'chsh -s /bin/zsh'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'git clone https://git.syui.ai/ai/bot && cd bot && cargo build && cp -rf ./target/debug/ai /bin/ && ai ai'
|
||||
tar -zcvf aios-bootstrap.tar.gz root.x86_64/
|
||||
|
4
cfg/ai.conf
Normal file
4
cfg/ai.conf
Normal file
@ -0,0 +1,4 @@
|
||||
unqualified-search-registries = ['docker.io', 'git.syui.ai', 'ghcr.io']
|
||||
|
||||
[aliases]
|
||||
"aios" = "git.syui.ai/ai/os"
|
@ -4,8 +4,6 @@ on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
schedule:
|
||||
- cron: "0 0 * * *"
|
||||
|
||||
permissions:
|
||||
contents: write
|
||||
@ -28,7 +26,7 @@ jobs:
|
||||
uses: actions/checkout@v4
|
||||
- name: Initialize
|
||||
run: |
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs
|
||||
pacman -Syuu --noconfirm base-devel archiso docker git nodejs bc
|
||||
git clone https://gitlab.archlinux.org/archlinux/archiso
|
||||
cp -rf ./cfg/profiledef.sh /usr/share/archiso/configs/releng/
|
||||
cp -rf ./cfg/profiledef.sh ./archiso/configs/releng/profiledef.sh
|
||||
@ -43,7 +41,9 @@ jobs:
|
||||
sed -i s/CheckSpace/#CheckeSpace/ root.x86_64/etc/pacman.conf
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --init'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman-key --populate archlinux'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'pacman -Syu --noconfirm base base-devel linux vim git zsh rust openssh openssl jq go nodejs docker podman'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'mkdir -p /etc/containers/registries.conf.d'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'curl -sL -o /etc/containers/registries.conf.d/ai.conf https://git.syui.ai/ai/os/raw/branch/main/cfg/ai.conf'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'chsh -s /bin/zsh'
|
||||
arch-chroot root.x86_64 /bin/sh -c 'git clone https://git.syui.ai/ai/bot && cd bot && cargo build && cp -rf ./target/debug/ai /bin/ && ai ai'
|
||||
tar -zcvf aios-bootstrap.tar.gz root.x86_64/
|
||||
|
@ -9,8 +9,6 @@ on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
schedule:
|
||||
- cron: "0 0 * * *"
|
||||
|
||||
permissions:
|
||||
contents: write
|
||||
@ -69,3 +67,5 @@ echo '#!/bin/zsh' >! $dd/build.zsh
|
||||
echo $yml_b >> $dd/build.zsh
|
||||
cat $dd/build.zsh
|
||||
|
||||
cp -rf $dd/cfg/gh-actions.yml $dd/.github/workflows/release.yml
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user