s3-librpc Rename and rework cli_rpc_pipe_open_ntlmssp() to be generic
[ira/wip.git] / source3 / rpc_client / init_samr.c
index db8f4aa37f71a988e738038495302b59796af409..e3bb3015c26194176a0a3b847ca9c61ad11b090e 100644 (file)
  */
 
 #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);
-}
-