• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 #include "param_message.h"
16 
17 #include <sys/socket.h>
18 #include <sys/un.h>
19 
20 #include "param_utils.h"
21 #include "securec.h"
22 
ConnectServer(int fd,const char * servername)23 int ConnectServer(int fd, const char *servername)
24 {
25     PARAM_CHECK(fd >= 0, return -1, "Invalid fd %d", fd);
26     PARAM_CHECK(servername != NULL, return -1, "Invalid servername");
27     int opt = 1;
28     int ret = setsockopt(fd, SOL_SOCKET, SO_PASSCRED, &opt, sizeof(opt));
29     PARAM_CHECK(ret == 0, return -1, "Failed to set socket option");
30     struct sockaddr_un addr;
31     /* fill socket address structure with server's address */
32     ret = memset_s(&addr, sizeof(addr), 0, sizeof(addr));
33     PARAM_CHECK(ret == 0, return -1, "Failed to memset server address");
34     addr.sun_family = AF_UNIX;
35     ret = sprintf_s(addr.sun_path, sizeof(addr.sun_path) - 1, "%s", servername);
36     PARAM_CHECK(ret > EOK, return -1, "Failed to sprintf_s server address");
37     socklen_t len = offsetof(struct sockaddr_un, sun_path) + strlen(addr.sun_path);
38     ret = connect(fd, (struct sockaddr *)&addr, len);
39     PARAM_CHECK(ret != -1, return -1, "Failed to connect server %s %d", servername, errno);
40     PARAM_LOGV("ConnectServer %s success", servername);
41     return 0;
42 }
43 
FillParamMsgContent(const ParamMessage * request,uint32_t * start,int type,const char * value,uint32_t length)44 int FillParamMsgContent(const ParamMessage *request, uint32_t *start, int type, const char *value, uint32_t length)
45 {
46     PARAM_CHECK(request != NULL && start != NULL, return -1, "Invalid param");
47     PARAM_CHECK(value != NULL && length > 0 && length < PARAM_BUFFER_MAX, return -1, "Invalid value");
48     uint32_t bufferSize = request->msgSize - sizeof(ParamMessage);
49     uint32_t offset = *start;
50     PARAM_CHECK((offset + sizeof(ParamMsgContent) + length) <= bufferSize,
51         return -1, "Invalid msgSize %u offset %u %d", request->msgSize, offset, type);
52     ParamMsgContent *content = (ParamMsgContent *)(request->data + offset);
53     content->type = type;
54     content->contentSize = length + 1;
55     int ret = memcpy_s(content->content, content->contentSize - 1, value, length);
56     PARAM_CHECK(ret == EOK, return -1, "Failed to copy value for %d", type);
57     content->content[length] = '\0';
58     offset += sizeof(ParamMsgContent) + PARAM_ALIGN(content->contentSize);
59     *start = offset;
60     return 0;
61 }
62 
CreateParamMessage(int type,const char * name,uint32_t msgSize)63 ParamMessage *CreateParamMessage(int type, const char *name, uint32_t msgSize)
64 {
65     PARAM_CHECK(name != NULL, return NULL, "Invalid name");
66     uint32_t size = msgSize;
67     if (msgSize < sizeof(ParamMessage)) {
68         size = sizeof(ParamMessage);
69     }
70     ParamMessage *msg = (ParamMessage *)calloc(1, size);
71     PARAM_CHECK(msg != NULL, return NULL, "Failed to malloc message");
72     msg->type = type;
73     msg->id.msgId = 0;
74     msg->msgSize = size;
75     int ret = strcpy_s(msg->key, sizeof(msg->key) - 1, name);
76     PARAM_CHECK(ret == EOK, free(msg);
77         return NULL, "Failed to fill name");
78     return msg;
79 }
80 
GetNextContent(const ParamMessage * reqest,uint32_t * offset)81 ParamMsgContent *GetNextContent(const ParamMessage *reqest, uint32_t *offset)
82 {
83     PARAM_CHECK(reqest != NULL, return NULL, "Invalid reqest");
84     PARAM_CHECK(offset != NULL, return NULL, "Invalid offset");
85     ParamMessage *msg = (ParamMessage *)reqest;
86     if ((msg == NULL) || ((*offset + sizeof(ParamMessage) + sizeof(ParamMsgContent)) >= msg->msgSize)) {
87         return NULL;
88     }
89     ParamMsgContent *content = (ParamMsgContent *)(msg->data + *offset);
90     *offset += sizeof(ParamMsgContent) + PARAM_ALIGN(content->contentSize);
91     return content;
92 }
93