-
Notifications
You must be signed in to change notification settings - Fork 787
/
Http4sDsl.scala
69 lines (59 loc) · 2.23 KB
/
Http4sDsl.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
* Copyright 2013 http4s.org
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.http4s.dsl
import cats.arrow.FunctionK
import org.http4s.Method
import org.http4s.Uri
import org.http4s.dsl.impl._
trait Http4sDsl2[F[_], G[_]] extends RequestDsl with Statuses with Responses[F, G] {
val Path: Uri.Path.type = Uri.Path
val Root: Uri.Path.Root.type = Uri.Path.Root
val / : impl./.type = impl./
val :? : impl.:?.type = impl.:?
val ~ : impl.~.type = impl.~
val -> : impl.->.type = impl.->
val /: : impl./:.type = impl./:
val +& : impl.+&.type = impl.+&
/** Alias for `->`.
*
* Note: Due to infix operation precedence, `→` has a lower priority than `/`. So you have to use parentheses in
* pattern matching when using this operator.
*
* For example:
* {{{
* (request.method, Path(request.path)) match {
* case Method.GET → (Root / "test.json") => ...
* }}}
*/
val → : impl.->.type = impl.->
val IntVar: impl.IntVar.type = impl.IntVar
val LongVar: impl.LongVar.type = impl.LongVar
val UUIDVar: impl.UUIDVar.type = impl.UUIDVar
}
trait Http4sDsl[F[_]] extends Http4sDsl2[F, F] {
val liftG: FunctionK[F, F] = FunctionK.id[F]
}
object Http4sDsl {
// Does not return Http4sDslBinCompat for bincompat reasons. ¯\_(ツ)_/¯
def apply[F[_]]: Http4sDsl[F] with RequestDslBinCompat = new Http4sDslBinCompat[F] {}
final class MethodOps(val method: Method) extends AnyVal {
def |(another: Method) = new MethodConcat(Set(method, another))
}
final class MethodConcatOps(val methods: MethodConcat) extends AnyVal {
def |(another: Method) = new MethodConcat(methods.methods + another)
}
}
trait Http4sDslBinCompat[F[_]] extends Http4sDsl[F] with RequestDslBinCompat