Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aiursoftweb/static
Static is a simple static files HTTP server, as a global tool. Mirror of: https://gitlab.aiursoft.cn/aiursoft/static
https://github.com/aiursoftweb/static
static webserver website
Last synced: 2 months ago
JSON representation
Static is a simple static files HTTP server, as a global tool. Mirror of: https://gitlab.aiursoft.cn/aiursoft/static
- Host: GitHub
- URL: https://github.com/aiursoftweb/static
- Owner: AiursoftWeb
- License: other
- Created: 2023-08-17T08:24:56.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-09-12T07:00:39.000Z (4 months ago)
- Last Synced: 2024-09-12T16:50:48.312Z (4 months ago)
- Topics: static, webserver, website
- Language: C#
- Homepage:
- Size: 127 KB
- Stars: 3
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Aiursoft.Static
[![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)](https://gitlab.aiursoft.cn/aiursoft/static/-/blob/master/LICENSE)
[![Pipeline stat](https://gitlab.aiursoft.cn/aiursoft/static/badges/master/pipeline.svg)](https://gitlab.aiursoft.cn/aiursoft/static/-/pipelines)
[![Test Coverage](https://gitlab.aiursoft.cn/aiursoft/static/badges/master/coverage.svg)](https://gitlab.aiursoft.cn/aiursoft/static/-/pipelines)
[![NuGet version (Aiursoft.Static)](https://img.shields.io/nuget/v/Aiursoft.Static.svg)](https://www.nuget.org/packages/Aiursoft.Static/)
[![ManHours](https://manhours.aiursoft.cn/r/gitlab.aiursoft.cn/aiursoft/Static.svg)](https://gitlab.aiursoft.cn/aiursoft/Static/-/commits/master?ref_type=heads)
[![Docker](https://img.shields.io/badge/docker-latest-blue?logo=docker)](https://hub.aiursoft.cn/#!/taglist/aiursoft/static)Static is a simple static files HTTP server, as a global tool.
## Install
Requirements:
1. [.NET 8 SDK](http://dot.net/)
Run the following command to install this tool:
```bash
dotnet tool install --global Aiursoft.Static
```## Usage
After getting the binary, run it directly in the terminal.
```bash
$ static.exe --help
Description:
Start a static file server.Usage:
static [options]Options:
-p, --port The port to listen for the server. [default: 8080]
--path The folder to start the server. [default: .]
--allow-directory-browsing Allow directory browsing the server files under the path. This options if conflict with --mirror. [default: False]
--mirror The website to mirror. Automatically proxy the file if the file is not found in the server. This option if conflict with --allow-directory-browsing.
--cache-mirror Cache the mirrored files. This will save the mirrored files to the servers disk. [default: True]
--enable-webdav Enable WebDAV for the server. This is a read-only WebDAV server. [default: False]
--version Show version information
-?, -h, --help Show help and usage informationIt will start an HTTP server on http://localhost:8080.
```## Install for all users
You can install this tool for all users by running the following command:
```bash
sudo apt install -y dotnet8
sudo dotnet tool install Aiursoft.Static --tool-path /opt/static || sudo dotnet tool update Aiursoft.Static --tool-path /opt/static
sudo chmod +x /opt/static/static
```Then you can run the tool by `/opt/static/static`.
## Install for systemd
You can make it a systemd service by creating a file `/etc/systemd/system/static.service` with the following content:
```ini
[Unit]
Description=Serves static files for '/mnt/data' on port 48466
After=network.target
Wants=network.target# Before starting, run:
# find /mnt/data -type d -print0 | sudo xargs -0 chmod 0755
# find /mnt/data -type f -print0 | sudo xargs -0 chmod 0644
# So www-data user can read the files
# Also owner user can write to the files
[Service]
User=www-data
Type=simple
Restart=on-failure
RestartSec=5s
ExecStart=/opt/static/static --path /mnt/data -p 48466 --allow-directory-browsing
WorkingDirectory=/mnt/data
LimitNOFILE=1048576
KillSignal=SIGINT
Environment="ASPNETCORE_ENVIRONMENT=Production"
Environment="DOTNET_PRINT_TELEMETRY_MESSAGE=false"
Environment="DOTNET_CLI_TELEMETRY_OPTOUT=1"
Environment="ASPNETCORE_FORWARDEDHEADERS_ENABLED=true"[Install]
WantedBy=multi-user.target
```Then you can start the service by running:
```bash
sudo systemctl enable static
sudo systemctl start static
sudo systemctl status static
```## Run in Docker
First, install Docker [here](https://docs.docker.com/get-docker/).
Then run the following commands in a Linux shell:
```bash
image=hub.aiursoft.cn/aiursoft/static
appName=static
sudo docker pull $image
sudo docker run -d --name $appName --restart unless-stopped -p 5000:5000 -v /var/www/$appName:/data $image
```That will start a web server at `http://localhost:5000` and you can test the app.
The docker image has the following context:
| Properties | Value |
|-------------|----------------------------------------|
| Image | hub.aiursoft.cn/aiursoft/static |
| Ports | 5000 |
| Binary path | /app |
| Data path | /data |## Use Aiursoft.Static to build your own Docker image
You can use Aiursoft.Static to build your own Docker image. Here is an example of a `Dockerfile`:
Assuming that you have a React project in the current directory that can be built with `yarn build` and the output is in the `build` directory.
```Dockerfile
# ============================
# Prepare Build Environment
FROM hub.aiursoft.cn/node:21-alpine as npm-env
WORKDIR /src
COPY . .
RUN yarn
RUN yarn build# ============================
# Prepare Runtime Environment
FROM hub.aiursoft.cn/aiursoft/static
COPY --from=npm-env /src/build /data
```If you want to override the default behavior, simply add the `entrypoint` key to the service.
```Dockerfile
FROM hub.aiursoft.cn/aiursoft/static
COPY --from=npm-env /app/public /dataENTRYPOINT [ "/app/static", "--port", "5000", "--path", "/data", "--not-found-page", "/404.html" ]
```## Use Aiursoft.Static in docker-compose
You can use Aiursoft.Static in docker-compose. Here is an example of a `docker-compose.yml`:
```yaml
version: '3.7'services:
static:
image: hub.aiursoft.cn/aiursoft/static
volumes:
- your-volume:/data
```If you want to override the default behavior, simply add the `entrypoint` key to the service.
```yaml
version: '3.7'services:
static:
image: hub.aiursoft.cn/aiursoft/static
volumes:
- your-volume:/data
entrypoint: ["sh", "-c", "/app/static --port 5000 --path /data/mirror/archive.ubuntu.com --allow-directory-browsing"]
```## How to contribute
There are many ways to contribute to the project: logging bugs, submitting pull requests, reporting issues, and creating suggestions.
Even if you with push rights on the repository, you should create a personal fork and create feature branches there when you need them. This keeps the main repository clean and your workflow cruft out of sight.
We're also interested in your feedback on the future of this project. You can submit a suggestion or feature request through the issue tracker. To make this process more effective, we're asking that these include more information to help define them more clearly.