25 #ifdef DBUS_ENABLE_EMBEDDED_TESTS 27 #include "dbus-auth-script.h" 31 #include "dbus-auth.h" 32 #include "dbus-string.h" 33 #include "dbus-hash.h" 34 #include "dbus-credentials.h" 35 #include "dbus-internals.h" 36 #include <dbus/dbus-test-tap.h> 39 # include "dbus/dbus-userdb.h" 65 while (i < _dbus_string_get_length (quoted))
69 b = _dbus_string_get_byte (quoted, i);
110 else if (b ==
' ' || b ==
'\n' || b ==
'\t')
129 int first_a_blank, first_b_blank;
134 if (first_a_blank != first_b_blank)
141 auth_state_from_string (
const DBusString *str)
144 return DBUS_AUTH_STATE_WAITING_FOR_INPUT;
146 return DBUS_AUTH_STATE_WAITING_FOR_MEMORY;
148 return DBUS_AUTH_STATE_HAVE_BYTES_TO_SEND;
150 return DBUS_AUTH_STATE_NEED_DISCONNECT;
152 return DBUS_AUTH_STATE_AUTHENTICATED;
154 return DBUS_AUTH_STATE_INVALID;
158 auth_state_to_string (DBusAuthState state)
162 case DBUS_AUTH_STATE_WAITING_FOR_INPUT:
163 return "WAITING_FOR_INPUT";
164 case DBUS_AUTH_STATE_WAITING_FOR_MEMORY:
165 return "WAITING_FOR_MEMORY";
166 case DBUS_AUTH_STATE_HAVE_BYTES_TO_SEND:
167 return "HAVE_BYTES_TO_SEND";
168 case DBUS_AUTH_STATE_NEED_DISCONNECT:
169 return "NEED_DISCONNECT";
170 case DBUS_AUTH_STATE_AUTHENTICATED:
171 return "AUTHENTICATED";
172 case DBUS_AUTH_STATE_INVALID:
184 int i, j, k, count, end;
187 end = _dbus_string_get_length (str);
191 for (count = 0; i < end; count++)
203 for (k = 0; k < count; k++)
208 if (array[k] ==
NULL)
214 _dbus_string_get_const_data_len (str, i, j - i), j - i);
215 array[k][j - i] =
'\0';
225 auth_set_unix_credentials(
DBusAuth *auth,
232 if (credentials ==
NULL)
233 _dbus_test_fatal (
"no memory");
238 _dbus_test_fatal (
"no memory");
243 _dbus_test_fatal (
"no memory");
261 _dbus_auth_script_run (
const DBusString *filename)
297 _dbus_warn (
"Getting contents of %s failed: %s",
298 _dbus_string_get_const_data (filename), error.
message);
303 state = DBUS_AUTH_STATE_NEED_DISCONNECT;
313 _dbus_string_delete_leading_blanks (&line);
318 DBUS_AUTH_STATE_HAVE_BYTES_TO_SEND)
323 int count = _dbus_string_get_length (tmp);
326 _dbus_string_get_length (&from_auth)))
332 if (_dbus_string_get_length (&line) == 0)
354 _dbus_test_diag (
"skipping unix only auth script");
370 _dbus_test_diag (
"skipping windows only auth script");
382 _dbus_warn (
"already created a DBusAuth (CLIENT or SERVER given twice)");
408 _dbus_warn (
"no memory for setting credentials");
424 _dbus_warn (
"already created a DBusAuth (CLIENT or SERVER given twice)");
450 _dbus_warn (
"no memory for setting credentials");
461 else if (auth ==
NULL)
478 "SILLY_CREDENTIALS"))
487 _dbus_string_delete_first_word (&line);
488 mechs = split_string (&line);
497 _dbus_string_delete_first_word (&line);
505 if (!append_quoted_string (&to_send, &line))
507 _dbus_warn (
"failed to append quoted string line %d",
513 _dbus_verbose (
"Sending '%s'\n", _dbus_string_get_const_data (&to_send));
517 _dbus_warn (
"failed to append \\r\\n from line %d",
528 "USERID_HEX", &where))
561 "USERNAME_HEX", &where))
578 _dbus_warn (
"no memory to subst USERNAME_HEX");
586 _dbus_warn (
"USERNAME_HEX cannot be used on Windows");
598 buffer, _dbus_string_get_length (buffer)))
600 _dbus_warn (
"not enough memory to call bytes_received, or can't add bytes to auth object already in end state");
614 DBusAuthState expected;
616 _dbus_string_delete_first_word (&line);
618 expected = auth_state_from_string (&line);
621 _dbus_warn (
"bad auth state given to EXPECT_STATE");
625 if (expected != state)
627 _dbus_warn (
"expected auth state %s but got %s on line %d",
628 auth_state_to_string (expected),
629 auth_state_to_string (state),
639 _dbus_string_delete_first_word (&line);
643 _dbus_warn (
"no mem to allocate string received");
649 _dbus_warn (
"no line popped from the DBusAuth being tested, expected command %s on line %d",
650 _dbus_string_get_const_data (&line), line_no);
655 if (!same_first_word (&received, &line))
657 _dbus_warn (
"line %d expected command '%s' and got '%s'",
659 _dbus_string_get_const_data (&line),
660 _dbus_string_get_const_data (&received));
673 _dbus_string_delete_first_word (&line);
677 _dbus_warn (
"no mem to allocate string expected");
681 if (!append_quoted_string (&expected, &line))
683 _dbus_warn (
"failed to append quoted string line %d",
698 _dbus_warn (
"Expected unused bytes '%s' and have '%s'",
699 _dbus_string_get_const_data (&expected),
700 _dbus_string_get_const_data (unused));
706 "EXPECT_HAVE_NO_CREDENTIALS"))
713 _dbus_warn (
"Expected anonymous login or failed login, but some credentials were authorized");
718 "EXPECT_HAVE_SOME_CREDENTIALS"))
725 _dbus_warn (
"Expected to have some credentials, but we don't");
734 _dbus_string_delete_first_word (&line);
738 _dbus_warn (
"no mem to allocate string expected");
742 if (!append_quoted_string (&expected, &line))
744 _dbus_warn (
"failed to append quoted string line %d",
751 _dbus_string_get_length (&expected)))
754 _dbus_string_get_length (&expected));
759 _dbus_warn (
"Expected exact string '%s' and have '%s'",
760 _dbus_string_get_const_data (&expected),
761 _dbus_string_get_const_data (&from_auth));
773 _dbus_warn (
"couldn't process line %d \"%s\"",
774 line_no, _dbus_string_get_const_data (&line));
781 _dbus_warn (
"Auth script is bogus, did not even have CLIENT or SERVER");
784 else if (state == DBUS_AUTH_STATE_AUTHENTICATED)
790 if (_dbus_string_get_length (unused) > 0)
792 _dbus_warn (
"did not expect unused bytes (scripts must specify explicitly if they are expected)");
797 if (_dbus_string_get_length (&from_auth) > 0)
799 _dbus_warn (
"script did not have EXPECT_ statements for all the data received from the DBusAuth");
800 _dbus_warn (
"Leftover data: %s", _dbus_string_get_const_data (&from_auth));
dbus_bool_t _dbus_string_append(DBusString *str, const char *buffer)
Appends a nul-terminated C-style string to a DBusString.
const char * message
public error message field
void _dbus_auth_delete_unused_bytes(DBusAuth *auth)
Gets rid of unused bytes returned by _dbus_auth_get_unused_bytes() after we've gotten them and succes...
#define NULL
A null pointer, defined appropriately for C or C++.
void _dbus_auth_get_unused_bytes(DBusAuth *auth, const DBusString **str)
Returns leftover bytes that were not used as part of the auth conversation.
dbus_bool_t _dbus_string_equal(const DBusString *a, const DBusString *b)
Tests two DBusString for equality.
dbus_bool_t _dbus_string_hex_encode(const DBusString *source, int start, DBusString *dest, int insert_at)
Encodes a string in hex, the way MD5 and SHA-1 are usually encoded.
dbus_bool_t _dbus_string_starts_with_c_str(const DBusString *a, const char *c_str)
Checks whether a string starts with the given C string.
dbus_bool_t _dbus_auth_set_context(DBusAuth *auth, const DBusString *context)
Sets the "authentication context" which scopes cookies with the DBUS_COOKIE_SHA1 auth mechanism for e...
#define DBUS_ERROR_INIT
Expands to a suitable initializer for a DBusError on the stack.
void _dbus_auth_return_buffer(DBusAuth *auth, DBusString *buffer)
Returns a buffer with new data read into it.
DBusAuthState _dbus_auth_do_work(DBusAuth *auth)
Analyzes buffered input and moves the auth conversation forward, returning the new state of the auth ...
void dbus_error_free(DBusError *error)
Frees an error that's been set (or just initialized), then reinitializes the error as in dbus_error_i...
dbus_bool_t _dbus_file_get_contents(DBusString *str, const DBusString *filename, DBusError *error)
Appends the contents of the given file to the string, returning error code.
dbus_bool_t _dbus_auth_set_mechanisms(DBusAuth *auth, const char **mechanisms)
Sets an array of authentication mechanism names that we are willing to use.
dbus_bool_t _dbus_string_init(DBusString *str)
Initializes a string.
dbus_bool_t _dbus_string_copy(const DBusString *source, int start, DBusString *dest, int insert_at)
Like _dbus_string_move(), but does not delete the section of the source string that's copied to the d...
#define DBUS_PID_UNSET
an invalid PID used to represent an uninitialized dbus_pid_t field
dbus_bool_t _dbus_string_find(const DBusString *str, int start, const char *substr, int *found)
Finds the given substring in the string, returning TRUE and filling in the byte index where the subst...
#define DBUS_UID_UNSET
an invalid UID used to represent an uninitialized dbus_uid_t field
unsigned long dbus_pid_t
A process ID.
DBusCredentials * _dbus_auth_get_identity(DBusAuth *auth)
Gets the identity we authorized the client as.
void _dbus_auth_get_buffer(DBusAuth *auth, DBusString **buffer)
Get a buffer to be used for reading bytes from the peer we're conversing with.
void * dbus_malloc(size_t bytes)
Allocates the given number of bytes, as with standard malloc().
dbus_bool_t _dbus_append_user_from_current_process(DBusString *str)
Append to the string the identity we would like to have when we authenticate, on UNIX this is the cur...
#define dbus_new0(type, count)
Safe macro for using dbus_malloc0().
dbus_bool_t _dbus_credentials_are_anonymous(DBusCredentials *credentials)
Checks whether a credentials object contains a user identity.
void _dbus_auth_bytes_sent(DBusAuth *auth, int bytes_sent)
Notifies the auth conversation object that the given number of bytes of the outgoing buffer have been...
Internal members of DBusAuth.
dbus_uint32_t dbus_bool_t
A boolean, valid values are TRUE and FALSE.
void _dbus_string_init_const(DBusString *str, const char *value)
Initializes a constant string.
void _dbus_string_skip_blank(const DBusString *str, int start, int *end)
Skips blanks from start, storing the first non-blank in *end (blank is space or tab).
DBusCredentials * _dbus_credentials_new_from_current_process(void)
Creates a new object with the most important credentials (user ID and process ID) from the current pr...
DBusAuth * _dbus_auth_server_new(const DBusString *guid)
Creates a new auth conversation object for the server side.
dbus_bool_t _dbus_string_pop_line(DBusString *source, DBusString *dest)
Assigns a newline-terminated or \r\n-terminated line from the front of the string to the given dest s...
DBusAuth * _dbus_auth_ref(DBusAuth *auth)
Increments the refcount of an auth object.
void _dbus_warn(const char *format,...)
Prints a warning message to stderr.
void _dbus_string_delete(DBusString *str, int start, int len)
Deletes a segment of a DBusString with length len starting at start.
Object representing an exception.
dbus_bool_t _dbus_string_equal_len(const DBusString *a, const DBusString *b, int len)
Tests two DBusString for equality up to the given length.
dbus_bool_t _dbus_string_append_byte(DBusString *str, unsigned char byte)
Appends a single byte to the string, returning FALSE if not enough memory.
void _dbus_string_free(DBusString *str)
Frees a string created by _dbus_string_init(), and fills it with the same contents as #_DBUS_STRING_I...
#define TRUE
Expands to "1".
dbus_bool_t _dbus_credentials_add_pid(DBusCredentials *credentials, dbus_pid_t pid)
Add a UNIX process ID to the credentials.
dbus_bool_t _dbus_string_find_blank(const DBusString *str, int start, int *found)
Finds a blank (space or tab) in the string.
dbus_bool_t _dbus_auth_set_credentials(DBusAuth *auth, DBusCredentials *credentials)
Sets credentials received via reliable means from the operating system.
DBusCredentials * _dbus_credentials_new(void)
Creates a new credentials object.
void dbus_free_string_array(char **str_array)
Frees a NULL-terminated array of strings.
void _dbus_auth_unref(DBusAuth *auth)
Decrements the refcount of an auth object.
dbus_bool_t _dbus_auth_get_bytes_to_send(DBusAuth *auth, const DBusString **str)
Gets bytes that need to be sent to the peer we're conversing with.
void _dbus_credentials_unref(DBusCredentials *credentials)
Decrement refcount on credentials.
#define FALSE
Expands to "0".
dbus_bool_t _dbus_credentials_add_unix_uid(DBusCredentials *credentials, dbus_uid_t uid)
Add a UNIX user ID to the credentials.
unsigned long dbus_uid_t
A user ID.
DBusAuth * _dbus_auth_client_new(void)
Creates a new auth conversation object for the client side.
dbus_bool_t _dbus_username_from_current_process(const DBusString **username)
Gets username of user owning current process.