Skip to content

Commit

Permalink
Sync from upstream (#1)
Browse files Browse the repository at this point in the history
* Fix Select-DbaBackupInformation

$_.LastLSN.ToString() -ge $LogBaseLsn
$_.LastLSN.ToString() is STRING, but $LogBaseLsn is BIGINT. Powershell converts [BIGINT]$LogBaseLsn to string and after that compare these variables as strings.

* Fix masking (dataplat#4942)

* Added money type

* Added txt data type

* added min and maxvalue to money type

* otsb

* Small fixes Import-DbaXESessionTemplate (dataplat#4917)

* Update Import-DbaXESessionTemplate.ps1

* Update Import-DbaXESessionTemplate.ps1

* 0.9.740

* ApplicationIntent fixes

* 0.9.741

* Update ConvertTo-DbaTimeline.ps1 (dataplat#4952)

Updated example 3; Send-MailMessage only accepts string for -Body

* 0.9.742

* Figure out the new name before doing the checks.

Otherwise we may check to see if "sourceInstance default profile" exists on the destination then trying to create "destinationInstance default profile" which already exists.

* Update Install-DbaMaintenanceSolution.ps1

Fixed path for output directory in Install-DbaMaintenanceSolution dataplat#4950

* Fixed "Succesful" typo (dataplat#4960)

Addresses Status property spelling error for Successful status.

* Adjust unit test (dataplat#4961)

Adjusting the unit test for `tests/Get-DbaTraceFlag.Tests.ps1`

* add example

* new improved unit tests

* removed link for now :(

* update variable names and fix example

* Do the same replacement check for accounts.

* update to new format

* Update replace of SQL commands to just update the @account_name and @profile_name fields

Also put single quotes around the account and profile name in messages for readability.

* command updates

* Update to contributing and readme files (dataplat#4976)

* adjusting content on contributing guide

* adjusting readme content

* Changed names of jobs and schedules. Fixes dataplat#4972 (dataplat#4973)

* Changed names of jobs and schedules. Fixes dataplat#4972

* Added back the source server name in the default copy and restore job

* Unit test updates round 2 (dataplat#4977)

Unit Test Updates, now uniform and simplified

* Add missing unit tests (dataplat#4979)

* add missing unit tests

* fix encoding

* support hostnames ending with - (dataplat#4978)

* 0.9.743

* tests every function has a tests file, and our standard unit tets

* typo

* adjusting example to use splatting

* Updating editor settings for VS Code

Added additional settings that I found turned off by default in VS Code now. Also added comments so folks can see a bit more info on why we set what.

* 0.9.744

* Update Invoke-ManagedComputerCommand.ps1

User must pass permissions

* Fix lower case / upper case

Also fix this line
$sql = $sql.Replace($db.Name, "<TARGETDB>")
This is wrong because of tempdb on the first line will be replaced.

* fixing output mismatch for continue

* removing comments

* 0.9.745

* Get-DbaProductKey: Get-DbaRegistryRoot add -Credential $Credential

* 0.9.747

* typo fixes: efficient -> inefficient. accomodating -> accommodating

In the CBH context of table parameter.

* fixes dataplat#4999 fixes dataplat#4998

* Sqlupdate 2016 sp2 cu5 (dataplat#5006)

* Sqlupdate 2016 sp2 cu5

* Sqlupdate 2016 sp2 cu5

* Sqlupdate 2016 sp2 cu5

* 0.9.748

* buildref, keep in sync (dataplat#5007)

* removing LSN check from backup

* 0.9.749

* Add type switch to gbh call to improve chances of gettign the right backup back

* resuse server connection for get-dbadefaultpath

* fixed bad db killing the bunch

* removing allowcontinue

* fixing up parameter count test

* 0.9.750

* proposed changes

* update docs

* Changes to Export-DbaScript to resolve Issue 2914

* fix caps

* fixed dataplat#4847

* fixed dataplat#5013

* First attempt at catching up on changelog

* Fix data masking on 724

* Fix failsafe on 725

* Fix remainder of off-by-one errors in release numbers

* support -Database properly fixes dataplat#5015

* Changelog caught up through end of 2018

* Changelog caught up to 0.9.750

* Changelog caught up to 0.9.750

* typo fix in sync-dbaavailabilitygroup (dataplat#5027)

Typos fixed in `Sync-DbaAvailabilityGroup`

* 0.9.751

* Update Backup-DbaDatabase AzureBaseUrl parameter help

Changed a reference from NoCopyOnly to Copy to cleanup help and documentation

* Get-DbaDbccMemoryStatus - remove dependency on system.data objects and use standard constructs (dataplat#5031)

* Remove dependancy on system.Data objects

* Fix case of variable

* Modify to use the  .query custom method

* Fixed math (dataplat#5040)

* Fix Set-DbaAgentJobStep  (dataplat#5030)

* Added option to add job step if it doesn't exist

* Added try/catch block for new job step
Moved job step settings

* Changed param type
Fixed if statement

* Removed comment in param

* Added else statements to alter the job step

* Fixed job check
Added filter for job and job step
Fixed check for job
Fixed check for Database and DatabaseUsername

* Changed if statements to better check for the variables

* Added subsystem server. Fixes dataplat#4715

* Formatted it to be the dbatools way

* Added check if Server value is set

* Reformatted the code

* Removed aliases

* Added parameter to unit test

* Added inputobject parameter

* Added help

* 0.9.752

* Update New-DbaAgentJobCategory.ps1 (dataplat#5042)

changed $instance to $server to fix authentication issue

* fixes piping issue (dataplat#5041)

* Update settings.json (dataplat#5054)

*  Added check if database from $Database array is accessible or not before getting roles membership (dataplat#5046)

* Added check if database from $Database array is accessible or not before getting roles membership

* add messaging in verbose mode

* Invoke-DbatoolsFormatter

* add LoginType to returned [PSCustomObject]$user

* Revert "add LoginType to returned [PSCustomObject]$user"

This reverts commit 9286f97.

revert last commit

* Update Get-DbaDbRoleMember.ps1

got rid of try/catch
add Logintype to output

* Added Stop-Function calls to fix dataplat#5050 (dataplat#5052)

* Added Stop-Function calls to fix dataplat#5050

* Simplified catch block to auto pass $EnableException to Stop-Function

* Pass -Force through to Set-DbaDbState (dataplat#5057)

* Fixes for Update-DbaInstance: parallelism, exceptions (dataplat#5053)

* Changing error handling in internal functions + minor fixes

* Removing $EnableException param

* 0.9.753

* 0.9.751 Changes

* 0.9.752 changes

* 0.9.753 changes

* Correct EOL date for 2014 SP2

* 0.9.754

* deprecating AllowContinue

* fixing tests after putting param back in

* buildref, bump date

* Initial commit of New-DbaDbMailProfile, need to add integration tests

* Add project support for VSCode plugin `markdownlint`. List of rules at
https: //github.com/DavidAnson/markdownlint/blob/v0.11.0/doc/Rules.md

Various fixes pointed out by markdownlint

* fixing type in tests

* doubling up on param names fixed

* updating Invoke-DbaDbUpgrade for dataplat#5047

this fixes dataplat#5047 by checking if each object is in the array instead of containing the array. Also applied to the ExcludeDatabase option

* 0.9.755

* test for existence first

* Get-DecryptedObject - Lowercase sys.credentials

* Copy-DbaLinkedServer - check ProductName

* Update Get-DecryptedObject.ps1

* 0.9.757

* New function to support multithreading

* Tests for advanced update function

* Removing lab computer names

* fixes issue dataplat#5090 and adds test coverage for it

* fix for test

* 0.9.770

* Clarified comments on sequenceNumber

* Fix naming conventions

* Removed unused integration tests. Added test for $priority.

* Fix wrong variable names in tests

* Add new login support for Azure SQL Dbs

Fixes dataplat#5100

* Correct formatting

* Changelog catchup (dataplat#5098)

* Catch up to 0.9.755

* 757

* Caught up to 0.9.770

* change bom

* added account, removed tests for properties that do not exist

* 0.9.771

adding current commands and prepping for future command

* buildref, added cu2 for 2014sp3 and cu16 for 2014sp2 (dataplat#5107)

* Changelog for 0.9.771 (dataplat#5105)

* Fixed self-building process (dataplat#5111)

* Fixed self-building process

* fixed indents

* Add handler for AllUserDatabases to resolve Issue 5108 (dataplat#5110)

* Add handler fro AllUserDatabases to resolve Issue 5108

* Fix OTSB Issue

* adding SmartTarget tag to those cmds using it (dataplat#5109)

* 0.9.772

* Corrected property names for job start & end dates (dataplat#5115)

* Add namespace variable so that full type name can be resolved (dataplat#5114)

* Update Install-DbaMaintenanceSolution to fix dataplat#5096 (dataplat#5112)

Changed $instance to $server to fix sql authentication issue during job removal in a -ReplaceExisting scenario

* 0.9.773

* Make Backup-DbaDatabase use Database and ExcludeDatabase when piping (dataplat#5069)

* fixes dataplat#5044

* fix one test

* in instead of contains

* 0.9.773 changelog (dataplat#5118)

* Pass Login values to Copy-DbaLogin (dataplat#5120)

Call to `Copy-DbaLogin` simply didn't pass the values.

Fixes dataplat#5119

* Update Copy-DbaAgentAlert.ps1

Added check to make sure the operator exists at the destination before creating the alert. If not, skip the alert and update the output object.

* Update Copy-DbaAgentAlert.ps1

Removed trailing spaces per failed test: "176Describe : dbatools style
177Context : indentation
178Name : It Copy-DbaAgentAlert.ps1 has no trailing spaces (line(s) 154,156)
179Result : Failed
180Message : Expected 0, but got 2."

* Fix masking commands (dataplat#5071)

* Added check for unique indexes

* Added procedure to make up what the unique indexes are build with
Added check if excluded column is in a unique index

* Added table

* Added extra options for data generation

* Removed unused rowcount
Added unique value dictionary creation

* Added format for masking types

* Added support for using formatting of values

* Added check if any masking info is present

* Implemented unique index support

* Renamed variable

* Revert "Renamed variable"

This reverts commit 3f7adb8.

* Renamed variable and applied formatiing

* Fixed errors in unique value generation

* Added variable for the unique value columns
Changed the if statement for the unique columns

* Explicitly reset the new value variable

* Moved variables to make sure they get cleared in the loop

* Removed date selection
Added section for finance. Can be used for other types that support max

* Revert "Removed date selection"

This reverts commit 6ec4f16.

* Added section for support of max

* Added part for finance

* Removed finance from other section

* Changed if statement to switch

* Changed switch back to if statement
Removed sections
Added finance to other section

* Removed section for finance

* Added checks for supported data types, masking types and sub types

* Moved retrieval of method and properties to begin
Changed if statements for types

* Changed message of unsupported types

* Added new known types
Added format key to known types

* Added extra known types

* Implemented support for text and ntext data types

* Added ntext and text data types

* Added decimal data type

* Moved data retrieval down

* Added types and synonyms
Rearranged the types to be in alphabetical order

* Added types

* Added types to automatically assign the right maskingtype

* Improved the check for supported data types

* Fixed bug missing curly bracket

* Moved the retrieval of the data
Implemented selective columns for data retrieval

* Changed back to SELECT * instead of selective columns

* Changed the SELECT * to be selective columns from table and not object

* Moved data retrieval
Changed where statement build-up

* Removed debug query outputs

* Moved where build-up

* Added special conversion to date and datetime columns

* Fixed bug with missing comma

* Added error record

* Removed unneccesary if statement
Fixed bug with TEXT and NTEXT cast in WHERE clause

* Implemented handling of temporal  values generation
Formatted code

* Fixed bool handling

* Added decimal type

* Added fax synonyms

* Fixed bool handling

* Updates test should statement

* Changed back the should statement

* Enabled rdp

* Changed rdp password

* Formatted test

* Reset appveyor.yml to original settings

* Changed instance

* Changed instance

* Changed instance back

* Added credential

* 0.9.773

* change instance

* Make Backup-DbaDatabase use Database and ExcludeDatabase when piping (dataplat#5069)

* fixes dataplat#5044

* fix one test

* in instead of contains

* 0.9.773 changelog (dataplat#5118)

* Pass Login values to Copy-DbaLogin (dataplat#5120)

Call to `Copy-DbaLogin` simply didn't pass the values.

Fixes dataplat#5119

* Updated test to use other instance

* Enabled RDP

* Set RDP to be started before tests

* Removed RDP option again

* Added fix for datetime

* Formatted code

* Added extra check for temporal tables

* Changed test back to 2008 instance

* 0.9.774

* fix comparison issue

* 0.9.775

* Update Copy-DbaAgentAlert.ps1

Incorporated approach by @alevyinroc at alevyinroc@8a8a8da . Fixed issues mentioned in review by @wsmelton - thank you!

* Update Copy-DbaAgentAlert.ps1

Checked for $null $sourceAlertOperators so Compare-Object wouldn't fail with a $null -ReferenceObject.

* Update Copy-DbaAgentAlert.ps1

Removed trailing spaces.

* Add testing for skipped wen operator not there

* Update Copy-DbaAgentAlert.ps1

Un-did changes using external command Compare-Object which has poor performance and problems with errors and put in approach by @wsmelton. Thanks, Shawn!

* fix path issues

* Update Backup-DbaDbCertificate.ps1

adding the Certificate param to the call out to Get-DbaDbCertificate

* Doc update - correcting example in Export-DbaDacPackage

* Doc update - fixing example for Invoke-DbaAdvancedUpdate (dataplat#5143)

* Doc update - Fix example in Read-DbaBackupHeader

* Doc update - Fix example in Get-DbaSsisExecutionHistory (dataplat#5140)

* Doc update - Fixing command reference in examples and link - Get-DbaDbccUserOption (dataplat#5141)

* Changes to Restart-DbaService to resolve Issue 5128 (dataplat#5145)

* Update Get-DbaUserPermission.ps1 (dataplat#5135)

Changing the cleanup query to run on tempdb

* Get-DbaServerRoleMember - Correcting call to child call for Get-DbaLogin (dataplat#5132)

* format and correcting connect issue to login cmd

* remove restart of agent (test don't require runing state)

* 0.9.777

* Fixed where statements

* Formatted code

* Fix bug in Get-DbaDbFile NextGrowthEventSize

Update $nextgrowtheventadd calculation for Percent growth types
to account for file size being returned in pages.

Also, update $nextgrowtheventadd calculation for non-Percent
growth types to not account for file size being returned in
pages as the "* 8" calculation is already performed in the
T-SQL calls when growth is not percent-based.

* 0.9.778

* Add Registered Server Support for Core (mac/linux) (dataplat#5153)

* bulk changes to support CMS / Registered Servers

* moved some commands

* 0.9.779

* CommandExecute.sql only runs if $Solution = "All"

* some additions

* yesss

* enable azure for .Query()

* added for invoke as well

* remove comments

* 0.9.780

* fixed windows check

* make sure it queries something

* fixed formatting

* formatting

* Merge pull request dataplat#5157 from SQLGB/patch-1

Update Get-DbaAgentJobHistory.ps1

* Include WindowsGroup login types

* remove output

* Look at $ads to get domain name instead of parsing from the group's DN.

* connstring fixes

* formatting

* 0.9.781

* Use ProviderPath property to allow for UNC paths

* removed default

* enable no transaction

fixes dataplat#5159

* fix found bug

* updated and added tests

* moved commands to proper location

* 0.9.774 changes

* 0.9.775 updates

* 0.9.777 changes

* 0.9.778 updates

* 0.9.779 changes

* 0.9.780 changes

* 0.9.781 changes

* Correct date on 0.9.781

* more azure support (dataplat#5172)

* removed unnecessary params and added azure support

* added feature parity to connect-dbainstance

* Newazur (dataplat#5178)

added documentation

* 0.9.782

* Connect consolidation (dataplat#5180)

Connect-SqlInstance -> Connect-DbaInstance

* remove extra info

* fix tests that take too long

* Fix debug and Path is null issues (dataplat#5183)

* add debug by default and dbatools_enabledebug

* remove missing files

* discard leftovers

* put dac back

* A few more azure fixes (dataplat#5185)

* more azure fixes

* return azure connstring

* add new db support for azure

* remove open requirement

* Invoke-DbaDbDataMasking - made azure compliant, probably (dataplat#5184)

* made azure compliant, probably

* fix path for azure

* fix - before i was getting null exceptions
  • Loading branch information
sphallsphall authored Mar 11, 2019
1 parent def28fe commit 92f140f
Show file tree
Hide file tree
Showing 750 changed files with 239,663 additions and 19,032 deletions.
3 changes: 3 additions & 0 deletions .github/ISSUE_TEMPLATE/Bug_Report.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ about: Found errors or unexpected behavior using dbatools module
- [ ] Verified this bug is not already reported in an issue
- [ ] Verified errors are not related to permissions
- [ ] Can reproduce in a clean PowerShell session (_clean = `powershell -NoProfile`_)
- [ ] If issue is with `Copy-DbaDatabase`, using `Backup-DbaDatabase | Restore-DbaDatabase` still does not work

Note that we do not have the resources to make `Copy-DbaDatabase` work in every environment. Instead, we try to ensure Backup & Restore work in your enviornment.

## Steps to Reproduce

Expand Down
1 change: 1 addition & 0 deletions .github/PULL_REQUEST_TEMPLATE.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
- [ ] Ran manual Pester test and has passed (`.\tests\manual.pester.ps1)
- [ ] Adding code coverage to existing functionality
- [ ] Pester test is included
- [ ] If new file reference added for test, has is been added to github.com/sqlcollaborative/appveyor-lab ?
- [ ] Nunit test is included
- [ ] Documentation
- [ ] Build system
Expand Down
7 changes: 7 additions & 0 deletions .markdownlint.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"MD024": false,
"MD022": false,
"MD032": false,
"MD013": false,
"MD001": true
}
257 changes: 257 additions & 0 deletions .vscode/dbatools.code-snippets
Original file line number Diff line number Diff line change
@@ -0,0 +1,257 @@
{
// Starting point for project-level snippets for the dbatools contributions.
// These are just a few and will be exapnded as time goes along.

"Get function for SMO object": {
"scope": "powershell",
"prefix": "getsmo",
"body": [
"function Get-Dba$0 {",
"<#",
"\t.SYNOPSIS",
"\t\t${1:Short of what command does}",
"",
"\t.DESCRIPTION",
"\t\t${2:Longer of what command does}",
"",
"\t.PARAMETER SqlInstance",
"\t\tSQL Server name or SMO object representing the SQL Server to connect to. This can be a collection and receive pipeline input to allow the function to be executed against multiple SQL Server instances.",
"",
"\t.PARAMETER SqlCredential",
"\t\tLogin to the target instance using alternate Windows or SQL Login Authentication. Accepts credential objects (Get-Credential).",
"",
"\t.PARAMETER EnableException",
"\t\tBy default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.",
"\t\tThis avoids overwhelming you with a \"sea of red\" exceptions, but is inconvenient because it basically disables advanced scripting.",
"\t\tUsing this switch turns this \"nice by default\" feature off and enables you to catch exceptions with your own try/catch.",
"",
"\t.NOTES",
"\t\tTags: ${3:Singular word for command index}",
"\t\tAuthor: ${4:FirstName} ${5:LastName} (@${6:TwitterHandle}), ${7:blog address}",
"",
"\t\tWebsite: https://dbatools.io",
"\t\tCopyright: (c) 2018 by dbatools, licensed under MIT",
"\t\tLicense: MIT https://opensource.org/licenses/MIT",
"",
"\t.LINK",
"\t\thttps://dbatools.io/Get-Dba$0",
"",
"\t.EXAMPLE",
"\t\tPS C:\\> Get-Dba$0 -SqlInstance localhost",
"",
"\t\t${8:Add minimum example for each parameter}",
"",
"#>",
"\t[CmdletBinding()]",
"\tparam (",
"\t\t[parameter(Position = 0, Mandatory, ValueFromPipeline)]",
"\t\t[Alias(\"ServerInstance\", \"SqlServer\")]",
"\t\t[DbaInstance[]]\\$SqlInstance,",
"\t\t[Alias(\"Credential\")]",
"\t\t[PSCredential]\\$SqlCredential,",
"\t\t[object[]]\\$${9:YourParameter},",
"\t\t[switch]\\$EnableException",
"\t)",
"\tprocess {",
"\t\tforeach (\\$instance in \\$SqlInstance) {",
"\t\t\tWrite-Message -Level Verbose -Message \"Attempting to connect to \\$instance\"",
"\t\t\ttry {",
"\t\t\t\t\\$server = Connect-SqlInstance -SqlInstance \\$instance -SqlCredential \\$SqlCredential",
"\t\t\t}",
"\t\t\tcatch {",
"\t\t\t\tStop-Function -Message \"Failure\" -Category ConnectionError -ErrorRecord \\$_ -Target \\$instance -Continue",
"\t\t\t}",
"",
"\t\t\t# Add in filter code",
"",
"\t\t\t# Add in processing SMO object",
"",
"\t\t\t<# Output must include 3 properties for each object:",
"\t\t\t\t1. ComputerName (\\$server.ComputerName)",
"\t\t\t\t2. InstanceName (\\$server.ServiceName)",
"\t\t\t\t3. SqlInstance (\\$server.DomainInstanceName)",
"",
"\t\t\t\t\"Select_DefaultView -InputObject \\$object -Property <property list\" can be used to only output certain properties",
"\t\t\t\t\"Select_DefaultView -InputObject \\$object -ExcludeProperty <property list\" can be used to output everything but the list of properties",
"\t\t\t#>",
"\t\t}",
"\t}",
"}"
],
"description": "template for building a function to get properties from SMO object"
},
"Set function": {
"scope": "powershell",
"prefix": "setsmo",
"body": [
"function Set-Dba$0 {",
"<#",
"\t.SYNOPSIS",
"\t\t${1:Short of what command does}",
"",
"\t.DESCRIPTION",
"\t\t${2:Longer of what command does}",
"",
"\t.PARAMETER SqlInstance",
"\t\tSQL Server name or SMO object representing the SQL Server to connect to. This can be a collection and receive pipeline input to allow the function to be executed against multiple SQL Server instances.",
"",
"\t.PARAMETER SqlCredential",
"\t\tLogin to the target instance using alternate Windows or SQL Login Authentication. Accepts credential objects (Get-Credential).",
"",
"\t.PARAMETER EnableException",
"\t\tBy default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.",
"\t\tThis avoids overwhelming you with a \"sea of red\" exceptions, but is inconvenient because it basically disables advanced scripting.",
"\t\tUsing this switch turns this \"nice by default\" feature off and enables you to catch exceptions with your own try/catch.",
"",
"\t.NOTES",
"\t\tTags: ${3:Singular word for command index}",
"\t\tAuthor: ${4:FirstName} ${5:LastName} (@${6:TwitterHandle}), ${7:blog address}",
"",
"\t\tWebsite: https://dbatools.io",
"\t\tCopyright: (c) 2018 by dbatools, licensed under MIT",
"\t\tLicense: MIT https://opensource.org/licenses/MIT",
"",
"\t.LINK",
"\t\thttps://dbatools.io/Set-Dba$0",
"",
"\t.EXAMPLE",
"\t\tPS C:\\> Set-Dba$0 -SqlInstance localhost",
"",
"\t\t${8:Add minimum example for each parameter}",
"",
"#>",
"\t[CmdletBinding(SupportsShouldProcess, ConfirmImpact = \"High\")]",
"\tparam (",
"\t\t[parameter(Position = 0, Mandatory, ValueFromPipeline)]",
"\t\t[Alias(\"ServerInstance\", \"SqlServer\")]",
"\t\t[DbaInstance[]]\\$SqlInstance,",
"\t\t[Alias(\"Credential\")]",
"\t\t[PSCredential]\\$SqlCredential,",
"\t\t[object[]]\\$${9:YourParameters},",
"\t\t[switch]\\$EnableException",
"\t)",
"\tprocess {",
"\t\tforeach (\\$instance in \\$SqlInstance) {",
"\t\t\tWrite-Message -Level Verbose -Message \"Attempting to connect to \\$instance\"",
"\t\t\ttry {",
"\t\t\t\t\\$server = Connect-SqlInstance -SqlInstance \\$instance -SqlCredential \\$SqlCredential",
"\t\t\t}",
"\t\t\tcatch {",
"\t\t\t\tStop-Function -Message \"Failure\" -Category ConnectionError -ErrorRecord \\$_ -Target \\$instance -Continue",
"\t\t\t}",
"",
"\t\t\t# Add code for parameter filters",
"",
"\t\t\tforeach (\\$object in \\$objects) {",
"\t\t\t\tif (\\$Pscmdlet.ShouldProcess(\"\\$object on \\$server\", \"What it will do\")) {",
"\t\t\t\t\t\t# Work to be done",
"",
"\t\t\t\t\t\t[PSCustomObject]@{",
"\t\t\t\t\t\t\tComputerName = \\$server.NetName",
"\t\t\t\t\t\t\tInstanceName = \\$server.ServiceName",
"\t\t\t\t\t\t\tSqlInstance = \\$server.DomainInstanceName",
"\t\t\t\t\t\t\tObject = \\$object.Name",
"\t\t\t\t\t\t\tStatus = \"Dropped/Updated/etc\"",
"\t\t\t\t\t\t}",
"\t\t\t\t\t}",
"\t\t\t}",
"\t\t}",
"\t}",
"}"
],
"description": "template for building a function to set properties from SMO object"
},

"Set function": {
"scope": "powershell",
"prefix": "setsql",
"body": [
"function Set-Dba$0 {",
"<#",
"\t.SYNOPSIS",
"\t\t${1:Short of what command does}",
"",
"\t.DESCRIPTION",
"\t\t${2:Longer of what command does}",
"",
"\t.PARAMETER SqlInstance",
"\t\tSQL Server name or SMO object representing the SQL Server to connect to. This can be a collection and receive pipeline input to allow the function to be executed against multiple SQL Server instances.",
"",
"\t.PARAMETER SqlCredential",
"\t\tLogin to the target instance using alternate Windows or SQL Login Authentication. Accepts credential objects (Get-Credential).",
"",
"\t.PARAMETER EnableException",
"\t\tBy default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.",
"\t\tThis avoids overwhelming you with a \"sea of red\" exceptions, but is inconvenient because it basically disables advanced scripting.",
"\t\tUsing this switch turns this \"nice by default\" feature off and enables you to catch exceptions with your own try/catch.",
"",
"\t.NOTES",
"\t\tTags: ${3:Singular word for command index}",
"\t\tAuthor: ${4:FirstName} ${5:LastName} (@${6:TwitterHandle}), ${7:blog address}",
"",
"\t\tWebsite: https://dbatools.io",
"\t\tCopyright: (c) 2018 by dbatools, licensed under MIT",
"\t\tLicense: MIT https://opensource.org/licenses/MIT",
"",
"\t.LINK",
"\t\thttps://dbatools.io/Set-Dba$0",
"",
"\t.EXAMPLE",
"\t\tPS C:\\> Set-Dba$0 -SqlInstance localhost",
"",
"\t\t${8:Add minimum example for each parameter}",
"",
"#>",
"\t[CmdletBinding(SupportsShouldProcess, ConfirmImpact = \"High\")]",
"\tparam (",
"\t\t[parameter(Position = 0, Mandatory, ValueFromPipeline)]",
"\t\t[Alias(\"ServerInstance\", \"SqlServer\")]",
"\t\t[DbaInstance[]]\\$SqlInstance,",
"\t\t[Alias(\"Credential\")]",
"\t\t[PSCredential]\\$SqlCredential,",
"\t\t[object[]]\\$${9:YourParameters},",
"\t\t[switch]\\$EnableException",
"\t)",
"\tbegin {",
"\t\t\\$sql = \"--FORMART YOUR T-SQL, poorsql.com",
"\t\t\t\\-- build your query based on parameters passed in",
"\t\t\"",
"\t}",
"\tprocess {",
"\t\tforeach (\\$instance in \\$SqlInstance) {",
"\t\t\tWrite-Message -Level Verbose -Message \"Attempting to connect to \\$instance\"",
"\t\t\ttry {",
"\t\t\t\t\\$server = Connect-SqlInstance -SqlInstance \\$instance -SqlCredential \\$SqlCredential",
"\t\t\t}",
"\t\t\tcatch {",
"\t\t\t\tStop-Function -Message \"Failure\" -Category ConnectionError -ErrorRecord \\$_ -Target \\$instance -Continue",
"\t\t\t}",
"",
"\t\t\t# Add code for parameter filters",
"",
"\t\t\tforeach (\\$object in \\$objects) {",
"\t\t\t\ttry {",
"\t\t\t\t\t\\$results = \\$server.Query(\\$sql)",
"\t\t\t\t}",
"\t\t\t\tcatch {",
"\t\t\t\t\tStop-Function -Message \"Something went wrong\" -Continue -Target \\$object -ErrorRecord \\$_",
"\t\t\t\t}",
"\t\t\t\tforeach (\\$row in \\$results) {",
"\t\t\t\t\t# Work to be done",
"",
"\t\t\t\t\t[PSCustomObject]@{",
"\t\t\t\t\t\tComputerName = \\$server.NetName",
"\t\t\t\t\t\tInstanceName = \\$server.ServiceName",
"\t\t\t\t\t\tSqlInstance = \\$server.DomainInstanceName",
"\t\t\t\t\t\tObject = \\$row.ColumnName",
"\t\t\t\t\t\tStatus = \"Dropped/Updated/Whatever\"",
"\t\t\t\t\t}",
"\t\t\t\t}",
"\t\t\t}",
"\t\t}",
"\t}",
"}"
],
"description": "template for building a function to set properties from SMO object"
}
}
14 changes: 12 additions & 2 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,9 +1,19 @@
// Place your settings in this file to overwrite default and user settings.
{
// cleans up whitespace
"files.trimTrailingWhitespace": true,

// formatting style this project adheres to: https://en.wikipedia.org/wiki/Indentation_style#Variant:_1TBS_(OTBS)
"powershell.codeFormatting.preset": "OTBS",

// editor settings for formatting standards on this project
"editor.tabSize": 4,
"editor.detectIndentation": false,
"editor.insertSpaces": true,
"editor.formatOnSave": true
}
"editor.formatOnSave": true,

// editor settings that will auto add the closing quote or curly brace
"editor.autoClosingBrackets": "always",
"editor.autoClosingQuotes": "always",
"editor.autoSurround": "languageDefined"
}
Loading

1 comment on commit 92f140f

@sphallsphall
Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Catch up upstream

Please sign in to comment.