You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
A blog engine written and proven in [Coq](https://coq.inria.fr/).
2
+
> A blog engine written and proven in [Coq](https://coq.inria.fr/).
3
3
4
4
This is a demo blog engine where a user can login (no passwords), add, edit or delete posts. The code is written mostly in Coq, compiled to OCaml and linked to the [CoHTTP](https://github.com/mirage/ocaml-cohttp) library to handle the HTTP protocol.
5
5
6
6
The aim of this project is to demonstrate that applications with I/Os can be written and specified naturally using the (new) concept of [symbolic simulations in Coq](http://coq-blog.clarus.me/checking-concurrent-programs-with-symbolic-simulations.html).
7
7
8
-
## Run
9
-
Add the Coq repositories with [OPAM](https://opam.ocaml.org/):
You can now open [localhost:8008](http://localhost:8008/) to navigate the blog. Posts will be saved in the current folder. There is not password for this demo project.
22
+
23
+
To build the project by hand for development, read the build instructions from the `coq-chick-blog.opam` file.
It handles an HTTP request and generate an answer using system calls to the file system. The type `C.t A` represents a computation doing I/O operations:
34
-
35
-
Inductive t (A : Type) : Type :=
36
-
| Ret : forall (x : A), t A
37
-
| Call : forall (command : Command.t), (Command.answer command -> t A) -> t A.
32
+
```coq
33
+
Inductive t (A : Type) : Type :=
34
+
| Ret : forall (x : A), t A
35
+
| Call : forall (command : Command.t), (Command.answer command -> t A) -> t A.
36
+
```
38
37
39
38
A computation can either:
40
39
@@ -47,17 +46,21 @@ The purity of Coq ensures that each request is answered exactly once in finite t
47
46
A scenario is a set of runs of the server. A type-checking scenario shows that the server behaves as expected in a certain use case. For example, we check that when we create, edit and view a post we get the same result as what we entered. You can think of a scenario as a unit test with universally quantified variables.
48
47
49
48
Here is a simple check of the execution of the index page:
50
-
51
-
(** The index page when the list of posts is available. *)
52
-
Definition index_ok (cookies : Cookies.t) (post_headers : list Post.Header.t)
53
-
: Run.t (Main.server Path.Index cookies).
54
-
(* The handler asks the list of available posts. We return `post_headers`. *)
Given any `cookies` and `post_headers`, we execute the server handler on the page `Request.Path.Index`. The handler does exactly one system call, to which we answer `Some post_headers`, playing the role of the system. The final response of the server is then `Response.Public.Index post_headers`. Note that we do not need to execute `index_ok` on every instances of `cookies` and `post_headers`: since the type-system of Coq is supposed sound, it is enough to type-check `index_ok`.
61
61
62
62
### Privacy
63
63
We check that, for any runs of a program, an unauthenticated user cannot access private pages (like edit) or modify the file system with system calls.
64
+
65
+
## License
66
+
All the code is under the open-source MIT license.
0 commit comments