libssh  0.10.1
The SSH library
misc.h
1/*
2 * This file is part of the SSH Library
3 *
4 * Copyright (c) 2009 by Aris Adamantiadis
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
21#ifndef MISC_H_
22#define MISC_H_
23
24/* in misc.c */
25/* gets the user home dir. */
26char *ssh_get_user_home_dir(void);
27char *ssh_get_local_username(void);
28int ssh_file_readaccess_ok(const char *file);
29int ssh_dir_writeable(const char *path);
30
31char *ssh_path_expand_tilde(const char *d);
32char *ssh_path_expand_escape(ssh_session session, const char *s);
33int ssh_analyze_banner(ssh_session session, int server);
34int ssh_is_ipaddr_v4(const char *str);
35int ssh_is_ipaddr(const char *str);
36
37/* list processing */
38
39struct ssh_list {
40 struct ssh_iterator *root;
41 struct ssh_iterator *end;
42};
43
45 struct ssh_iterator *next;
46 const void *data;
47};
48
50 long seconds;
51 long useconds;
52};
53
54enum ssh_quote_state_e {
55 NO_QUOTE,
56 SINGLE_QUOTE,
57 DOUBLE_QUOTE
58};
59
60struct ssh_list *ssh_list_new(void);
61void ssh_list_free(struct ssh_list *list);
62struct ssh_iterator *ssh_list_get_iterator(const struct ssh_list *list);
63struct ssh_iterator *ssh_list_find(const struct ssh_list *list, void *value);
64size_t ssh_list_count(const struct ssh_list *list);
65int ssh_list_append(struct ssh_list *list, const void *data);
66int ssh_list_prepend(struct ssh_list *list, const void *data);
67void ssh_list_remove(struct ssh_list *list, struct ssh_iterator *iterator);
68char *ssh_lowercase(const char* str);
69char *ssh_hostport(const char *host, int port);
70
71const void *_ssh_list_pop_head(struct ssh_list *list);
72
73#define ssh_iterator_value(type, iterator)\
74 ((type)((iterator)->data))
75
81#define ssh_list_pop_head(type, ssh_list)\
82 ((type)_ssh_list_pop_head(ssh_list))
83
84int ssh_make_milliseconds(unsigned long sec, unsigned long usec);
85void ssh_timestamp_init(struct ssh_timestamp *ts);
86int ssh_timeout_elapsed(struct ssh_timestamp *ts, int timeout);
87int ssh_timeout_update(struct ssh_timestamp *ts, int timeout);
88
89int ssh_match_group(const char *group, const char *object);
90
91void uint64_inc(unsigned char *counter);
92
93void ssh_log_hexdump(const char *descr, const unsigned char *what, size_t len);
94
95int ssh_mkdirs(const char *pathname, mode_t mode);
96
97int ssh_quote_file_name(const char *file_name, char *buf, size_t buf_len);
98int ssh_newline_vis(const char *string, char *buf, size_t buf_len);
99int ssh_tmpname(char *template);
100
101char *ssh_strreplace(const char *src, const char *pattern, const char *repl);
102#endif /* MISC_H_ */
void ssh_log_hexdump(const char *descr, const unsigned char *what, size_t len)
Log the content of a buffer in hexadecimal format, similar to the output of 'hexdump -C' command.
Definition: misc.c:479
int ssh_mkdirs(const char *pathname, mode_t mode)
Attempts to create a directory with the given pathname. The missing directories in the given pathname...
Definition: misc.c:1009
size_t ssh_list_count(const struct ssh_list *list)
Get the number of elements in the list.
Definition: misc.c:721
char * ssh_path_expand_tilde(const char *d)
Expand a directory starting with a tilde '~'.
Definition: misc.c:1072
int ssh_timeout_update(struct ssh_timestamp *ts, int timeout)
updates a timeout value so it reflects the remaining time
Definition: misc.c:1515
int ssh_dir_writeable(const char *path)
Check if the given path is an existing directory and that is accessible for writing.
Definition: misc.c:289
Definition: misc.h:44
Definition: misc.h:39
Definition: session.h:110
Definition: misc.h:49