Compare commits
22 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3b28d2328a | |||
| 68add3b228 | |||
| 8ec6c7652a | |||
| fc542ba388 | |||
| b32f59b708 | |||
| c4bd93992d | |||
| 22c9217059 | |||
| 77450f38f1 | |||
| c949c75f28 | |||
| 1c4ff9231b | |||
| 0d2a4a6c68 | |||
| c27cf3d3e8 | |||
| e968c718af | |||
| 612cf4b9ed | |||
| 2bf58a419b | |||
| 7931aa73a6 | |||
| 4d4f08c762 | |||
| 13ddeae596 | |||
| e76b9f5a90 | |||
| 0dbb4e047d | |||
| 8bf93e2c30 | |||
| 1fb7988ff8 |
65
.drone.yml
65
.drone.yml
@@ -10,7 +10,7 @@ steps:
|
||||
- name: clone-repo
|
||||
image: alpine/git:latest
|
||||
commands:
|
||||
- git clone https://gitea.akshun-lab.uk/akshun/python-setup.git /artifacts
|
||||
- git clone https://gitea.akshun-lab.cc/aggarwalakshun/python-setup.git /artifacts
|
||||
volumes:
|
||||
- name: artifacts
|
||||
path: /artifacts
|
||||
@@ -61,59 +61,32 @@ steps:
|
||||
path: /artifacts
|
||||
|
||||
- name: upload-artifacts
|
||||
image: alpine/curl:latest
|
||||
image: alpine:latest
|
||||
depends_on: [arch-build, debian-build, fedora-build]
|
||||
commands:
|
||||
- apk add --no-cache curl jq
|
||||
- apk add jq curl
|
||||
- |
|
||||
if [ -z "$GITEA_TOKEN" ] || [ -z "$GITEA_SERVER" ]; then
|
||||
echo "Error: GITEA_TOKEN or GITEA_SERVER not set"
|
||||
exit 1
|
||||
fi
|
||||
# Get the latest release information
|
||||
RELEASE_INFO=$(curl -s "https://gitea.akshun-lab.cc/api/v1/repos/aggarwalakshun/python-setup/releases/latest")
|
||||
LATEST_TAG=$(echo "$RELEASE_INFO" | jq -r '.tag_name')
|
||||
RELEASE_ID=$(echo "$RELEASE_INFO" | jq -r '.id')
|
||||
|
||||
echo "Latest tag: $LATEST_TAG"
|
||||
echo "Release ID: $RELEASE_ID"
|
||||
|
||||
REPO_PATH="${DRONE_REPO:-akshun/python-script}"
|
||||
|
||||
if [ -n "${DRONE_TAG}" ]; then
|
||||
echo "Creating release for tag ${DRONE_TAG}"
|
||||
response=$(curl -s -X POST \
|
||||
for file in /artifacts/*-setup; do
|
||||
FILENAME=$(basename "$file")
|
||||
echo "Uploading $FILENAME..."
|
||||
|
||||
# Use the release ID instead of tag name in the URL
|
||||
curl -X POST "https://gitea.akshun-lab.cc/api/v1/repos/aggarwalakshun/python-setup/releases/$RELEASE_ID/assets?name=$FILENAME" \
|
||||
-H "Authorization: token $GITEA_TOKEN" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"tag_name": "'"${DRONE_TAG}"'", "name": "'"${DRONE_TAG}"'", "body": "Automated release"}' \
|
||||
"$GITEA_SERVER/api/v1/repos/$REPO_PATH/releases")
|
||||
release_id=$(echo "$response" | jq -r '.id')
|
||||
else
|
||||
echo "Using latest release"
|
||||
response=$(curl -s -H "Authorization: token $GITEA_TOKEN" \
|
||||
"$GITEA_SERVER/api/v1/repos/$REPO_PATH/releases/latest" || echo "")
|
||||
|
||||
if [ -z "$response" ] || [ "$(echo "$response" | jq -r '.id')" = "null" ]; then
|
||||
echo "Creating new draft release"
|
||||
response=$(curl -s -X POST \
|
||||
-H "Authorization: token $GITEA_TOKEN" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"tag_name": "continuous", "name": "Continuous Build", "draft": true, "body": "Automated continuous build"}' \
|
||||
"$GITEA_SERVER/api/v1/repos/$REPO_PATH/releases")
|
||||
fi
|
||||
|
||||
release_id=$(echo "$response" | jq -r '.id')
|
||||
fi
|
||||
|
||||
for artifact in /artifacts/*-setup; do
|
||||
if [ -f "$artifact" ]; then
|
||||
filename=$(basename "$artifact")
|
||||
echo "Uploading $filename"
|
||||
curl -X POST \
|
||||
-H "Authorization: token $GITEA_TOKEN" \
|
||||
-H "Content-Type: multipart/form-data" \
|
||||
-F "attachment=@$artifact" \
|
||||
"$GITEA_SERVER/api/v1/repos/$REPO_PATH/releases/$release_id/assets?name=$filename"
|
||||
fi
|
||||
-H "Content-Type: application/octet-stream" \
|
||||
--data-binary @"$file"
|
||||
done
|
||||
environment:
|
||||
GITEA_TOKEN:
|
||||
from_secret: gitea-token
|
||||
GITEA_SERVER:
|
||||
from_secret: gitea-server
|
||||
from_secret: GITEA_TOKEN
|
||||
volumes:
|
||||
- name: artifacts
|
||||
path: /artifacts
|
||||
|
||||
76
.gitea/workflows/release.yml
Normal file
76
.gitea/workflows/release.yml
Normal file
@@ -0,0 +1,76 @@
|
||||
name: Multi Distro Build
|
||||
|
||||
on: workflow_dispatch
|
||||
|
||||
jobs:
|
||||
arch-build:
|
||||
runs-on: ubuntu-latest
|
||||
container: archlinux:latest
|
||||
steps:
|
||||
- name: Install node
|
||||
run: pacman -Syu --noconfirm nodejs npm
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
pacman -S --noconfirm git python python-pip binutils
|
||||
mv /lib/python3*/EXTERNALLY-MANAGED /tmp/
|
||||
pip install --upgrade pip
|
||||
pip install pyinstaller inquirerpy distro
|
||||
- name: Build binary
|
||||
run: |
|
||||
pyinstaller --onefile --add-data "data/:data/" setup.py
|
||||
cp dist/setup arch-setup
|
||||
shell: bash
|
||||
- name: Release binary
|
||||
uses: akkuman/gitea-release-action@v1
|
||||
with:
|
||||
files: |-
|
||||
arch-setup
|
||||
|
||||
debian-build:
|
||||
runs-on: ubuntu-latest
|
||||
container: debian:stable-slim
|
||||
steps:
|
||||
- name: Install node
|
||||
run: apt-get update && apt-get upgrade -y && apt-get install -y nodejs npm
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
apt-get install -y git python3 python3-pip binutils
|
||||
mv /usr/lib/python*/EXTERNALLY-MANAGED /tmp/
|
||||
pip install pyinstaller inquirerpy distro
|
||||
- name: Build binary
|
||||
run: |
|
||||
pyinstaller --onefile --add-data "data/:data/" setup.py
|
||||
cp dist/setup debian-setup
|
||||
shell: bash
|
||||
- name: Release binary
|
||||
uses: akkuman/gitea-release-action@v1
|
||||
with:
|
||||
files: |-
|
||||
debian-setup
|
||||
|
||||
fedora-build:
|
||||
runs-on: ubuntu-latest
|
||||
container: fedora:latest
|
||||
steps:
|
||||
- name: Install node
|
||||
run: dnf up -y && dnf install -y nodejs npm
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
dnf install -y git python python-pip binutils
|
||||
pip install inquirerpy distro pyinstaller
|
||||
- name: Build binary
|
||||
run: |
|
||||
pyinstaller --onefile --add-data "data/:data/" setup.py
|
||||
cp dist/setup fedora-setup
|
||||
shell: bash
|
||||
- name: Release binary
|
||||
uses: akkuman/gitea-release-action@v1
|
||||
with:
|
||||
files: |-
|
||||
fedora-setup
|
||||
45
setup.py
45
setup.py
@@ -289,6 +289,47 @@ def install_other():
|
||||
selected_other = menu2
|
||||
|
||||
for other in selected_other:
|
||||
os.system(f"bash {dir}data/scripts/third-party/" + other + ".sh")
|
||||
os.system(f"bash {dir}data/scripts/" + other + ".sh")
|
||||
|
||||
menu()
|
||||
def handle_arguments():
|
||||
arguments = sys.argv[1:]
|
||||
if not arguments:
|
||||
menu()
|
||||
else:
|
||||
if len(arguments) >= 2 and arguments[0] == "install":
|
||||
if arguments[1] == "--system":
|
||||
selected_items = arguments[2:]
|
||||
if selected_items:
|
||||
os.system(f"sudo dnf install -y {' '.join(selected_items)}")
|
||||
else:
|
||||
print("No packages specified for system install.")
|
||||
elif arguments[1] == "--flatpak":
|
||||
if which("flatpak") is None:
|
||||
print("Flatpak is not installed. Install Flatpak? (y/n)")
|
||||
choice = input()
|
||||
if choice == "y":
|
||||
os.system("sudo dnf install flatpak -y")
|
||||
os.system("flatpak remote-add --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo")
|
||||
else:
|
||||
print("Exiting...")
|
||||
sys.exit(0)
|
||||
selected_items = arguments[2:]
|
||||
if selected_items:
|
||||
os.system(f"flatpak install flathub {' '.join(selected_items)} -y")
|
||||
else:
|
||||
print("No packages specified for flatpak install.")
|
||||
elif arguments[1] == "--drivers" and len(arguments) >= 3:
|
||||
if arguments[2] == "nvidia":
|
||||
os.system("sudo dnf install akmod-nvidia")
|
||||
elif arguments[2] == "amd":
|
||||
os.system("sudo dnf install mesa-dri-drivers")
|
||||
elif arguments[2] == "intel":
|
||||
os.system("sudo dnf install intel-media-driver")
|
||||
else:
|
||||
print("Unknown driver specified.")
|
||||
else:
|
||||
print("Invalid install option or missing arguments.")
|
||||
else:
|
||||
print("Unknown command or missing arguments.")
|
||||
|
||||
handle_arguments()
|
||||
|
||||
Reference in New Issue
Block a user