mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-12 02:59:08 +00:00
net stuff
git-svn-id: https://conky.svn.sourceforge.net/svnroot/conky/trunk/conky@110 7f574dfc-610e-0410-a909-a81674777703
This commit is contained in:
parent
5968a83614
commit
30cfbc684c
6
common.c
6
common.c
@ -7,6 +7,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "conky.h"
|
#include "conky.h"
|
||||||
|
#include "remoted.h"
|
||||||
|
#include "remotec.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -176,7 +178,7 @@ void update_stuff()
|
|||||||
}
|
}
|
||||||
|
|
||||||
prepare_update();
|
prepare_update();
|
||||||
|
/* client(); this is approximately where the client should be called */
|
||||||
#define NEED(a) ((need_mask & (1 << a)) && ((info.mask & (1 << a)) == 0))
|
#define NEED(a) ((need_mask & (1 << a)) && ((info.mask & (1 << a)) == 0))
|
||||||
|
|
||||||
if (NEED(INFO_UPTIME))
|
if (NEED(INFO_UPTIME))
|
||||||
@ -229,8 +231,6 @@ void update_stuff()
|
|||||||
last_metar_update = current_update_time;
|
last_metar_update = current_update_time;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
if ((NEED(INFO_MEM) || NEED(INFO_BUFFERS)) &&
|
if ((NEED(INFO_MEM) || NEED(INFO_BUFFERS)) &&
|
||||||
current_update_time - last_meminfo_update > 6.9) {
|
current_update_time - last_meminfo_update > 6.9) {
|
||||||
update_meminfo();
|
update_meminfo();
|
||||||
|
5
conky.c
5
conky.c
@ -3,11 +3,7 @@
|
|||||||
*
|
*
|
||||||
* This program is licensed under BSD license, read COPYING
|
* This program is licensed under BSD license, read COPYING
|
||||||
*
|
*
|
||||||
<<<<<<< conky.c
|
|
||||||
* $Id$
|
* $Id$
|
||||||
=======
|
|
||||||
* $Id$
|
|
||||||
>>>>>>> 1.58
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "conky.h"
|
#include "conky.h"
|
||||||
@ -2801,6 +2797,7 @@ static void draw_string(const char *s)
|
|||||||
if (out_to_console) {
|
if (out_to_console) {
|
||||||
printf("%s\n", s);
|
printf("%s\n", s);
|
||||||
}
|
}
|
||||||
|
/* daemon_run(s); the daemon can be called here, but we need to have a buffer in daemon_run() and we need to tell it when everything is ready to be sent */
|
||||||
strcpy(tmpstring1, s);
|
strcpy(tmpstring1, s);
|
||||||
pos = 0;
|
pos = 0;
|
||||||
added = 0;
|
added = 0;
|
||||||
|
@ -427,8 +427,9 @@ char *get_freq()
|
|||||||
int i;
|
int i;
|
||||||
char *cpuspeed;
|
char *cpuspeed;
|
||||||
|
|
||||||
if ((cpuspeed = (char *) malloc(16)) == NULL)
|
if ((cpuspeed = (char *) malloc(16)) == NULL) {
|
||||||
exit(1);
|
CRIT_ERR("get_freq()");
|
||||||
|
}
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
if ((i = get_cpu_speed()) > 0) {
|
if ((i = get_cpu_speed()) > 0) {
|
||||||
|
70
ftp.c
70
ftp.c
@ -934,73 +934,3 @@ int disconnectFtp(void)
|
|||||||
ftpFd = -1;
|
ftpFd = -1;
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef STANDALONE
|
|
||||||
void ftpList(void *userData, const char *filename, const char *attrib,
|
|
||||||
const char *owner, const char *group, unsigned long size,
|
|
||||||
int links, int year, const char *month, int day, int minute)
|
|
||||||
{
|
|
||||||
printf("%s %s %s %ld %s\n", attrib, owner, group, size, filename);
|
|
||||||
}
|
|
||||||
void ftpData(void *userData, const char *data, int len)
|
|
||||||
{
|
|
||||||
if (userData == NULL)
|
|
||||||
return;
|
|
||||||
if (len <= 0) {
|
|
||||||
fclose(userData);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
fwrite(data, len, 1, userData);
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
int res;
|
|
||||||
FILE *output;
|
|
||||||
const char *tstfile = "tstfile";
|
|
||||||
|
|
||||||
initFtp();
|
|
||||||
if (argc > 1) {
|
|
||||||
res = connectFtp(argv[1], 0);
|
|
||||||
if (argc > 2)
|
|
||||||
tstfile = argv[2];
|
|
||||||
} else
|
|
||||||
res = connectFtp("localhost", 0);
|
|
||||||
if (res < 0) {
|
|
||||||
fprintf(stderr, "Couldn't connect to localhost\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
res = changeFtpDirectory("/linux");
|
|
||||||
if (res < 0) {
|
|
||||||
fprintf(stderr, "disconnected\n");
|
|
||||||
disconnectFtp();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
if (res == 0) {
|
|
||||||
fprintf(stderr, "/linux : CWD failed\n");
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "/linux : CWD successful\n");
|
|
||||||
}
|
|
||||||
res = changeFtpDirectory("/toto");
|
|
||||||
if (res < 0) {
|
|
||||||
fprintf(stderr, "disconnected\n");
|
|
||||||
disconnectFtp();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
if (res == 0) {
|
|
||||||
fprintf(stderr, "/toto : CWD failed\n");
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "/toto : CWD successful\n");
|
|
||||||
}
|
|
||||||
listFtp(ftpList, NULL);
|
|
||||||
output = fopen("/tmp/tstdata", "w");
|
|
||||||
if (output != NULL) {
|
|
||||||
if (getFtp(ftpData, (void *) output, tstfile) < 0)
|
|
||||||
fprintf(stderr, "Failed to get file %s\n",
|
|
||||||
tstfile);
|
|
||||||
|
|
||||||
}
|
|
||||||
disconnectFtp();
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
#endif /* STANDALONE */
|
|
||||||
|
@ -172,7 +172,7 @@ void update_metar()
|
|||||||
pthread_cancel(thread1);
|
pthread_cancel(thread1);
|
||||||
status = 2;
|
status = 2;
|
||||||
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
||||||
} else { /* status must be 1 */
|
} else if (status == 1) { /* status must be 1 */
|
||||||
pthread_join(thread1, NULL);
|
pthread_join(thread1, NULL);
|
||||||
status = 2;
|
status = 2;
|
||||||
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
||||||
|
56
remotec.c
56
remotec.c
@ -11,3 +11,59 @@
|
|||||||
okay, nothing here right now. thanks for coming out
|
okay, nothing here right now. thanks for coming out
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "conky.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <netdb.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
#define PORT 3490 // the port client will be connecting to
|
||||||
|
|
||||||
|
#define MAXDATASIZE 100 // max number of bytes we can get at once
|
||||||
|
|
||||||
|
void client()
|
||||||
|
{
|
||||||
|
int sockfd, numbytes;
|
||||||
|
char buf[MAXDATASIZE];
|
||||||
|
struct hostent *he;
|
||||||
|
struct sockaddr_in their_addr; // connector's address information
|
||||||
|
if ((he=gethostbyname("localhost")) == NULL) { // get the host info
|
||||||
|
perror("gethostbyname");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
|
||||||
|
perror("socket");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
their_addr.sin_family = AF_INET; // host byte order
|
||||||
|
their_addr.sin_port = htons(PORT); // short, network byte order
|
||||||
|
their_addr.sin_addr = *((struct in_addr *)he->h_addr);
|
||||||
|
memset(&(their_addr.sin_zero), '\0', 8); // zero the rest of the struct
|
||||||
|
|
||||||
|
if (connect(sockfd, (struct sockaddr *)&their_addr,
|
||||||
|
sizeof(struct sockaddr)) == -1) {
|
||||||
|
perror("connect");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((numbytes=recv(sockfd, buf, MAXDATASIZE-1, 0)) == -1) {
|
||||||
|
perror("recv");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[numbytes] = '\0';
|
||||||
|
|
||||||
|
printf("Received: %s",buf);
|
||||||
|
|
||||||
|
close(sockfd);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -11,3 +11,5 @@
|
|||||||
okay, nothing here right now. thanks for coming out
|
okay, nothing here right now. thanks for coming out
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
void client();
|
||||||
|
121
remoted.c
121
remoted.c
@ -1,39 +1,124 @@
|
|||||||
/*
|
/*
|
||||||
* Conky, a system monitor, based on torsmo
|
* Conky, a system monitor, based on torsmo
|
||||||
*
|
*
|
||||||
* This program is licensed under BSD license, read COPYING
|
* This program is licensed under BSD license, read COPYING
|
||||||
*
|
*
|
||||||
* $Id$
|
* $Id$
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
|
#include <signal.h>
|
||||||
|
|
||||||
static pthread_t daemon;
|
static pthread_t daemon_thread;
|
||||||
static int daemon_status = 0;
|
static int daemon_status = 0;
|
||||||
|
static char *data;
|
||||||
|
|
||||||
/* okay, heres how it will basically work.
|
/* okay, heres how it will basically work.
|
||||||
* when something connects, it will first send the conkyrc on the local (daemonized) server
|
* when something connects, it will first send the conkyrc on the local (daemonized) server
|
||||||
* after this, it will simply continue to send all the buffered text to the remote client
|
* after this, it will simply continue to send all the buffered text to the remote client
|
||||||
* http://analyser.oli.tudelft.nl/beej/mirror/net/html/
|
* http://analyser.oli.tudelft.nl/beej/mirror/net/html/
|
||||||
* http://www.kegel.com/c10k.html
|
* http://www.kegel.com/c10k.html
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void *daemon_thread()
|
#define MYPORT 3490 // the port users will be connecting to
|
||||||
|
|
||||||
|
#define BACKLOG 10 // how many pending connections queue will hold
|
||||||
|
|
||||||
|
void sigchld_handler(int s)
|
||||||
{
|
{
|
||||||
/* do something */
|
while(wait(NULL) > 0);
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void daemon_loop()
|
void *daemon_loop()
|
||||||
|
{
|
||||||
|
/* do something */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int sockfd, new_fd; // listen on sock_fd, new connection on new_fd
|
||||||
|
struct sockaddr_in my_addr; // my address information
|
||||||
|
struct sockaddr_in their_addr; // connector's address information
|
||||||
|
int sin_size;
|
||||||
|
struct sigaction sa;
|
||||||
|
int yes=1;
|
||||||
|
|
||||||
|
if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
|
||||||
|
perror("socket");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (setsockopt(sockfd,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(int)) == -1) {
|
||||||
|
perror("setsockopt");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
my_addr.sin_family = AF_INET; // host byte order
|
||||||
|
my_addr.sin_port = htons(MYPORT); // short, network byte order
|
||||||
|
my_addr.sin_addr.s_addr = INADDR_ANY; // automatically fill with my IP
|
||||||
|
memset(&(my_addr.sin_zero), '\0', 8); // zero the rest of the struct
|
||||||
|
|
||||||
|
if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr))
|
||||||
|
== -1) {
|
||||||
|
perror("bind");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (listen(sockfd, BACKLOG) == -1) {
|
||||||
|
perror("listen");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
sa.sa_handler = sigchld_handler; // reap all dead processes
|
||||||
|
sigemptyset(&sa.sa_mask);
|
||||||
|
sa.sa_flags = SA_RESTART;
|
||||||
|
if (sigaction(SIGCHLD, &sa, NULL) == -1) {
|
||||||
|
perror("sigaction");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
while(1) { // main accept() loop
|
||||||
|
sin_size = sizeof(struct sockaddr_in);
|
||||||
|
if ((new_fd = accept(sockfd, (struct sockaddr *)&their_addr,
|
||||||
|
&sin_size)) == -1) {
|
||||||
|
perror("accept");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
printf("server: got connection from %s\n",
|
||||||
|
inet_ntoa(their_addr.sin_addr));
|
||||||
|
if (!fork()) { // this is the child process
|
||||||
|
close(sockfd); // child doesn't need the listener
|
||||||
|
if (send(new_fd, data, 14, 0) == -1)
|
||||||
|
perror("send");
|
||||||
|
close(new_fd);
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
close(new_fd); // parent doesn't need this
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void daemon_run(const char *s)
|
||||||
{
|
{
|
||||||
/* create thread, keep an eye on it */
|
/* create thread, keep an eye on it */
|
||||||
|
data = s;
|
||||||
int iret;
|
int iret;
|
||||||
if (!daemon_status) {
|
if (!daemon_status) {
|
||||||
daemon_status = 1;
|
daemon_status = 1;
|
||||||
iret = pthread_create(&daemon, NULL, daemon_thread, NULL);
|
iret = pthread_create(&daemon_thread, NULL, daemon_loop, NULL);
|
||||||
} else if (daemon_status == 1) {
|
} else if (daemon_status == 1) {
|
||||||
/* thread is still running, we'll just wait for it to finish for now */
|
/* thread is still running, we'll just wait for it to finish for now */
|
||||||
pthread_join(daemon, NULL);
|
pthread_join(daemon_thread, NULL);
|
||||||
daemon_status = 0;
|
daemon_status = 0;
|
||||||
} else {
|
} else {
|
||||||
/* something else */
|
/* something else */
|
||||||
|
Loading…
Reference in New Issue
Block a user