Friday, February 21, 2014

Lists: Resource Throttling


I recently came across an issue where I had an Infopath form that needed access to a list that had over 10,000 items (Don't worry the form used a web service to filter the number of items returned).  When I opened the form, I received a message complaining  I was trying to query a list with more items than my list threshold, even though I was technically only returning only about 100 items.

There were a couple options.

Option 1: Increase the Resource Throttling through Central Administration.
  1. Go to Central Administration > Application Management > Manage Web Applications
  2. Select your site in the list, and in the ribbon click the drop down arrow for General Settings and select Resource Throttling.
  3. Adjust List View Threshold.
Option 2: User Power shell to increase Resource Throttling for just the list.

$Site = Get-SPWeb http://siteurl
$List = $Site.List["List Name"]
$List.EnableThrottling = $false
$List.Update()

I didn't need to increase the throttling amount for all of my environment, so I opted for Option 2 as most of our list and libraries have well below 10,000 items.  In most cases, I would recommend Option 2.

Wednesday, February 19, 2014

Nintex: Setting Up Lazy Approval

Lazy Approval is awesome.  I love it, and perhaps more importantly end users love it.  Lazy approval allows someone to approve or reject a task by e-mail.  Managers generally do not like to click and navigate to several different areas.  By having your notification messages include the relevant details and enabling lazy approvals, managers only need to read the e-mail and respond with text as simple as Yes or No to approve.


So, how is this awesome feature enabled?

Step 1: Install SMTP Service

Installing SMTP is pretty straight forward and I don't really want to go through it, but I will provide a couple articles for those unfamiliar with the process.
  1. Go to Central Administration.
  2. Under Nintex Workflow Management, click Global Settings.
  3. Enter your Outbound SMTP Server, a From Address, a Reply To Address.  This may already be configured if Nintex is sending notifications through workflows.
  4. Perform an IIS Reset.
Step 3: Enabling Lazy Approval
  1. Go to Central Administration.
  2. Click Nintex Workflow Management.
  3. Click Lazy Approval Settings.
  4. Click Enable / Disable Lazy Approval.
  5. Select Yes for Enable Lazy Approval via E-mail.
  6. Provide an e-mail alias.
  7. Perform an IIS Reset or wait about 15 minutes for the changes to go into effect.
Step 4: Manage Lazy Approval Terms
Adding New Terms
  1. Go to Central Administration.
  2. Click Nintex Workflow Management.
  3. Click Lazy Approval Settings.
  4. Click Create a new LazyApproval term for the current server farm.
  5. Provide the phrase and outcome and click OK
Adding New Terms to Ignore
These terms must appear in the e-mail subjects line to be ignored.
  1. Go to Central Administration.
  2. Click Nintex Workflow Management.
  3. Click Lazy Approval Settings.
  4. Click Create a term to ignore.
  5. Enter term, click OK.


Saturday, February 1, 2014

PowerShell Script to Mask User

SharePoint Survey Lists have the option to mask the Created By and Modified By fields, but unfortunately no other lists have this option.

If you need to mask the Created By and Modified By names on a SharePoint list, use the script below:

#Get Web and List objects
$spweb = Get-SPWeb http://SiteUrl
$splist = $web.Lists["List Name"]
#Mask Created By/Modified By
$splist.ShowUser = $false
$splist.Update()
$spweb.Dispose()


You could also modify the view to not show the Created By/Modified By fields and customize the template to not display those fields, however, if you use mobile SharePoint apps on a tablet or SmartPhone, the fields may still appear.  Using this script, however, the fields' values are either masked or the fields are not shown (at least in the apps I have tried).

Nintex Call Web Service Action is Cool, Part 1.

Nintex'x Call Web Service Action is an incredible powerful tool and helps build an integration between your SharePoint environment and with external systems.  Not only that, it can be used to call SharePoint's web services, which makes it possible for a workflow to add a user to a SharePoint group, start a workflow on another document library, etc.

This post will explain how to configure the workflow action to add a user to a SharePoint group.  I hope this entry will be the first part of many as the Call Web Service Action is a powerful action that I use frequently.

The web service needed is located at http://spsite/_vti_bin/UserGroup.asmx.

 If you are new to web services and SharePoint, go ahead and copy and paste the url into your browser, replacing spsite with your SharePoint site url.  You should see a nice summary of the operations available under the UserGroup webservice.


Below is a screenshot of how I have configured the Call Web Service Action. I will go through how to configure each field.

URL: The location of the web service.  I used my farm account as the user, however you should be okay with any account that has full control over the site.  

Web Method: After the username is entered, you will need to click refresh.  Assuming the account has the correct permissions, the Web method drop down should be enabled allowing you to select AddUserToGroup.

If you leave the editor set to SOAP Builder, you should see a nice list of fields under Web service input.

groupName: The group name that the user is being added to.  I used the inline function fn-XmlEncode to ensure the string will not cause the workflow to error.  For example, the function should change ampersands (&) to the xml code of &amp.

userName:  This is the account ID of the user.  Do not include the domain name.

userLoginName: This is the account ID, but with the prefix of the domain name.

userEmail: The user's email address.

Nintex has a Query User Profile action that can be used to acquire a user's e-mail address.  You'll need to provide the action with the username and you will be able to acquire a number of different attributes stored within the user profile.