1d9f0492fSopenharmony_ci/*
2d9f0492fSopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3d9f0492fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4d9f0492fSopenharmony_ci * you may not use this file except in compliance with the License.
5d9f0492fSopenharmony_ci * You may obtain a copy of the License at
6d9f0492fSopenharmony_ci *
7d9f0492fSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8d9f0492fSopenharmony_ci *
9d9f0492fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10d9f0492fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11d9f0492fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12d9f0492fSopenharmony_ci * See the License for the specific language governing permissions and
13d9f0492fSopenharmony_ci * limitations under the License.
14d9f0492fSopenharmony_ci */
15d9f0492fSopenharmony_ci#include <errno.h>
16d9f0492fSopenharmony_ci#include <string.h>
17d9f0492fSopenharmony_ci#include <sys/socket.h>
18d9f0492fSopenharmony_ci#include <sys/un.h>
19d9f0492fSopenharmony_ci#include <unistd.h>
20d9f0492fSopenharmony_ci#include "init_log.h"
21d9f0492fSopenharmony_ci#include "init_socket.h"
22d9f0492fSopenharmony_ci#include "securec.h"
23d9f0492fSopenharmony_ci
24d9f0492fSopenharmony_ci#define BUFFER_LENGTH 15
25d9f0492fSopenharmony_ci#define ARG_COUNT 2
26d9f0492fSopenharmony_ci
27d9f0492fSopenharmony_ciint main(int argc, char* argv[])
28d9f0492fSopenharmony_ci{
29d9f0492fSopenharmony_ci    if (argc < ARG_COUNT) {
30d9f0492fSopenharmony_ci        INIT_LOGE("Client need an argument");
31d9f0492fSopenharmony_ci        return 0;
32d9f0492fSopenharmony_ci    }
33d9f0492fSopenharmony_ci    int sockFd = socket(PF_UNIX, SOCK_DGRAM, 0);
34d9f0492fSopenharmony_ci    if (sockFd < 0) {
35d9f0492fSopenharmony_ci        INIT_LOGE("Failed to create client socket");
36d9f0492fSopenharmony_ci        return -1;
37d9f0492fSopenharmony_ci    }
38d9f0492fSopenharmony_ci    struct sockaddr_un addr;
39d9f0492fSopenharmony_ci    bzero(&addr, sizeof(struct sockaddr_un));
40d9f0492fSopenharmony_ci    addr.sun_family = PF_UNIX;
41d9f0492fSopenharmony_ci    size_t addrLen = sizeof(addr.sun_path);
42d9f0492fSopenharmony_ci    int ret = 0;
43d9f0492fSopenharmony_ci    if (strcmp(argv[1], "server") == 0) {
44d9f0492fSopenharmony_ci        ret = snprintf_s(addr.sun_path, addrLen, addrLen - 1, "/dev/unix/socket/serversock");
45d9f0492fSopenharmony_ci        INIT_ERROR_CHECK(ret >= 0, return -1, "Failed to format addr");
46d9f0492fSopenharmony_ci        if (connect(sockFd, (struct sockaddr *)&addr, sizeof(addr))) {
47d9f0492fSopenharmony_ci            INIT_LOGE("Failed to connect socket: %d", errno);
48d9f0492fSopenharmony_ci            close(sockFd);
49d9f0492fSopenharmony_ci            return -1;
50d9f0492fSopenharmony_ci        }
51d9f0492fSopenharmony_ci    } else {
52d9f0492fSopenharmony_ci        INIT_LOGE("input error, invalid server name");
53d9f0492fSopenharmony_ci        close(sockFd);
54d9f0492fSopenharmony_ci        return -1;
55d9f0492fSopenharmony_ci    }
56d9f0492fSopenharmony_ci    ret = write(sockFd, argv[ARG_COUNT], strlen(argv[ARG_COUNT]));
57d9f0492fSopenharmony_ci    if (ret < 0) {
58d9f0492fSopenharmony_ci        INIT_LOGE("Failed to write, errno = %d", errno);
59d9f0492fSopenharmony_ci    }
60d9f0492fSopenharmony_ci    close(sockFd);
61d9f0492fSopenharmony_ci    return 0;
62d9f0492fSopenharmony_ci}