Skip to content

How to Maintain a RockWeb Environment for your Custom Rock Library Plugin Project(s)

Mike Peterson edited this page Jun 10, 2013 · 13 revisions

If you are Plugin Developer and often update to a newer version of the Rock Core, this doc is for you!

The main topics in this doc are

  • Organizing your GitHub repo for the solution
  • Organizing your project's Visual Studio solution (*.sln)
  • How to refresh your RockWeb installation/environment from updated builds of the Rock Core.

Your GitHub Account

First, you should really have a GitHub account for your Plugin Project(s). Typically, this would be a account specifically for the Church that you are working for. So, let's say your church is called Some Awesome Church. So, you would probably have an Account called github.com/SomeAwesomeChurch.

Your Rock GitHub Repo

Now, have a GitHub Repo for the Rock Plugin Project(s). Let's just call it Rock. So, the full repo name would be github.com/SomeAwesomeChurch/Rock.

Your Visual Studio solution (*.sln)

Now, after pulling your Repo, etc., to your local machine, let's say you put it at c:\Projects\SomeAwesomeChurch-Rock\ This is where we are going to create the Visual Studio solution for all the plugin projects. So, whether you are going to just have one Plugin project for this church or dozens, let's just keep them all in one master solution.

In your c:\Projects\SomeAwesomeChurch-Rock\ folder, we'll want

  • the RockWeb folder from a RockCore build
  • a folder for each specific plugin
  • the main solution file

So, let's say you just have one plugin so far. Here what the contents of your c:\Projects\SomeAwesomeChurch-Rock\ should look like

PotluckDinner\
RockWeb\
SomeAwesomeChurch-Rock.sln

and as you add additional plugins, you'll have a folder for each and add those projects to your main solution

NewPastorTraining\
PotluckDinner\
StaffVacationPlanner\
SummerCampSignup\    
RockWeb\
SomeAwesomeChurch-Rock.sln

Keeping RockWeb updated

So, now that we have our folder and solution organized, we need to figure out how to keep RockWeb updated as newer versions of the Rock Core are released

Step 1 - Get the most recent version RockWeb from a RockCore build/install, but don't paste it into your solution folder just yet. Let's say this is on your hard drive as C:\Projects\RockCore\RockWeb

Step 2 - Clean up your \SomeAwesomeChurch\RockWeb folder

  • Keep these
    • Plugins (folder)
    • web.config
    • web.connectionString.config
    • any other customizations you might have, for example:
      • Assets\SomeAwesomeChurch\
      • Css\SomeAwesomeChurch\
      • Themes\SomeAwesomeChurch\
  • Rename this
    • web.config to web.SomeAwesomeChurch.config
  • Delete everything else

Step 3 - Copy and Paste C:\Projects\RockCore\RockWeb into C:\Projects\SomeAwesomeChurch\

Step 4 - After copying, clean up some of the files that came from RockCore/RockWeb

  • Delete from C:\Projects\SomeAwesomeChurch\RockWeb...
    • contents of RockWeb\Cache
    • contents of RockWeb\Logs
    • all of the *.refresh files in RockWeb\Bin
  • If RockWeb\bin\.gitignore got overwritten with a copy from RockCore/RockWeb, revert it (we'll make a custom one in a later step)

Step 5 - Edit web.config

  • manually copy the values for the following appSettings keys from web.SomeAwesomeChurch.config into web.config
<appSettings>
    <add key="RunJobsInIISContext" value="..." />
    <add key="EnablePageViewTracking" value="..." />
    <add key="AutoMigrateDatabase" value="..." />
    <add key="PasswordKey" value="..." />
    <add key="DataEncryptionKey" value="..." />
</appSettings>
  • After confirming that your appSettings values from web.SomeAwesomeChurch.config have been successfully merged into the real web.config, you can delete web.SomeAwesomeChurch.config

Update/Create your RockWeb\Bin\.gitignore

You only want some of the files in RockWeb\Bin to be commited/pushed to GitHub. A good rule-of-thumb is that the RockWeb\bin github repository should only include files that don't get copied into RockWeb\Bin as a result of building your solution. For example, here is what your .gitignore in RockWeb\Bin should look like

#NOTE: RockWeb\bin repository should only include files that don't get copied into RockWeb\Bin as a result of building the application
#  except for these files:
#    Microsoft.Data.Edm.dll
#    Microsoft.Data.OData.dll
#    System.Spatial.dll

#For non-core RockWeb projects, 
#  don't ignore these:
#    Rock.dll
#    Rock.Rest.dll
#    Quartz.dll
#    DDay.iCal.dll

#Ignore stuff from plugins that we build
/com.SomeAwesomeChurch.PotluckDinner.dll
/com.SomeAwesomeChurch.PotluckDinner.pdb
/com.SomeAwesomeChurch.CampSignUp.dll
/com.SomeAwesomeChurch.CampSignUp.pdb

#Ignore all these file types
*.resources.dll

#Ignore these too (if you have access to the RockWeb//.gitignore from RockCore, you can use that to help you build this list)
/AjaxControlToolkit.dll
/AjaxControlToolkit.pdb
/EntityFramework.dll
/EntityFramework.xml
/Facebook.dll
/Facebook.xml
/Microsoft.Data.Edm.xml
/Microsoft.Data.OData.Contrib.dll
/Microsoft.Data.OData.xml
/Newtonsoft.Json.dll
/Newtonsoft.Json.xml
/Quartz.pdb
/Rock.Rest.pdb
/Rock.pdb
/System.Spatial.xml
/System.Web.Http.OData.dll
/EntityFramework.SqlServer.dll
/EntityFramework.SqlServer.xml

Verify, Commit, and Push to Git

Using Smartgit (or whatever git client / diffs viewer you use), verify that the changes make sense, then commit and push them.

That's about it!

Clone this wiki locally