kemal/CHANGELOG.md

346 lines
11 KiB
Markdown
Raw Normal View History

2018-11-04 23:27:44 +00:00
# 0.25.0 (05-10-2018)
- Crystal 0.27.0 support.
- *[breaking change]* Added back `env.params.files`.
Here's a fully working sample for reading a image file upload `image1` and saving it under `public/uploads`.
```crystal
post "/upload" do |env|
file = env.params.files["image1"].tmpfile
file_path = ::File.join [Kemal.config.public_folder, "uploads/", file.filename]
File.open(file_path, "w") do |f|
IO.copy(file, f)
end
"Upload ok"
end
```
To test
`curl -F "image1=@/Users/serdar/Downloads/kemal.png" http://localhost:3000/upload`
- Cache HTTP routes to increase performance :rocket: https://github.com/kemalcr/kemal/pull/493
2018-08-14 11:17:26 +00:00
# 0.24.0 (14-08-2018)
2018-07-04 19:04:22 +00:00
- *[breaking change]* Removed `env.params.files`. You can use Crystal's built-in `HTTP::FormData.parse` instead
```ruby
2018-07-04 19:04:22 +00:00
post "/upload" do |env|
HTTP::FormData.parse(env.request) do |upload|
filename = file.filename
if !filename.is_a?(String)
"No filename included in upload"
else
file_path = ::File.join [Kemal.config.public_folder, "uploads/", filename]
File.open(file_path, "w") do |f|
IO.copy(file.tmpfile, f)
end
"Upload OK"
end
end
```
2018-08-14 11:17:26 +00:00
- *[breaking change]* From now on to access dynamic url params in a WebSocket route you have to use:
2018-07-04 19:04:22 +00:00
```ruby
ws "/:id" do |socket, context|
id = context.ws_route_lookup.params["id"]
end
```
2018-08-14 11:17:26 +00:00
- *[breaking change]* Removed `_method` magic param.
- Added new exception page [#466](https://github.com/kemalcr/kemal/pull/466). Thanks @mamantoha 🙏
- Support custom port binding. Thanks @straight-shoota 🙏
```ruby
Kemal.run do |config|
server = config.server.not_nil!
server.bind_tcp "127.0.0.1", 3000, reuse_port: true
server.bind_tcp "0.0.0.0", 3001, reuse_port: true
end
```
2018-07-04 19:04:22 +00:00
2018-06-17 16:17:19 +00:00
# 0.23.0 (17-06-2018)
- Crystal 0.25.0 support 🎉
- Add `Kemal::Context.get?` to safely access context storage :sunglasses:
- [Security] Don't serve 404 image dynamically :thumbsup:
2018-06-17 16:19:01 +00:00
- Disable `X-Powered-By` header [#449](https://github.com/kemalcr/kemal/pull/449). Thanks @Blacksmoke16 🙏
2018-06-17 16:17:19 +00:00
2017-12-29 12:23:06 +00:00
# 0.22.0 (29-12-2017)
- Crystal 0.24.1 support 🎉
- Only return string from route.[#408](https://github.com/kemalcr/kemal/pull/408) thanks @crisward 🙏
- Don't crash on empty path when compiled in --release. [#407](https://github.com/kemalcr/kemal/pull/407) thanks @crisward 🙏
- Rename `Kemal::CommonLogHandler` to `Kemal::LogHandler` and `Kemal::CommonExceptionHandler` to `Kemal::ExceptionHandler`.
- Allow videos to be opened with correct mime type. [#406](https://github.com/kemalcr/kemal/pull/406) thanks @crisward 🙏
2018-11-04 23:27:44 +00:00
- Add webm mime type.[#413](https://github.com/kemalcr/kemal/pull/413) thanks @reindeer-cafe 🙏
2017-12-29 12:23:06 +00:00
2017-09-05 09:15:00 +00:00
# 0.21.0 (05-09-2017)
2017-08-23 22:05:19 +00:00
2017-09-05 09:15:00 +00:00
- Dynamically insert handlers :muscle: Fixes [#376](https://github.com/kemalcr/kemal/pull/376).
- Add context to WebSocket. This allows one to use `HTTP::Server::Context` in `ws` declarations :heart_eyes: Fixes [#349](https://github.com/kemalcr/kemal/pull/349).
2017-08-23 22:05:19 +00:00
```ruby
ws "/:room_name" do |socket, env|
env.params.url["room_name"]
end
```
2017-09-05 09:15:00 +00:00
- Add support for customizing the headers of built-in `Kemal::StaticFileHandler` :hammer: Useful for supporting `CORS` for single page applications :clap:
2017-08-23 22:05:19 +00:00
```ruby
static_headers do |response, filepath, filestat|
if filepath =~ /\.html$/
response.headers.add("Access-Control-Allow-Origin", "*")
end
response.headers.add("Content-Size", filestat.size.to_s)
end
end
```
2017-09-05 09:15:00 +00:00
- Allow %w in Handler macros [#385](https://github.com/kemalcr/kemal/pull/385). Thanks @will :pray:
- Security: X-Content-Type-Options: nosniff for static files. Fixes [#379](https://github.com/kemalcr/kemal/issues/379). Thanks @crisward :pray:
- Performance: [Remove tempfile management to OS](https://github.com/kemalcr/kemal/commit/a1520de7ed3865fa73258343a80fad4f20666a99). This brings %10 - 15 performance boost to Kemal :rocket:
2017-07-01 19:02:09 +00:00
# 0.20.0 (01-07-2017)
2017-05-14 01:39:11 +00:00
2017-07-01 19:17:30 +00:00
- Crystal 0.23.0 support! As always, Kemal is compatible with the latest major release of Crystal 💎
2017-07-01 19:12:36 +00:00
- Great news everyone 🎉 All handlers are now completely ***customizable***!. Use the default `Kemal` handlers or go wild, it's all up to you ⛏
2017-05-14 01:39:11 +00:00
```ruby
2017-07-01 19:12:36 +00:00
# Don't forget to add `Kemal::RouteHandler::INSTANCE` or your routes won't work!
2017-05-14 01:39:11 +00:00
Kemal.config.handlers = [Kemal::InitHandler.new, YourHandler.new, Kemal::RouteHandler::INSTANCE]
```
2017-07-01 19:12:36 +00:00
You can also insert a handler into a specific position.
2017-07-01 19:02:09 +00:00
```ruby
# This adds MyCustomHandler instance to 1 position. Be aware that the index starts from 0.
add_handler MyCustomHandler.new, 1
```
2017-07-01 19:03:17 +00:00
- Updated [Kilt](https://github.com/jeromegn/kilt) to v0.4.0.
2017-07-01 19:04:27 +00:00
- Make `Route` a `Struct`. This improves the performance of route declarations.
2017-07-01 19:02:09 +00:00
2017-05-09 08:00:31 +00:00
# 0.19.0 (09-05-2017)
- Return no body for head route fixes #323. (thanks @crisward)
- Update `radix` to `0.3.8`. (thanks @waghanza)
- User defined context store types. (thanks @neovitange)
```ruby
class User
property name
end
add_context_storage_type(User)
```
- Prevent `send_file returning filesize. (thanks @crisward)
- Dont call setup in `config#add_filter_handler` fixes #338.
2017-03-07 16:51:30 +00:00
# 0.18.3 (07-03-2017)
- Remove `Gzip::Header` monkey patch since it's fixed in `Crystal 0.21.1`.
2017-02-24 07:30:09 +00:00
# 0.18.2 (24-02-2017)
- Fix [Gzip in Kemal Seems broken for static files](https://github.com/kemalcr/kemal/issues/316). This was caused by `Gzip::Writer` in `Crystal 0.21.0` and currently mitigated by monkey patching `Gzip::Header`.
2017-02-21 19:29:13 +00:00
# 0.18.1 (21-02-2017)
- Crystal 0.21.0 support
- Drop `multipart.cr` dependency. `multipart` support is now built-into Crystal <3
- Since Crystal 0.21.0 comes built-in with `multipart` there are some improvements and deprecations.
`meta` has been removed from `FileUpload` and it has the following properties
+ `tmpfile`: This is temporary file for file upload. Useful for saving the upload file.
+ `filename`: File name of the file upload. (logo.png, images.zip e.g)
+ `headers`: Headers for the file upload.
+ `creation_time`: Creation time of the file upload.
+ `modification_time`: Last Modification time of the file upload.
+ `read_time`: Read time of the file upload.
+ `size`: Size of the file upload.
2017-02-21 19:29:13 +00:00
# 0.18.0 (11-02-2017)
2017-02-11 13:54:19 +00:00
- Simpler file upload. File uploads can now be access from `HTTP::Server::Context` like `env.params.files["filename"]`.
`env.params.files["filename"]` has 5 methods
- `tmpfile`: This is temporary file for file upload. Useful for saving the upload file.
- `tmpfile_path`: File path of `tmpfile`.
- `filename`: File name of the file upload. (logo.png, images.zip e.g)
- `meta`: Meta information for the file upload.
- `headers`: Headers for the file upload.
Here's a fully working sample for reading a image file upload `image1` and saving it under `public/uploads`.
```crystal
post "/upload" do |env|
file = env.params.files["image1"].tmpfile
file_path = ::File.join [Kemal.config.public_folder, "uploads/", file.filename]
File.open(file_path, "w") do |f|
IO.copy(file, f)
end
"Upload ok"
end
```
To test
`curl -F "image1=@/Users/serdar/Downloads/kemal.png" http://localhost:3000/upload`
- RF7233 support a.k.a file streaming. (https://github.com/kemalcr/kemal/pull/299) (thanks @denysvitali)
- Update Radix to 0.3.7. Fixes https://github.com/kemalcr/kemal/issues/293
- Configurable startup / shutdown logging. https://github.com/kemalcr/kemal/issues/291 and https://github.com/kemalcr/kemal/issues/292 (thanks @twisterghost).
2017-02-21 19:29:13 +00:00
# 0.17.5 (09-01-2017)
2017-02-11 13:54:19 +00:00
- Update multipart.cr to 0.1.2. Fixes #285 related to multipart.cr
2016-12-24 11:45:17 +00:00
# 0.17.4 (24-12-2016)
2016-12-10 10:02:31 +00:00
2016-12-24 11:45:17 +00:00
- Support for Crystal 0.20.3
2016-12-10 10:02:31 +00:00
- Add `Kemal.stop`. Fixes #269.
2016-12-24 11:45:17 +00:00
- `HTTP::Handler` is not a class anymore, it's a module. See https://github.com/crystal-lang/crystal/releases/tag/0.20.3
2016-12-10 10:02:31 +00:00
2016-12-03 14:37:58 +00:00
# 0.17.3 (03-12-2016)
- Handle missing 404 image. Fixes #263
- Remove basic auth middleware from core and move to [kemalcr/kemal-basic-auth](https://github.com/kemalcr/kemal-basic-auth).
2016-11-25 14:40:00 +00:00
# 0.17.2 (25-11-2016)
- Use body.gets_to_end for parse_json. Fixes #260.
2016-11-25 14:41:07 +00:00
- Update Radix to 0.3.5 and lock pessimistically. (thanks @luislavena)
2016-11-25 14:40:00 +00:00
2016-11-24 09:30:27 +00:00
# 0.17.1 (24-11-2016)
- Treat `HTTP::Request` body as an `IO`. Fixes [#257](https://github.com/sdogruyol/kemal/issues/257)
2016-11-23 17:47:13 +00:00
# 0.17.0 (23-11-2016)
2016-10-28 09:37:11 +00:00
2017-12-29 12:23:06 +00:00
- Reimplemented Request middleware / filter routing.
2016-10-28 09:37:11 +00:00
Now all requests will first go through the Middleware stack then Filters (before_*) and will finally reach the matching route.
Which is illustrated as,
```
Request -> Middleware -> Filter -> Route
```
- Rename `return_with` as `halt`.
- Route declaration must start with `/`. Fixes [#242](https://github.com/sdogruyol/kemal/issues/242)
2016-11-06 08:59:17 +00:00
- Set default exception Content-Type to text/html. Fixes [#202](https://github.com/sdogruyol/kemal/issues/242)
2017-12-29 12:23:06 +00:00
- Add `only` and `exclude` paths for `Kemal::Handler`. This change requires that all handlers must inherit from `Kemal::Handler`.
2016-11-09 16:17:29 +00:00
For example this handler will only work on `/` path. By default the HTTP method is `GET`.
```crystal
class OnlyHandler < Kemal::Handler
2016-11-09 16:17:29 +00:00
only ["/"]
2017-12-29 12:23:06 +00:00
2016-11-09 16:17:29 +00:00
def call(env)
return call_next(env) unless only_match?(env)
puts "If the path is / i will be doing some processing here."
end
end
```
The handlers using `exclude` will work on the paths that isn't specified. For example this handler will work on any routes other than `/`.
```crystal
class ExcludeHandler < Kemal::Handler
2016-11-09 16:17:29 +00:00
exclude ["/"]
2017-12-29 12:23:06 +00:00
2016-11-09 16:17:29 +00:00
def call(env)
return call_next(env) unless only_match?(env)
puts "If the path is NOT / i will be doing some processing here."
end
end
```
2016-11-12 18:30:01 +00:00
- Close response on `halt`. (thanks @samueleaton).
- Update `Radix` to `v0.3.4`.
2016-11-16 17:27:01 +00:00
- `error` handler now also yields error. For example you can get the error mesasage like
```crystal
error 500 do |env, err|
err.message
end
```
2016-11-23 17:47:13 +00:00
- Update `multipart.cr` to `v0.1.1`
2016-10-12 13:56:40 +00:00
# 0.16.1 (12-10-2016)
- Improved Multipart support with more info on parsed files. `parse_multipart(env)` now yields
2017-12-29 12:23:06 +00:00
an `UploadFile` object which has the following properties `field`,`data`,`meta`,`headers.
2016-10-12 13:56:40 +00:00
```crystal
post "/upload" do |env|
parse_multipart(env) do |f|
image1 = f.data if f.field == "image1"
image2 = f.data if f.field == "image2"
puts f.meta
puts f.headers
"Upload complete"
end
end
2016-10-20 14:21:37 +00:00
```
2016-10-12 13:56:40 +00:00
2016-10-01 15:50:24 +00:00
# 0.16.0
2016-09-15 18:20:18 +00:00
2016-10-01 15:50:24 +00:00
- Multipart support <3 (thanks @RX14). Now you can handle file uploads.
2017-12-29 12:23:06 +00:00
2016-10-02 15:33:28 +00:00
```crystal
post "/upload" do |env|
parse_multipart(env) do |field, data|
image1 = data if field == "image1"
image2 = data if field == "image2"
"Upload complete"
end
end
```
2016-10-02 15:33:28 +00:00
2016-10-01 15:50:24 +00:00
- Make session configurable. Now you can specify session name and expire time wit
2016-10-02 15:33:28 +00:00
```crystal
Kemal.config.session["name"] = "your_app"
Kemal.config.session["expire_time"] = 48.hours
```
2016-10-01 15:50:24 +00:00
- Session now supports more types. (String, Int32, Float64, Bool)
2016-09-15 18:20:18 +00:00
- Add `gzip` helper to enable / disable gzip compression on responses.
2016-09-20 23:32:09 +00:00
- Static file caching with etag and gzip (thanks @crisward)
- `Kemal.run` now accepts port to listen.
2016-09-15 18:20:18 +00:00
2016-10-12 13:56:40 +00:00
# 0.15.1 (05-09-2016)
2016-09-15 18:20:18 +00:00
- Don't forget to call_next on NullLogHandler
2016-09-03 14:14:22 +00:00
# 0.15.0 (03-09-2016)
2016-09-02 12:21:42 +00:00
2016-09-02 14:12:34 +00:00
- Add context store
- `KEMAL_ENV` respects to `Kemal.config.env` and needs to be explicitly set.
- `Kemal::InitHandler` is introduced. Adds initial configuration, headers like `X-Powered-By`.
- Add `send_file` to helpers.
- Add mime types.
- Fix parsing JSON params when "charset" is present in "Content-Type" header.
2017-12-29 12:23:06 +00:00
- Use http-only cookie for session
2016-10-20 14:21:37 +00:00
- Inject STDOUT by default in CommonLogHandler