Compare commits
8 Commits
c949c75f28
...
v4
| Author | SHA1 | Date | |
|---|---|---|---|
| 3b28d2328a | |||
| 68add3b228 | |||
| 8ec6c7652a | |||
| fc542ba388 | |||
| b32f59b708 | |||
| c4bd93992d | |||
| 22c9217059 | |||
| 77450f38f1 |
63
.drone.yml
63
.drone.yml
@@ -10,7 +10,7 @@ steps:
|
|||||||
- name: clone-repo
|
- name: clone-repo
|
||||||
image: alpine/git:latest
|
image: alpine/git:latest
|
||||||
commands:
|
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:
|
volumes:
|
||||||
- name: artifacts
|
- name: artifacts
|
||||||
path: /artifacts
|
path: /artifacts
|
||||||
@@ -61,59 +61,32 @@ steps:
|
|||||||
path: /artifacts
|
path: /artifacts
|
||||||
|
|
||||||
- name: upload-artifacts
|
- name: upload-artifacts
|
||||||
image: alpine/curl:latest
|
image: alpine:latest
|
||||||
depends_on: [arch-build, debian-build, fedora-build]
|
depends_on: [arch-build, debian-build, fedora-build]
|
||||||
commands:
|
commands:
|
||||||
- apk add --no-cache curl jq
|
- apk add jq curl
|
||||||
- |
|
- |
|
||||||
if [ -z "$GITEA_TOKEN" ] || [ -z "$GITEA_SERVER" ]; then
|
# Get the latest release information
|
||||||
echo "Error: GITEA_TOKEN or GITEA_SERVER not set"
|
RELEASE_INFO=$(curl -s "https://gitea.akshun-lab.cc/api/v1/repos/aggarwalakshun/python-setup/releases/latest")
|
||||||
exit 1
|
LATEST_TAG=$(echo "$RELEASE_INFO" | jq -r '.tag_name')
|
||||||
fi
|
RELEASE_ID=$(echo "$RELEASE_INFO" | jq -r '.id')
|
||||||
|
|
||||||
REPO_PATH="${DRONE_REPO:-akshun/python-script}"
|
echo "Latest tag: $LATEST_TAG"
|
||||||
|
echo "Release ID: $RELEASE_ID"
|
||||||
|
|
||||||
if [ -n "${DRONE_TAG}" ]; then
|
for file in /artifacts/*-setup; do
|
||||||
echo "Creating release for tag ${DRONE_TAG}"
|
FILENAME=$(basename "$file")
|
||||||
response=$(curl -s -X POST \
|
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 "Authorization: token $GITEA_TOKEN" \
|
||||||
-H "Content-Type: application/json" \
|
-H "Content-Type: application/octet-stream" \
|
||||||
-d '{"tag_name": "'"${DRONE_TAG}"'", "name": "'"${DRONE_TAG}"'", "body": "Automated release"}' \
|
--data-binary @"$file"
|
||||||
"$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
|
|
||||||
done
|
done
|
||||||
environment:
|
environment:
|
||||||
GITEA_TOKEN:
|
GITEA_TOKEN:
|
||||||
from_secret: gitea-token
|
from_secret: GITEA_TOKEN
|
||||||
GITEA_SERVER:
|
|
||||||
from_secret: gitea-server
|
|
||||||
volumes:
|
volumes:
|
||||||
- name: artifacts
|
- name: artifacts
|
||||||
path: /artifacts
|
path: /artifacts
|
||||||
|
|||||||
45
setup.py
45
setup.py
@@ -289,6 +289,47 @@ def install_other():
|
|||||||
selected_other = menu2
|
selected_other = menu2
|
||||||
|
|
||||||
for other in selected_other:
|
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