# gohttp

## 目标

实现一个类似nginx功能的http服务器
## 功能

- 支持静态文件
- Proxy
- 支持rewrite 
- 支持TLS
- 支持端口复用

## 配置
```json
{
   "logging" :{
        "appenders": {
            "out" :{
                "type": "file",
                "options":{
                    "file": "gohttpd.log"
                }
            }
        },
        "categories": {
            "default": {
                "appenders": [ "out" ],
                "level": "debug"
            }
        }
    },
    "admin" : {
        "name": "admin",
        "port" : 8088,
        "username": "admin",
        "password": "admin",
        "directives":[
            "Set-Header Access-Control-Allow-Origin *"
        ],
        "paths": [
            {
                "path": "/",
                "root": "./adminui",
                "default": "index.html"
            }
        ]
    },
    "servers":[{
        "port" : 8080,
        "name":"test",
        "paths":[
            {
                "path": "/",
                "root": "/home/kingecg/code/gohttp/public/",
                "default": "index.html"
            },
            {
                "path": "/ws",
                "upstreams":["http://localhost:3000"],
                "directives":[
                    "HostSchemas $target",
                    "HeaderOrigin",
                    "Path /ws /",
                    "RemoveCookie token"
                ]
            }
        ]
    }] 
}
```
- logging 日志配置
- admin 管理后台配置
- servers 服务器配置

日志采用自己实现的类log4j库,目前只支持console 和file两种appeder

servers 配置

- port 端口
- name 服务器名称
- paths 路径配置
- certfile 证书文件
- keyfile 证书密钥文件
- directives 指令 针对response的指令,目前只实现了set-header


paths 配置

- path 路径
- root 根目录
- default 默认文件
- upstreams 代理地址
- directives  这里指令针对的是代理请求,有以下几种:
    - HostSchemas [$target] 代理地址
    - HeaderOrigin 代理请求时,添加Origin头
    - Path [/ws] [/] 代理请求时,重写URL路径,用第二个参数替换url中的第一个部分
    - RemoveCookie [token] 代理请求时,删除cookie中的某些字段

### 指令系统

指令系统采用了nginx的指令系统,指令的格式为:

```
指令名 参数1 参数2 ... 参数n
```
指令系统用来对特定的request/response进行处理。目前只支持:

- 返回的response中设置header
- 反向代理时,修改发送到上游服务器的请求

## Packages

### Server

RestMux 提供
- Restful API注册功能的 ServerMux
- Route
- Url路径参数解析(形如:/user/:id)
- 中间件
- server管理

### model
提供模型定义

### admin
管理后台api

### handler

目录 handler

提供文件和代理两种handler
其中proxy handler 提供简单的负载均衡和会话粘滞功能

## 构建

```bash
make clean && make build
```
在target目录下生成可执行文件

## 运行

```bash
./gohttpd
```