Skip to content

Latest commit

 

History

History
99 lines (86 loc) · 7.36 KB

README.md

File metadata and controls

99 lines (86 loc) · 7.36 KB

GroupMe Desktop Client Plugin Demos

Samples for the Group-Chat Option Plugin and the Message Composer Plugin

  • EffectDemo: Basic template for a message composer plugin. This plugin format can be used to offer message suggestions based on what a user has typed.
  • GroupPluginDemoWPF-MVVM: Group Plugins can be invoked for a specific Group or Chat (direct message) from the dropdown menu at the top. This is demo that opens a WPF window and displays the name of the selected group. The most recent message in the group is shown from cache, as well as the most recently cached message (from any group). MvvmLight is included.

Build

Both the GroupMeClientApi and GroupMeClientPlugin packages required to build the demo are hosted on NuGet. The sample solution includes a binary copy of the packaging tool, which is automatically run upon a 'Release' build.

Install (Standard Manual Method)

  • Create the folder %localappdata%\MicroCube\GroupMe Desktop Client\Plugins if it does not exist
  • Copy the generated .dll file from the \bin\Debug\ into the Plugins directory.
    • Only the single dll needs copied. The build directory will have copies of GroupMeClientApi.dll and GroupMeClientPlugin.dll. These can be omitted, since they are already installed with the Desktop Client.
    • For the MVVM Demo, the Galasoft/MvvmLight dlls can also be omitted. The Desktop Client already targets the same version of MvvmLight.
    • See the Publishing section for more details about configuring unneccesary dependencies to be omitted.

(Optional) Static Installation

  • Instead of copying the plugin binaries into the Plugins folder and loading them dynamically at runtime, it may be easier to compile a special debug version of GroupMe Desktop Client that statically links against your plugin.
  • This method will allow you to fully step-through your plugin, view how it interacts with the GMDC Runtime, and better set breakpoints.
  • To build a static test copy:
    • Clone the develop branch of GroupMe Desktop Client from GitHub.
    • Open the Solution in Visual Studio. Add your plugin project to the GMDC solution.
    • In the GroupMeClient project (the GMDC Core), add a "Shared Project" reference to your plugin project.
    • Edit Plugins\PluginManager.cs as follows:
      public void LoadPlugins(string pluginsPath)
      {
         ... /*Add your code at the very bottom of the method */
         
         // For a Group Plugin
         this.GroupChatPluginsManuallyInstalled.Add(new YourPluginProject.YourPlugin()); 
         
         // For a Effect Plugin
         this.MessageComposePluginsManuallyInstalled.Add(new YourPluginProject.YourPlugin()); 
      }
    • Run the project. Your plugin will be available, and all Visual Studio debugging features will be available.

Test

  • Run the GroupMe Desktop Client
  • Open a Group or Chat
  • Select the dropdown arrow next to the group name (above the messages) to open the Group Options menu.
  • Select one of the installed GroupPlugin demos. For both, a plain window should be displayed containing the Group or Chat name.
  • To see the Effect Demo, begin composing a message, and then select the icon to the left of the send box.

Publishing

GroupMe Desktop Client v0.0.25 and newer include support for automatically installing and updating plugins from online repositories. GitHub Releases are supported and are the recommended method for distributing plugins. The sample solution comes pre-configured to generate the RELEASES file and zip bundles for automatic installation. To apply this packaging to plugins in another solution, the following steps can be used.

  • Install the GMDCPluginPackager package from NuGet

  • Edit the .csproj file for your plugin. Include the following section in the project file:

    <Target Name="_DetermineSetupGMDCPackagerVersion" Condition="'$(SetupGMDCPackagerVersion)' == ''">
     <ItemGroup>
       <Package-GMDCPluginPackager Include="@(PackageReference)" Condition=" '%(Identity)' == 'GMDCPluginPackager' " />
     </ItemGroup>
     <CreateProperty Value="%(Package-GMDCPluginPackager.Version)">
       <Output TaskParameter="Value" PropertyName="SetupGMDCPackagerVersion" />
     </CreateProperty>
     <Message Text="Automatically detected GMDC Packaging Tools version: $(SetupGMDCPackagerVersion)" Importance="Normal" />
    </Target>
    <Target Name="PackageForRelease" AfterTargets="Build" Condition=" '$(Configuration)' == 'Release'" DependsOnTargets="_DetermineSetupGMDCPackagerVersion">
     <Message Text="Packaging for Release...." Importance="High" />
     <PropertyGroup>
       <_PackageForReleasePath>$(NuGetPackageRoot)GMDCPluginPackager\$(SetupGMDCPackagerVersion)\tools\net46\PackageForRelease.exe</_PackageForReleasePath>
     </PropertyGroup>
     <GetAssemblyIdentity AssemblyFiles="$(TargetPath)">
       <Output TaskParameter="Assemblies" ItemName="myAssemblyInfo" />
     </GetAssemblyIdentity>
     <Exec Command="&quot;$(_PackageForReleasePath)&quot; --shortname $(ProjectName) --fullname &quot;Group Plugin Demo&quot; --bindir &quot;$(OutDir)\&quot; --pubdir &quot;$(OutDir)\..\..\..\\Publish\\&quot; --version &quot;$([System.Version]::Parse(%(myAssemblyInfo.Version)).ToString(3))&quot;" />
    </Target>
```
  • Replace PUT THE FULL NAME HERE with the complete display name of your plugin, or select a MSBuild variable to use. This string will be shown in the GMDC Repo Browser to identify your plugin.

  • The pubdir parameter indicates the folder where the resulting RELEASES file and zip bundles should be stored. The number of ..\ paths may need to be adjusted relative to your solution structure. The sample path is a typical representation for a .NET Framework project nested in a solution.

  • All artifacts produced in the bindir folder will be bundled with your plugin. Some dependencies, such as GroupMeClientApi and GroupMePlugin should NOT be included though, since they are already provided at runtime by GMDC. The same applies for some external libraries that are core components of GMDC. To exclude these dependencies from being included in a release build, update the .csproj as shown below.

     <PackageReference Include="{the name of the dependency}">
       <Version>{the correct version}</Version>
       <ExcludeAssets>runtime</ExcludeAssets>
       <PrivateAssets>all</PrivateAssets>
     </PackageReference>
    • Note the inclusion of the <ExcludeAssets>runtime</ExcludeAssets> and <PrivateAssets>all</PrivateAssets> lines.
    • ExcludeAssets and PrivateAssets should be set for ALL of the following libraries:
      • GroupMeClientApi
      • GroupMeClientPlugin
      • MahApps.Metro version 2.x
      • MvvmLightLibsStd10
  • To run the packaging tool, build in Release mode.

  • Prior to producing a final release build, empty the contents of the Publish folder. The packaging tool appends a new line onto the RELEASES file for each plugin, however, it does not delete old files.

  • Create a GitHub release and ensure that all packaged artifacts are uploaded to the release. This includes the RELEASES.txt file and all .zip packages. None of the files should be renamed.

    • If using the GitHub Action for releasing, when a tag is pushed to the master branch, a build will be automatically executed, and the results will be copied into a pre-release GitHub Release entry.
    • The release can be manually edited and approved through the GitHub website.