summaryrefslogtreecommitdiff
path: root/provider/download-provider-socket.c
diff options
context:
space:
mode:
authorjk7744.park <jk7744.park@samsung.com>2015-02-01 14:10:33 +0900
committerjk7744.park <jk7744.park@samsung.com>2015-02-01 14:10:33 +0900
commitd7efab678d65d5ea8c470d328427f24f4d683af9 (patch)
tree184c76feb27d8056dd39823d7b998fdf1681c80e /provider/download-provider-socket.c
parent335597a2db0a33a96684c052e4cf8a0736918fcf (diff)
downloaddownload-provider-tizen_2.3.tar.gz
download-provider-tizen_2.3.tar.bz2
download-provider-tizen_2.3.zip
Diffstat (limited to 'provider/download-provider-socket.c')
-rwxr-xr-xprovider/download-provider-socket.c351
1 files changed, 0 insertions, 351 deletions
diff --git a/provider/download-provider-socket.c b/provider/download-provider-socket.c
deleted file mode 100755
index 7feabf8..0000000
--- a/provider/download-provider-socket.c
+++ /dev/null
@@ -1,351 +0,0 @@
-/*
- * Copyright (c) 2012 Samsung Electronics Co., Ltd All Rights Reserved
- *
- * Licensed under the Apache License, Version 2.0 (the License);
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an AS IS BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-
-#include <pthread.h>
-
-#include <time.h>
-#include <sys/time.h>
-
-#include <sys/socket.h>
-#include <sys/un.h>
-#include <sys/stat.h>
-#include <systemd/sd-daemon.h>
-#include <signal.h>
-
-#include "download-provider.h"
-#include "download-provider-log.h"
-#include "download-provider-socket.h"
-
-//////////////////////////////////////////////////////////////////////////
-/// @brief write the error to socket
-/// @return if success, return 0
-int dp_ipc_send_errorcode(int fd, dp_error_type errorcode)
-{
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return -1;
- }
-
- if (fd >= 0 && write(fd, &errorcode, sizeof(dp_error_type)) <= 0) {
- TRACE_STRERROR("[ERROR] write FD[%d]", fd);
- return -1;
- }
- return 0;
-}
-
-//////////////////////////////////////////////////////////////////////////
-/// @brief write the progressinfo to socket
-/// @return if success, return 0
-int dp_ipc_send_event(int fd, int id, dp_state_type state,
- dp_error_type errorcode, unsigned long long received_size)
-{
- if (fd < 0) {
- TRACE_ERROR("[ERROR][%d] CHECK FD[%d]", id, fd);
- return -1;
- }
-
- dp_event_info eventinfo;
- eventinfo.id = id;
- eventinfo.state = state;
- eventinfo.err = errorcode;
- eventinfo.received_size = received_size;
-
- // write
- if (fd >= 0 && write(fd, &eventinfo, sizeof(dp_event_info)) <= 0) {
- TRACE_STRERROR("[ERROR][%d] write FD[%d]", id, fd);
- return -1;
- }
- return 0;
-}
-
-// keep the order/ unsigned , str
-char *dp_ipc_read_string(int fd)
-{
- unsigned length = 0;
- size_t recv_size = 0;
- unsigned remain_size = 0;
- size_t buffer_size = 0;
- char *str = NULL;
-
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return NULL;
- }
-
- // read flexible URL from client.
- ssize_t recv_bytes = read(fd, &length, sizeof(unsigned));
- if (recv_bytes < 0) {
- TRACE_STRERROR("[ERROR] read FD[%d] length[%d]", fd, length);
- return NULL;
- }
- if (length < 1 || length > DP_MAX_URL_LEN) {
- TRACE_ERROR("[STRING LEGNTH] [%d]", length);
- return NULL;
- }
- str = (char *)calloc((length + 1), sizeof(char));
- if (str == NULL) {
- TRACE_STRERROR("[ERROR] calloc length:%d FD[%d]", length, fd);
- return NULL;
- }
- remain_size = length;
- do {
- buffer_size = 0;
- if (remain_size > DP_DEFAULT_BUFFER_SIZE)
- buffer_size = DP_DEFAULT_BUFFER_SIZE;
- else
- buffer_size = remain_size;
- recv_size = (size_t)read(fd, str + (int)(length - remain_size),
- buffer_size * sizeof(char));
- if (recv_size > DP_DEFAULT_BUFFER_SIZE) {
- recv_size = -1;
- break;
- }
- if (recv_size > 0)
- remain_size = remain_size - (unsigned)recv_size;
- } while (recv_size > 0 && remain_size > 0);
-
- if (recv_size == 0) {
- TRACE_STRERROR("[ERROR] closed peer:%d", fd);
- free(str);
- return NULL;
- }
- str[length] = '\0';
- return str;
-}
-
-
-// 0 : Socket Error
-// -1 : Invalid type
-unsigned dp_ipc_read_bundle(int fd, int *type, bundle_raw **b)
-{
- unsigned length = 0;
- size_t recv_size = 0;
- unsigned remain_size = 0;
- size_t buffer_size = 0;
- bundle_raw *b_raw = NULL;
-
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return 0;
- }
-
- // read flexible URL from client.
- ssize_t recv_bytes = read(fd, type, sizeof(int));
- if (recv_bytes < 0) {
- TRACE_STRERROR("[ERROR] read FD[%d] type[%d]", fd, type);
- return 0;
- }
- if ((*type) != DP_NOTIFICATION_BUNDLE_TYPE_ONGOING &&
- (*type) != DP_NOTIFICATION_BUNDLE_TYPE_COMPLETE &&
- (*type) != DP_NOTIFICATION_BUNDLE_TYPE_FAILED) {
- TRACE_ERROR("[NOTI TYPE] [%d]", *type);
- return -1;
- }
- // read flexible URL from client.
- recv_bytes = read(fd, &length, sizeof(unsigned));
- if (recv_bytes < 0) {
- TRACE_STRERROR("[ERROR] read FD[%d] length[%d]", fd, length);
- return 0;
- }
- if (length < 1 || length > DP_MAX_URL_LEN) {
- TRACE_ERROR("[STRING LEGNTH] [%d]", length);
- return 0;
- }
- b_raw = (bundle_raw *)calloc(length, 1);
- if (b_raw == NULL) {
- TRACE_STRERROR("[ERROR] calloc length:%d FD[%d]", length, fd);
- return 0;
- }
- remain_size = length;
- do {
- buffer_size = 0;
- if (remain_size > DP_DEFAULT_BUFFER_SIZE)
- buffer_size = DP_DEFAULT_BUFFER_SIZE;
- else
- buffer_size = remain_size;
- recv_size = (size_t)read(fd, b_raw + (int)(length - remain_size),
- buffer_size * sizeof(char));
- if (recv_size > DP_DEFAULT_BUFFER_SIZE) {
- recv_size = -1;
- break;
- }
- if (recv_size > 0)
- remain_size = remain_size - (unsigned)recv_size;
- } while (recv_size > 0 && remain_size > 0);
-
- if (recv_size <= 0) {
- TRACE_STRERROR("[ERROR] closed peer:%d", fd);
- bundle_free_encoded_rawdata(&b_raw);
- return 0;
- }
- *b = b_raw;
- return length;
-}
-
-// keep the order/ unsigned , str
-int dp_ipc_send_string(int fd, const char *str)
-{
- unsigned length = 0;
-
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return -1;
- }
- if (str == NULL) {
- TRACE_ERROR("[ERROR] CHECK STRING FD[%d]", fd);
- return -1;
- }
-
- length = strlen(str);
- if (length < 1) {
- TRACE_ERROR("[ERROR] CHECK LENGTH FD[%d]", fd);
- return -1;
- }
- if (fd >= 0 && write(fd, &length, sizeof(unsigned)) <= 0) {
- TRACE_STRERROR("[ERROR] read FD[%d] length[%d]", fd, length);
- return -1;
- }
- if (fd >= 0 && write(fd, str, length * sizeof(char)) <= 0) {
- TRACE_STRERROR("[ERROR] write FD[%d]", fd);
- return -1;
- }
- return 0;
-}
-
-int dp_ipc_send_bundle(int fd, bundle_raw *b, unsigned length)
-{
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return -1;
- }
- if (b == NULL) {
- TRACE_ERROR("[ERROR] CHECK STRING FD[%d]", fd);
- return -1;
- }
-
- if (length < 1) {
- TRACE_ERROR("[ERROR] CHECK LENGTH FD[%d]", fd);
- return -1;
- }
- if (fd >= 0 && write(fd, &length, sizeof(unsigned)) <= 0) {
- TRACE_STRERROR("[ERROR] read FD[%d] length[%d]", fd, length);
- return -1;
- }
- if (fd >= 0 && write(fd, b, length) <= 0) {
- TRACE_STRERROR("[ERROR] write FD[%d]", fd);
- return -1;
- }
- return 0;
-}
-
-int dp_ipc_send_custom_type(int fd, void *value, size_t type_size)
-{
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return -1;
- }
- if (value == NULL) {
- TRACE_ERROR("[ERROR] CHECK VALUE FD[%d]", fd);
- return -1;
- }
- if (fd >= 0 && write(fd, value, type_size) <= 0) {
- TRACE_STRERROR("[ERROR] write FD[%d]", fd);
- return -1;
- }
- return 0;
-}
-
-int dp_ipc_read_custom_type(int fd, void *value, size_t type_size)
-{
- if (fd < 0) {
- TRACE_ERROR("[ERROR] CHECK FD[%d]", fd);
- return -1;
- }
- if (value == NULL) {
- TRACE_ERROR("[ERROR] CHECK VALUE FD[%d]", fd);
- return -1;
- }
-
- ssize_t recv_bytes = read(fd, value, type_size);
- if (recv_bytes < 0) {
- TRACE_STRERROR("[ERROR] read FD[%d]", fd);
- return -1;
- }
- return 0;
-}
-
-int dp_accept_socket_new()
-{
- int sockfd = -1;
- struct sockaddr_un listenaddr;
-
- int n = sd_listen_fds(1);
- if (n > 1) {
- TRACE_STRERROR("too many file descriptors received");
- return -1;
- } else if (n == 1) {
- int r;
- if ((r = sd_is_socket_unix(SD_LISTEN_FDS_START, SOCK_STREAM, 1, DP_IPC, 0)) <= 0) {
- TRACE_STRERROR("passed systemd file descriptor is of wrong type");
- return -1;
- }
- sockfd = SD_LISTEN_FDS_START + 0;
- } else {
- if ((sockfd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) {
- TRACE_STRERROR("failed to create socket");
- return -1;
- }
-
- bzero(&listenaddr, sizeof(listenaddr));
- listenaddr.sun_family = AF_UNIX;
- strcpy(listenaddr.sun_path, DP_IPC);
-
- if (bind(sockfd, (struct sockaddr *)&listenaddr, sizeof listenaddr) !=
- 0) {
- TRACE_STRERROR("[CRITICAL] bind");
- close(sockfd);
- return -1;
- }
-
- if (chmod(listenaddr.sun_path, 0777) < 0) {
- TRACE_STRERROR("[CRITICAL] chmod");
- close(sockfd);
- return -1;
- }
-
- // need 3 socket per a group
- if (listen(sockfd, DP_MAX_GROUP * 3) != 0) {
- TRACE_STRERROR("[CRITICAL] listen");
- close(sockfd);
- return -1;
- }
- }
- return sockfd;
-}
-
-int dp_socket_free(int sockfd)
-{
- TRACE_DEBUG("[%d]", sockfd);
- if (sockfd < 0)
- return -1;
- shutdown(sockfd, 0);
- close(sockfd);
- return 0;
-}