Adoptable Cookbooks List

Looking for a cookbook to adopt? You can now see a list of cookbooks available for adoption!
List of Adoptable Cookbooks

Supermarket Belongs to the Community

Supermarket belongs to the community. While Chef has the responsibility to keep it running and be stewards of its functionality, what it does and how it works is driven by the community. The chef/supermarket repository will continue to be where development of the Supermarket application takes place. Come be part of shaping the direction of Supermarket by opening issues and pull requests or by joining us on the Chef Mailing List.

Select Badges

Select Supported Platforms

Select Status


samba (35) Versions 0.13.0

Installs/Configures samba

cookbook 'samba', '= 0.13.0', :supermarket
cookbook 'samba', '= 0.13.0'
knife supermarket install samba
knife supermarket download samba
Quality 67%


Installs and configures Samba version 3.


Assumes Samba version 3.

Should work on Debian-family, Red Hat-family and ArchLinux systems.

Uses Chef Server for data bag to build configuration file shares. Chef Zero should work as long as data bags are set up per Usage below.

Requires a users data bag for the users when the password backend is not LDAP. If using the users cookbook, this already needs to exist, though a password needs to be specified for Samba.


Does not (yet) integrate with LDAP/AD.

Uses plaintext passwords for the user data bag entry to create the SMB users if the password backend is tdbsam or smbpasswd. See below under usage.

Does not modify the Samba daemons to launch (i.e., ArchLinux's /etc/conf.d/samba SAMBA_DAMONS).

Samba 4 may work with or without modification.


The attributes are used to set up the default values in the smb.conf, and set default locations used in the recipe. Where appropriate, the attributes use the default values in Samba.

  • node["samba"]["workgroup"] - The SMB workgroup to use, default "SAMBA".
  • node["samba"]["interfaces"] - Interfaces to listen on, default "lo".
  • node["samba"]["hosts_allow"] - Allowed hosts/networks, default "".
  • node["samba"]["bind_interfaces_only"] - Limit interfaces to serve SMB, default "no"
  • node["samba"]["server_string"] - Server string value, default "Samba Server".
  • node["samba"]["load_printers"] - Whether to load printers, default "no".
  • node["samba"]["passdb_backend"] - Which password backend to use, default "tdbsam".
  • node["samba"]["dns_proxy"] - Whether to search NetBIOS names through DNS, default "no".
  • node["samba"]["security"] - Samba security mode, default "user".
  • node["samba"]["map_to_guest"] - What Samba should do with logins that don't match Unix users, default "Bad User".
  • node["samba"]["socket_options"] - Socket options, default "TCP_NODELAY"
  • node["samba"]["config"] - Location of Samba configuration, default "/etc/samba/smb.conf".
  • node["samba"]["log_dir"] - Location of Samba logs, default "/var/log/samba/%m.log".
  • node["samba"]["shares_data_bag"] - the name of the data bag that contains the shares information, default "samba". See Usage below.
  • node["samba"]["users_data_bag"] - the name of the data bag that contains user details, default "users". See Usage below.
  • node["samba"]["options"] - the list of additional options, default {'unix charset' => 'UTF8'}. (optional)



Installs smbclient to provide access to SMB shares.


Includes the client recipe by default.


Sets up a Samba server. See "Usage" below for more information.


This cookbook includes a resource/provider for managing samba users with the smbpasswd program.

samba_user "jtimberman" do
  password "plaintextpassword"
  action [:create, :enable]

For now, this resource can only create, enable or delete the user. It only supports setting the user's initial password. It assumes a password db backend that utilizes the smbpasswd program.

This will not enforce the password to be set to the value specified. Meaning, if the local user changes their password with smbpasswd, the recipe will not reset it. This may be changed in a future version of this cookbook.


The samba::default recipe includes samba::client, which simply installs smbclient package. Remaining information in this section pertains to samba::server recipe.

Set attributes as desired in a role, and create a data bag with an item called shares. The default name for the data bag is samba but this can be changed by setting node["samba"]["data_bag"]. Also create a data bag with an item for each user that should have access to samba. The name of the users data bag defaults to users but can be changed by setting node["samba"]["users_data_bag"].

Example data bag item for a single share named export in the shares item.

% cat data_bags/samba/shares.json
  "id": "shares",
  "shares": {
    "export": {
      "comment": "Exported Share",
      "path": "/srv/export",
      "guest ok": "no",
      "printable": "no",
      "write list": ["jtimberman"],
      "create mask": "0664",
      "directory mask": "0775"

Each of the hashes in shares will be a stanza in the smb.conf.

Example data bag item for a user. Note that the user must exist on the system already. This is the minimal users data bag to set up the smbpasswd entry. More options are available for those using the users cookbook, see the readme for that cookbook for more information.

% cat data_bags/users/jtimberman.json
  "id": "jtimberman",
  "smbpasswd": "plaintextpassword"

Unfortunately, smbpasswd does not take a hashed password as an argument - the password is echoed and piped to the smbpasswd program. This is a limitation of Samba.


This cookbook is tested with:

License and Author

Author:: Joshua Timberman (

Copyright:: 2010, Opscode, Inc

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
See the License for the specific language governing permissions and
limitations under the License.

Samba Changelog

v0.13.0 (2016-12-30)

  • This cookbook is now maintained by Sous Chefs ( Expect regular updates and quicker turnaround on PRs!
  • This will be the last version of this cookbook that supports Chef 11. Pin to this version if you require Chef 11 compatibility
  • Added node["samba"]["options"] for passing an array of additional options
  • Added node['samba']['enable_users_search'] to enable/disable searching for samba users. Defaults to true to maintain existing behavior.
  • Added SmartOS compatibility
  • Added ChefSpec matchers for the LWRP
  • Added source_url issues_url and chef_version metadata
  • Removed arch and raspbian from the metadata and added oracle. We officially support systems we can test with Test Kitchen only.
  • Added a Rakefile for simplified testing
  • Switched integration testing to Inspec from serverspec
  • Moved all testing to the 'test' cookbook and eliminated the need for the apt cookbook
  • Switched to cookstyle from Rubocop and resolved all warnings
  • Added testing in Travis CI
  • Added a kitchen config for kitchen-dokken. Expect testing in Travis using kitchen-dokken soon
  • Added a Code of Conduct doc
  • Updated the Contributing docs


  • Manage services at end of server recipe
  • Move package and service names to attributes
  • Select data bags via attributes instead of hardcoded names
  • Corrected service name on Debian
  • Add map to guest option in smb.conf
  • Add test kitchen, chefspec, serverspec, rubocop ignore rules, and foodcritic check
  • Cleanup attributes to make them easier to follow per-platform



  • [COOK-3144]: Wrong service name in samba cookbook



  • [COOK-2978]: samba cookbook has foodcritic errors


  • [COOK-1719] - Add Scientific / Amazon support to the Samba recipe


  • [COOK-1363] - user password assignment fails on systems using dash as default shell


  • Fixes COOK-802, typo in nmbd service name

Collaborator Number Metric

0.13.0 passed this metric

Collaborator Number Metric

0.13.0 passed this metric

Foodcritic Metric

0.13.0 failed this metric

FC059: LWRP provider does not declare use_inline_resources: /tmp/0a736094ddffa393c1399543/samba/providers/user.rb:1
Run with Foodcritic Version 8.1.0 with tags metadata,correctness ~FC031 ~FC045 and failure tags any

Foodcritic Metric

0.13.0 failed this metric

FC059: LWRP provider does not declare use_inline_resources: /tmp/d70c30dde5589eb115adb595/samba/providers/user.rb:1
Run with Foodcritic Version 8.1.0 with tags metadata,correctness ~FC031 ~FC045 and failure tags any

License Metric

0.13.0 passed this metric

License Metric

0.13.0 passed this metric