2 * Copyright (c) 2000, Red Hat, Inc.
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * A copy of the GNU General Public License can be found at
12 * Written by DJ Delorie <dj@cygnus.com>
16 /* OK, here's how this works. Each of the steps needed for install -
17 dialogs, downloads, installs - are in their own files and have some
18 "do_*" function (prototype in dialog.h) and a resource id (IDD_* or
19 IDD_S_* in resource.h) for that step. Each step is responsible for
20 selecting the next step! See the NEXT macro in dialog.h. Note
21 that the IDD_S_* ids are fake; those are for steps that don't
22 really have a controlling dialog (some have progress dialogs, but
23 those don't count, although they could). Replace the IDD_S_* with
24 IDD_* if you create a real dialog for those steps. */
27 static const char *cvsid
=
51 /* Maximum size of a SID on NT/W2K. */
52 #define MAX_SID_LEN 40
54 /* Computes the size of an ACL in relation to the number of ACEs it
56 #define TOKEN_ACL_SIZE(cnt) (sizeof(ACL) + \
57 (cnt) * (sizeof(ACCESS_ALLOWED_ACE) + MAX_SID_LEN))
59 #define iswinnt (GetVersion() < 0x80000000)
64 /* To assure that the created files have a useful ACL, the
65 default DACL in the process token is set to full access to
66 everyone. This applies to files and subdirectories created
67 in directories which don't propagate permissions to child
70 /* Create a buffer which has enough room to contain the TOKEN_DEFAULT_DACL
71 structure plus an ACL with one ACE. */
72 char buf
[sizeof (TOKEN_DEFAULT_DACL
) + TOKEN_ACL_SIZE (1)];
74 /* First initialize the TOKEN_DEFAULT_DACL structure. */
75 PTOKEN_DEFAULT_DACL dacl
= (PTOKEN_DEFAULT_DACL
) buf
;
76 dacl
->DefaultDacl
= (PACL
) (buf
+ sizeof *dacl
);
78 /* Initialize the ACL for containing one ACE. */
79 if (!InitializeAcl (dacl
->DefaultDacl
, TOKEN_ACL_SIZE (1), ACL_REVISION
))
81 log (LOG_TIMESTAMP
, "InitializeAcl() failed: %lu", GetLastError ());
85 /* Get the SID for "Everyone". */
87 SID_IDENTIFIER_AUTHORITY sid_auth
= { SECURITY_WORLD_SID_AUTHORITY
};
88 if (!AllocateAndInitializeSid (&sid_auth
, 1, 0, 0, 0, 0, 0, 0, 0, 0, &sid
))
90 log (LOG_TIMESTAMP
, "AllocateAndInitializeSid() failed: %lu",
95 /* Create the ACE which grants full access to "Everyone" and store it
96 in dacl->DefaultDacl. */
97 if (!AddAccessAllowedAce
98 (dacl
->DefaultDacl
, ACL_REVISION
, GENERIC_ALL
, sid
))
100 log (LOG_TIMESTAMP
, "AddAccessAllowedAce() failed: %lu",
105 /* Get the processes access token. */
107 if (!OpenProcessToken (GetCurrentProcess (),
108 TOKEN_READ
| TOKEN_ADJUST_DEFAULT
, &token
))
110 log (LOG_TIMESTAMP
, "OpenProcessToken() failed: %lu", GetLastError ());
114 /* Set the default DACL to the above computed ACL. */
115 if (!SetTokenInformation (token
, TokenDefaultDacl
, dacl
, sizeof buf
))
116 log (LOG_TIMESTAMP
, "OpenProcessToken() failed: %lu", GetLastError ());
118 /* Close token handle. */
122 /* Free memory occupied by the "Everyone" SID. */
127 WinMain (HINSTANCE h
,
128 HINSTANCE hPrevInstance
, LPSTR command_line
, int cmd_show
)
132 next_dialog
= IDD_SPLASH
;
134 log (LOG_TIMESTAMP
, "Starting cygwin install, version %s", version
);
137 GetCurrentDirectory (sizeof (cwd
), cwd
);
138 local_dir
= strdup (cwd
);
139 log (0, "Current Directory: %s", cwd
);
143 log (LOG_TIMESTAMP
, "Command line parameters\n");
144 for (argc
= 0, argv
= __argv
; *argv
; argv
++)
145 log (LOG_TIMESTAMP
, "%d - '%s'\n", argc
++, *argv
);
146 log (LOG_TIMESTAMP
, "%d parameters passed\n", argc
);
148 /* Set the default DACL only on NT/W2K. 9x/ME has no idea of access
149 control lists and security at all. */
196 case IDD_S_POSTINSTALL
:
207 /* Keep gcc happy :} */