Skip to content

co-IT/coIT.Toolkit.SendGrid.TemplateManager

Repository files navigation

coIT.Toolkit.SendGrid.TemplateManager

Anwendung zur Verwaltung von SendGrid Templates für Cyber Produkte

Anleitung

Ersteinrichtung

.msi-Datei von GitHub Releases herunterladen und installieren

Wichtig: Es muss der verschlüsselte Datenbank ConnectionString als Umgebungsvariable COIT_TOOLKIT_DATABASE_CONNECTIONSTRING zur Verfügung stehen.

Updates

Beim Programmstart wird in den GitHub Releases automatisch nach Updates gesucht und diese installiert.

SQL-Queries

PhishingTemplates importieren

SELECT
  templates.TemplateId,
  templates.Title,
  templates.SenderEmail,
  templates.SenderName,
  STRING_AGG(pmt.PackageValue, '&') AS PackageValues
FROM
  [dbo].[PhishingMailTemplates] templates
    LEFT JOIN
  [dbo].[PackagePhishingMailTemplates] pmt
  ON templates.Id = pmt.PhishingMailTemplateId
GROUP BY
  templates.TemplateId,
  templates.Title,
  templates.SenderEmail,
  templates.SenderName;

Save it as CSV.

Phishing Klicks importieren

SELECT [SuccessfullyFooled]
      ,[TemplateId]
  FROM [dbo].[PhishingMailInformation]
  LEFT JOIN PhishingMailTemplates ON PhishingMailTemplates.Id = PhishingMailInformation.PhishingMailTemplateId

Save it as CSV.

Development

Das Repo enthält bereits:

  • CSharpier und eine .editorconfig
  • .gitattributes für konsistente Zeilenenden
  • .gitignore für VisualStudio und Rider
  • .github/workflows/build_and_publish.yml mit der das Projekt automatisch beim Erstellen von Releases veröffentlicht wird

Deployment

Wenn eine neue Version released werden soll, muss nur ein neuer GitHub Release mit einem Tag im Format x.x.x erstellt werden.

Das Deployment startet daraufhin in einer GitHub Action durch den gepushten Tag automatisch.

Die .NET Version für den Build and publish workflow wird in der global.json festgelegt und muss in der Zukunft eventuell angepasst werden.

nuget-Packages

Um die notwendigen Packages aus dem privaten Package-Manager der co-IT aus GitHub zu laden, wird eine eigene nuget.config benötigt.

  1. Stelle sicher, dass die GitHub Cli bei dir installiert ist (winget)
  2. Falls du bisher noch nie eine nuget.config anlegen musstest führe gh auth login --scopes read:packages aus und verknüpfge deinen GitHub Account
  3. Lege eine nuget.config Datei mit dem folgenden Inhalt an
<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <packageSources>
        <clear />
        <add key="nuget.org" value="https://api.nuget.org/v3/index.json" />
        <add key="github" value="https://nuget.pkg.github.com/co-IT/index.json" />
    </packageSources>
    <packageSourceCredentials>
        <github>
            <add key="Username" value="{Nutzername}" />
            <add key="ClearTextPassword" value="{Token}" />
        </github>
    </packageSourceCredentials>
</configuration>
  1. Führe gh api user -q ".login" aus und ersetze {Nutzername} in der nuget.config mit dem Ergebnis
  2. Führe gh auth token aus und ersetze {Token} in der nuget.config mit dem Ergebnis

In Zukunft, kannst du diese nuget.config auch für andere Tools und Projekte nutzen, die Zugriff auf den co-IT GitHub package manager benötigen und musst nicht mehr den Schritten von oben folgen