summaryrefslogtreecommitdiff
path: root/tests/dbupload2.ur
blob: 428f24609e78e547b4cc0fa86a493ce7e874d726 (plain)
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
table t : { Id : int, Blob : blob, MimeType : string }
sequence s

fun getImage id : transaction page =
    r <- oneRow1 (SELECT t.Blob, t.MimeType
                  FROM t
                  WHERE t.Id = {[id]});
    returnBlob r.Blob (blessMime r.MimeType)

fun handle (r : {File:file, Param:string}) =
    id <- nextval s;
    dml (INSERT INTO t (Id, Blob, MimeType)
         VALUES ({[id]}, {[fileData r.File]}, {[fileMimeType r.File]}));
    debug ("Text is " ^ r.Param);
    main ()

and main () : transaction page =
    x <- queryX1 (SELECT t.Id FROM t)
                 (fn r => <xml><img src={url (getImage r.Id)}/>
</xml>);
    return <xml><body>
      <form>
      <upload{#File}/>
      <textbox{#Param} value="text"/>
      <submit action={handle}/>
      </form>
      <hr/>
      {x}
    </body></xml>