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}