2 * Copyright (C) 2015 "IoT.bzh"
3 * Author "Fulup Ar Foll"
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
20 #include "local-def.h"
22 // With content-type=json data are directly avaliable in request->post->data
23 STATIC json_object* GetJsonByPost (AFB_request *request) {
28 // check if we have some post data
29 if (request->post == NULL) request->post->data="NoData";
31 // Get all query string [Note real app should probably use value=getQueryValue(request,"key")]
32 len = getQueryAll (request, query, sizeof(query));
33 if (len == 0) strncpy (query, "NoSearchQueryList", sizeof(query));
35 // for debug/test return response to caller
36 jresp = jsonNewMessage(AFB_SUCCESS, "GetJsonByPost query={%s} PostData: [%s]", query, request->post->data);
43 // Upload a file and execute a function when upload is done
44 STATIC json_object* UploadAppli (AFB_request *request, AFB_PostItem *item) {
46 char *destination = "applications";
48 // This is called after PostForm and then after DonePostForm
50 AFB_PostCtx *postFileCtx = getPostContext(request);
51 if (postFileCtx != NULL) {
53 // request Application Framework to install application
55 request->errcode = MHD_HTTP_OK; // or error is something went wrong;
56 request->jresp = jsonNewMessage(AFB_FAIL,"UploadFile Post Request file=[%s] done", postFileCtx->path);
60 // upload multi iteration logic is handle by getPostedFile
61 return (getPostFile (request, item, destination));
64 // Simples Upload case just upload a file
65 STATIC json_object* UploadMusic (AFB_request *request, AFB_PostItem *item) {
67 char *destination = "musics";
69 // upload multi iteration logic is handle by getPostedFile
70 return (getPostFile (request, item, destination));
73 // PostForm callback is called multiple times (one or each key within form, or once per file buffer)
74 // When file has been fully uploaded call is call with item==NULL
75 STATIC json_object* UploadImage (AFB_request *request, AFB_PostItem *item) {
77 // note if directory is relative it will be prefixed by request->config->sessiondir
78 char *destination = "images";
80 // This is called after PostForm and then after DonePostForm
82 AFB_PostCtx *postFileCtx = getPostContext(request);
84 // if postFileCtx == NULL then an error happen [getPostedFile automatically reports errors]
85 if (postFileCtx != NULL) {
86 // Do something with your newly upload filepath=postFileCtx->path
87 request->errcode = MHD_HTTP_OK;
88 request->jresp = jsonNewMessage(AFB_FAIL,"UploadFile Post Request file=[%s] done", postFileCtx->path);
90 // Note: should not return here in order getPostedFile to clear Post resources.
94 // upload multi iteration logic is handle by getPostedFile
95 return (getPostFile (request, item, destination));
99 // NOTE: this sample does not use session to keep test a basic as possible
100 // in real application upload-xxx should be protected with AFB_SESSION_CHECK
101 STATIC AFB_restapi pluginApis[]= {
102 {"ping" , AFB_SESSION_NONE , (AFB_apiCB)getPingTest ,"Ping Rest Test Service"},
103 {"upload-json" , AFB_SESSION_NONE , (AFB_apiCB)GetJsonByPost ,"Demo for Json Buffer on Post"},
104 {"upload-image" , AFB_SESSION_NONE , (AFB_apiCB)UploadImage ,"Demo for file upload"},
105 {"upload-music" , AFB_SESSION_NONE , (AFB_apiCB)UploadMusic ,"Demo for file upload"},
106 {"upload-appli" , AFB_SESSION_NONE , (AFB_apiCB)UploadAppli ,"Demo for file upload"},
110 PUBLIC AFB_plugin *pluginRegister () {
111 AFB_plugin *plugin = malloc (sizeof (AFB_plugin));
112 plugin->type = AFB_PLUGIN_JSON;
113 plugin->info = "Application Framework Binder Service";
114 plugin->prefix= "post"; // url base
115 plugin->apis = pluginApis;
116 plugin->handle= (void*) "What ever you want";