1
0
mirror of https://github.com/samba-team/samba.git synced 2024-12-23 17:34:34 +03:00
https://gitlab.com/samba-team/samba is the Official GitLab mirror of https://git.samba.org/samba.git -- Merge requests should be made on GitLab (not on GitHub)
Go to file
Ralph Boehme 60e3e10e84 s3/smbd: remove flags2 FLAGS2_READ_PERMIT_EXECUTE hack in the SMB2 code
By adding a SMB2 specific CHECK_READ_SMB2 macro called that always
grants read access if execute was granted, we can get rid of the flags2
hack.

All callers in the SMB2 code are converted to use the CHECK_READ_SMB2
macro.

Amongs other things, this later allows moving the handle checks in
copychunk_check_handles() down into the VFS layer where we don't have
access to the smbreq.

Signed-off-by: Ralph Boehme <slow@samba.org>
Reviewed-by: Stefan Metzmacher <metze@samba.org>
2017-07-03 19:59:08 +02:00
auth auth/spnego: do basic state_position checking in gensec_spnego_update_in() 2017-06-29 20:15:05 +02:00
buildtools wafsamba: add maxversion and version_blacklist to CHECK_BUNDLED_SYSTEM[_PKG]() 2017-07-02 17:35:18 +02:00
coverity coverity: Add modeling file for Coverity scan 2017-02-23 07:11:18 +01:00
ctdb ctdb-tests: Add transaction/recovery test for replicated database 2017-06-29 14:43:44 +02:00
dfs_server Avoid including libds/common/roles.h in public loadparm.h header. 2016-01-13 04:43:23 +01:00
docs-xml debug: new debug class for kerberos 2017-06-30 02:12:22 +02:00
dynconfig param: Remove winbindd privileged socket directory option 2017-01-22 18:30:12 +01:00
examples s3/vfs: rename SMB_VFS_COPY_CHUNK_SEND/RECV to SMB_VFS_OFFLOAD_WRITE_SEND/RECV 2017-07-03 19:59:08 +02:00
file_server s4: Add TALLOC_CTX * to register_server_service(). 2017-05-11 20:30:13 +02:00
include
lib lib/util: add more tfork tests 2017-07-03 19:59:07 +02:00
libcli libcli/auth: pass the cleartext blob to netlogon_creds_cli_ServerPasswordSet*() 2017-06-27 16:57:46 +02:00
libds/common Avoid including libds/common/roles.h in public loadparm.h header. 2016-01-13 04:43:23 +01:00
libgpo lib: Give util_paths.c its own header 2017-06-24 01:21:10 +02:00
librpc librpc/idl: make use storage_offload_token 2017-07-03 19:59:07 +02:00
nsswitch selftest: Prime the netlogon cache during test_idmap_rfc2307 2017-07-02 21:59:18 +02:00
packaging packaging: Remove Mandrake 2017-05-10 07:35:20 +02:00
pidl pidl:NDR/Parser: add missing {start,end}_flags() to ParseElementPrint() 2017-06-27 16:57:43 +02:00
python dsdb: Add tests showing that the CN=CONFIGURATION partition is also locked 2017-07-02 17:35:20 +02:00
release-scripts release-scripts/build-manpages-nogit: run make realdistclean at the end 2015-08-17 17:43:36 +02:00
script autobuild: Use new selftest.pl feature to run only some environments 2017-06-30 02:12:22 +02:00
selftest selftest: Bind rfc2307 tests to exactly one server 2017-07-02 17:35:20 +02:00
source3 s3/smbd: remove flags2 FLAGS2_READ_PERMIT_EXECUTE hack in the SMB2 code 2017-07-03 19:59:08 +02:00
source4 s4/torture: pass destination tree to test_setup_copy_chunk 2017-07-03 19:59:07 +02:00
testdata selftest: ndr_pack/unpack performance test 2017-03-02 04:35:14 +01:00
testprogs testprogs/blackbox: don't use hardcoded values in test_net_ads_dns.sh 2017-06-13 22:46:14 +02:00
tests smbd: remove quota support for some ancient OSs 2016-03-17 01:08:32 +01:00
testsuite unittest: Add testsuite for smb_probe_module() 2017-06-06 18:36:07 +02:00
third_party third_party/dnspython: fix variable name in dnssec 2017-06-23 02:25:25 +02:00
wintest wintest: Try harder to make wintest force the telnet server to start 2014-03-14 14:51:20 +01:00
.bzrignore
.gitignore gitignore: ignore .gpg-* generated files (for ubuntu 16.04) 2017-06-15 21:40:07 +02:00
.testr.conf testr: Use waf testonly and create a custom directory for new workers. 2014-10-14 06:44:07 +02:00
.travis.yml travis-ci: Also build samba-systemkrb5 2017-06-30 02:12:22 +02:00
.ycm_extra_conf.py Update .ycm_extra_conf.py 2016-11-18 02:22:10 +01:00
BUILD_SYSTEMS.txt doc: Modify build doc concerning missing headers 2014-01-07 04:13:27 +01:00
callcatcher-exceptions.grep
configure configure: Unload the wrappers so waf configure succeeds. 2014-10-09 19:32:16 +02:00
configure.developer lib: Change socket_wrapper to preloadable version. 2014-04-17 14:56:06 +02:00
COPYING
install_with_python.sh install_with_python: Secure Python download with sha256 checks. 2015-07-24 05:19:05 +02:00
Makefile make perftest: for performance testing 2016-08-31 07:09:26 +02:00
PFIF.txt
prog_guide4.txt
README Fix little typo in README file 2015-12-04 06:08:29 +01:00
README.cifs-utils
README.Coding README.Coding: Add clang-format style file 2016-10-04 05:43:18 +02:00
README.contributing Update mailing list references to point at lists.samba.org 2015-02-10 07:08:28 +01:00
simple-dc-steps.sh dbcheck linked attribute tests: save environment with bad links 2016-07-15 10:01:30 +02:00
VERSION VERSION: Bump version up to 4.7.0pre1... 2017-01-05 09:17:41 +01:00
WHATSNEW.txt WHATSNEW: Improved AD performance (particularly linked attributes) 2017-07-03 03:59:17 +02:00
wscript wscript: Fix some typos 2017-06-06 05:26:36 +02:00
wscript_build waf: Only build pam_wrapper if we build with pam 2017-04-12 12:54:24 +02:00
wscript_build_embedded_heimdal wscript: Build the KDC code if we have the AD DC build enabled 2016-03-17 04:32:28 +01:00
wscript_build_system_heimdal wscript: Build the KDC code if we have the AD DC build enabled 2016-03-17 04:32:28 +01:00
wscript_build_system_mitkrb5
wscript_configure_system_mitkrb5 waf: Improve log errors for MIT build 2017-05-02 23:42:14 +02:00

This is the release version of Samba, the free SMB and CIFS client and
server and Domain Controller for UNIX and other operating
systems. Samba is maintained by the Samba Team, who support the
original author, Andrew Tridgell.

>>>> Please read THE WHOLE of this file as it gives important information
>>>> about the configuration and use of Samba.

NOTE: Installation instructions may be found
      for the file/print server and domain member in:
      docs/htmldocs/Samba3-HOWTO/install.html

      For the AD DC implementation a full HOWTO is provided at:
      http://wiki.samba.org/index.php/Samba4/HOWTO

This software is freely distributable under the GNU public license, a
copy of which you should have received with this software (in a file
called COPYING). 


WHAT IS SMB/CIFS?
=================

This is a big question. 

The very short answer is that it is the protocol by which a lot of
PC-related machines share files and printers and other information
such as lists of available files and printers. Operating systems that
support this natively include Windows 9x, Windows NT (and derivatives), 
OS/2, Mac OS X and Linux.  Add on packages that achieve the same 
thing are available for DOS, Windows 3.1, VMS, Unix of all kinds, 
MVS, and more.  Some Web Browsers can speak this protocol as well 
(smb://).  Alternatives to SMB include Netware, NFS, Appletalk, 
Banyan Vines, Decnet etc; many of these have advantages but none are 
both public specifications and widely implemented in desktop machines 
by default.

The Common Internet File system (CIFS) is what the new SMB initiative
is called. For details watch http://samba.org/cifs.


WHY DO PEOPLE WANT TO USE SMB?
==============================

1. Many people want to integrate their Microsoft desktop clients
   with their Unix servers.

2. Others want to integrate their Microsoft (etc) servers with Unix
   servers. This is a different problem to integrating desktop 
   clients.

3. Others want to replace protocols like NFS, DecNet and Novell NCP,
   especially when used with PCs.


WHAT CAN SAMBA DO?
==================

Please refer to the WHATSNEW.txt included with this README for
a list of features in the latest Samba release.

Here is a very short list of what samba includes, and what it does. 
For many networks this can be simply summarized by "Samba provides 
a complete replacement for Windows NT, Warp, NFS or Netware servers."

- a SMB server, to provide Windows NT and LAN Manager-style file and print 
  services to SMB clients such as Windows 95, Warp Server, smbfs and others.

- a Windows Domain Controller (NT4 and AD) replacement.

- a file/print server that can act as a member of a Windows NT 4.0
  or Active Directory domain.

- a NetBIOS (rfc1001/1002) nameserver, which amongst other things gives 
  browsing support. Samba can be the master browser on your LAN if you wish.

- a ftp-like SMB client so you can access PC resources (disks and
  printers) from UNIX, Netware, and other operating systems

- a tar extension to the client for backing up PCs

- limited command-line tool that supports some of the NT administrative
  functionality, which can be used on Samba, NT workstation and NT server.

For a much better overview have a look at the web site at
http://samba.org/samba, and browse the user survey.

Related packages include:

- cifsvfs, an advanced Linux-only filesystem allowing you to mount 
  remote SMB filesystems from PCs on your Linux box. This is included 
  as standard with Linux 2.5 and later.

- smbfs, the previous Linux-only filesystem allowing you to mount remote SMB
  filesystems from PCs on your Linux box. This is included as standard with
  Linux 2.0 and later.



CONTRIBUTIONS
=============

1. To contribute via GitHub
  - fork the official Samba team repository on GitHub
      * see https://github.com/samba-team/samba
  - become familiar with the coding standards as described in README.Coding
  - make sure you read the Samba copyright policy
      * see https://www.samba.org/samba/devel/copyright-policy.html
  - create a feature branch
  - make changes
  - when committing, be sure to add signed-off-by tags
      * see https://wiki.samba.org/index.php/CodeReview#commit_message_tags
  - send a pull request for your branch through GitHub
  - this will trigger an email to the samba-technical mailing list
  - discussion happens on the samba-technical mailing list as described below
  - more info on using Git for Samba development can be found on the Samba Wiki
      * see https://wiki.samba.org/index.php/Using_Git_for_Samba_Development

2. If you want to contribute to the development of the software then
please join the mailing list. The Samba team accepts patches
(preferably in "diff -u" format, see http://samba.org/samba/devel/ 
for more details) and are always glad to receive feedback or 
suggestions to the address samba@lists.samba.org.  More information
on the various Samba mailing lists can be found at http://lists.samba.org/.

You can also get the Samba sourcecode straight from the git repository - see
http://wiki.samba.org/index.php/Using_Git_for_Samba_Development.

If you like a particular feature then look through the git change-log
(on the web at http://gitweb.samba.org/?p=samba.git;a=summary) and see
who added it, then send them an email.

Remember that free software of this kind lives or dies by the response
we get. If no one tells us they like it then we'll probably move onto
something else.

MORE INFO
=========

DOCUMENTATION
-------------

There is quite a bit of documentation included with the package,
including man pages, and lots of .html files with hints and useful
info. This is also available from the web page. There is a growing
collection of information under docs/.

A list of Samba documentation in languages other than English is
available on the web page.

If you would like to help with the documentation, please coordinate
on the samba@samba.org mailing list.  See the next section for details 
on subscribing to samba mailing lists.


MAILING LIST
------------

Please do NOT send subscription/unsubscription requests to the lists!

There is a mailing list for discussion of Samba.  For details go to
<http://lists.samba.org/> or send mail to <samba-subscribe@lists.samba.org>

There is also an announcement mailing list where new versions are
announced.  To subscribe go to <http://lists.samba.org/> or send mail
to <samba-announce-subscribe@lists.samba.org>.  All announcements also
go to the samba list, so you only need to be on one.

For details of other Samba mailing lists and for access to archives, see
<http://lists.samba.org/>


MAILING LIST ETIQUETTE
----------------------

A few tips when submitting to this or any mailing list.

1. Make your subject short and descriptive. Avoid the words "help" or
   "Samba" in the subject. The readers of this list already know that
   a) you need help, and b) you are writing about samba (of course,
   you may need to distinguish between Samba PDC and other file
   sharing software). Avoid phrases such as "what is" and "how do
   i". Some good subject lines might look like "Slow response with
   Excel files" or "Migrating from Samba PDC to NT PDC".

2. If you include the original message in your reply, trim it so that
   only the relevant lines, enough to establish context, are
   included. Chances are (since this is a mailing list) we've already
   read the original message.

3. Trim irrelevant headers from the original message in your
   reply. All we need to see is a) From, b) Date, and c) Subject. We
   don't even really need the Subject, if you haven't changed
   it. Better yet is to just preface the original message with "On
   [date] [someone] wrote:".

4. Please don't reply to or argue about spam, spam filters or viruses
   on any Samba lists. We do have a spam filtering system that is
   working quite well thank you very much but occasionally unwanted
   messages slip through. Deal with it.

5. Never say "Me too." It doesn't help anyone solve the
   problem. Instead, if you ARE having the same problem, give more
   information. Have you seen something that the other writer hasn't
   mentioned, which may be helpful?

6. If you ask about a problem, then come up with the solution on your
   own or through another source, by all means post it. Someone else
   may have the same problem and is waiting for an answer, but never
   hears of it.

7. Give as much *relevant* information as possible such as Samba
   release number, OS, kernel version, etc...

8. RTFM. Google. groups.google.com.


WEB SITE
--------

A Samba WWW site has been setup with lots of useful info. Connect to:

http://samba.org/

As well as general information and documentation, this also has searchable 
archives of the mailing list and a user survey that shows who else is using
this package.