*/
#include "includes.h"
+#include "../libcli/auth/libcli_auth.h"
+#include "../lib/crypto/md5.h"
+#include "../lib/crypto/arcfour.h"
+#include "rpc_client/init_samr.h"
-/*******************************************************************
- inits a structure.
-********************************************************************/
+/*************************************************************************
+ inits a samr_CryptPasswordEx structure
+ *************************************************************************/
-static void init_lsa_String(struct lsa_String *name, const char *s)
+void init_samr_CryptPasswordEx(const char *pwd,
+ DATA_BLOB *session_key,
+ struct samr_CryptPasswordEx *pwd_buf)
{
- name->string = s;
-}
+ /* samr_CryptPasswordEx */
-/*******************************************************************
- inits a structure.
-********************************************************************/
+ uchar pwbuf[532];
+ struct MD5Context md5_ctx;
+ uint8_t confounder[16];
+ DATA_BLOB confounded_session_key = data_blob(NULL, 16);
-void init_samr_DomInfo1(struct samr_DomInfo1 *r,
- uint16_t min_password_length,
- uint16_t password_history_length,
- uint32_t password_properties,
- int64_t max_password_age,
- int64_t min_password_age)
-{
- r->min_password_length = min_password_length;
- r->password_history_length = password_history_length;
- r->password_properties = password_properties;
- r->max_password_age = max_password_age;
- r->min_password_age = min_password_age;
-}
+ encode_pw_buffer(pwbuf, pwd, STR_UNICODE);
-/*******************************************************************
- inits a structure.
-********************************************************************/
+ generate_random_buffer((uint8_t *)confounder, 16);
-void init_samr_DomInfo2(struct samr_DomInfo2 *r,
- NTTIME force_logoff_time,
- const char *comment,
- const char *domain_name,
- const char *primary,
- uint64_t sequence_num,
- uint32_t unknown2,
- enum samr_Role role,
- uint32_t unknown3,
- uint32_t num_users,
- uint32_t num_groups,
- uint32_t num_aliases)
-{
- r->force_logoff_time = force_logoff_time;
- init_lsa_String(&r->comment, comment);
- init_lsa_String(&r->domain_name, domain_name);
- init_lsa_String(&r->primary, primary);
- r->sequence_num = sequence_num;
- r->unknown2 = unknown2;
- r->role = role;
- r->unknown3 = unknown3;
- r->num_users = num_users;
- r->num_groups = num_groups;
- r->num_aliases = num_aliases;
-}
+ MD5Init(&md5_ctx);
+ MD5Update(&md5_ctx, confounder, 16);
+ MD5Update(&md5_ctx, session_key->data,
+ session_key->length);
+ MD5Final(confounded_session_key.data, &md5_ctx);
-/*******************************************************************
- inits a structure.
-********************************************************************/
+ arcfour_crypt_blob(pwbuf, 516, &confounded_session_key);
+ memcpy(&pwbuf[516], confounder, 16);
-void init_samr_DomInfo3(struct samr_DomInfo3 *r,
- NTTIME force_logoff_time)
-{
- r->force_logoff_time = force_logoff_time;
+ memcpy(pwd_buf->data, pwbuf, sizeof(pwbuf));
+ data_blob_free(&confounded_session_key);
}
-/*******************************************************************
- inits a structure.
-********************************************************************/
+/*************************************************************************
+ inits a samr_CryptPassword structure
+ *************************************************************************/
-void init_samr_DomInfo4(struct samr_DomInfo4 *r,
- const char *comment)
+void init_samr_CryptPassword(const char *pwd,
+ DATA_BLOB *session_key,
+ struct samr_CryptPassword *pwd_buf)
{
- init_lsa_String(&r->comment, comment);
-}
+ /* samr_CryptPassword */
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo5(struct samr_DomInfo5 *r,
- const char *domain_name)
-{
- init_lsa_String(&r->domain_name, domain_name);
-}
-
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo6(struct samr_DomInfo6 *r,
- const char *primary)
-{
- init_lsa_String(&r->primary, primary);
-}
-
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo7(struct samr_DomInfo7 *r,
- enum samr_Role role)
-{
- r->role = role;
+ encode_pw_buffer(pwd_buf->data, pwd, STR_UNICODE);
+ arcfour_crypt_blob(pwd_buf->data, 516, session_key);
}
-
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo8(struct samr_DomInfo8 *r,
- uint64_t sequence_num,
- NTTIME domain_create_time)
-{
- r->sequence_num = sequence_num;
- r->domain_create_time = domain_create_time;
-}
-
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo9(struct samr_DomInfo9 *r,
- uint32_t unknown)
-{
- r->unknown = unknown;
-}
-
-/*******************************************************************
- inits a structure.
-********************************************************************/
-
-void init_samr_DomInfo12(struct samr_DomInfo12 *r,
- uint64_t lockout_duration,
- uint64_t lockout_window,
- uint16_t lockout_threshold)
-{
- r->lockout_duration = lockout_duration;
- r->lockout_window = lockout_window;
- r->lockout_threshold = lockout_threshold;
-}
-
-/*******************************************************************
- inits a samr_GroupInfoAll structure.
-********************************************************************/
-
-void init_samr_group_info1(struct samr_GroupInfoAll *r,
- const char *name,
- uint32_t attributes,
- uint32_t num_members,
- const char *description)
-{
- DEBUG(5, ("init_samr_group_info1\n"));
-
- init_lsa_String(&r->name, name);
- r->attributes = attributes;
- r->num_members = num_members;
- init_lsa_String(&r->description, description);
-}
-
-/*******************************************************************
- inits a lsa_String structure
-********************************************************************/
-
-void init_samr_group_info2(struct lsa_String *r, const char *group_name)
-{
- DEBUG(5, ("init_samr_group_info2\n"));
-
- init_lsa_String(r, group_name);
-}
-
-/*******************************************************************
- inits a samr_GroupInfoAttributes structure.
-********************************************************************/
-
-void init_samr_group_info3(struct samr_GroupInfoAttributes *r,
- uint32_t attributes)
-{
- DEBUG(5, ("init_samr_group_info3\n"));
-
- r->attributes = attributes;
-}
-
-/*******************************************************************
- inits a lsa_String structure
-********************************************************************/
-
-void init_samr_group_info4(struct lsa_String *r, const char *description)
-{
- DEBUG(5, ("init_samr_group_info4\n"));
-
- init_lsa_String(r, description);
-}
-
-/*******************************************************************
- inits a samr_GroupInfoAll structure.
-********************************************************************/
-
-void init_samr_group_info5(struct samr_GroupInfoAll *r,
- const char *name,
- uint32_t attributes,
- uint32_t num_members,
- const char *description)
-{
- DEBUG(5, ("init_samr_group_info5\n"));
-
- init_lsa_String(&r->name, name);
- r->attributes = attributes;
- r->num_members = num_members;
- init_lsa_String(&r->description, description);
-}
-
-/*******************************************************************
- inits a samr_AliasInfoAll structure.
-********************************************************************/
-
-void init_samr_alias_info1(struct samr_AliasInfoAll *r,
- const char *name,
- uint32_t num_members,
- const char *description)
-{
- DEBUG(5, ("init_samr_alias_info1\n"));
-
- init_lsa_String(&r->name, name);
- r->num_members = num_members;
- init_lsa_String(&r->description, description);
-}
-
-/*******************************************************************
-inits a lsa_String structure.
-********************************************************************/
-
-void init_samr_alias_info3(struct lsa_String *r,
- const char *description)
-{
- DEBUG(5, ("init_samr_alias_info3\n"));
-
- init_lsa_String(r, description);
-}
-