Skip to content

Commit

Permalink
Merge pull request #507 from Crypter-File-Transfer/stable
Browse files Browse the repository at this point in the history
Merge 'stable' to 'main'
  • Loading branch information
Jack-Edwards authored Apr 25, 2023
2 parents 35bf8a1 + 178d7fc commit 1698a0f
Show file tree
Hide file tree
Showing 38 changed files with 1,064 additions and 265 deletions.
66 changes: 0 additions & 66 deletions .github/workflows/build-and-test.yml

This file was deleted.

94 changes: 94 additions & 0 deletions .github/workflows/unit-test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
name: Unit test

on:
pull_request:
branches: [ main, stable ]

jobs:
build-and-test:

runs-on: ubuntu-latest

services:
database:
image: postgres
env:
POSTGRES_INITDB_ARGS: --auth-host=scram-sha-256 --auth-local=scram-sha-256
POSTGRES_HOST_AUTH_METHOD: scram-sha-256
POSTGRES_USER: postgres
POSTGRES_PASSWORD: DEFAULT_PASSWORD
POSTGRES_DB: crypter
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432

steps:
- uses: actions/checkout@v3
- name: Setup .NET
uses: actions/setup-dotnet@v3
with:
dotnet-version: 7.0.x

- name: Install wasm-tools
run: dotnet workload install wasm-tools

- name: Restore dependencies
run: dotnet restore

- name: Build
run: dotnet build --configuration Release --no-restore

- name: Create Hangfire databases
run: |
sudo apt-get install --yes --no-install-recommends postgresql-client
export PGPASSWORD=DEFAULT_PASSWORD
psql -h 127.0.0.1 -U postgres <<-EOSQL
CREATE DATABASE crypter_hangfire;
EOSQL
- name: Create crypter_user database user
run: |
export PGPASSWORD=DEFAULT_PASSWORD
psql -h 127.0.0.1 -U postgres --dbname "crypter" <<-EOSQL
CREATE USER crypter_user WITH PASSWORD 'DEFAULT_PASSWORD';
REVOKE ALL PRIVILEGES ON DATABASE crypter_hangfire FROM crypter_user;
GRANT CONNECT ON DATABASE crypter TO crypter_user;
CREATE SCHEMA IF NOT EXISTS crypter AUTHORIZATION crypter_user;
GRANT CREATE ON DATABASE crypter TO crypter_user;
GRANT CREATE ON SCHEMA public TO crypter_user;
GRANT CREATE ON SCHEMA crypter TO crypter_user;
GRANT USAGE ON SCHEMA public TO crypter_user;
GRANT USAGE ON SCHEMA crypter TO crypter_user;
EOSQL
- name: Create crypter_hangfire_user database user
run: |
export PGPASSWORD=DEFAULT_PASSWORD
psql -h 127.0.0.1 -U postgres --dbname "crypter_hangfire" <<-EOSQL
CREATE USER crypter_hangfire_user WITH PASSWORD 'DEFAULT_PASSWORD';
REVOKE ALL PRIVILEGES ON DATABASE crypter FROM crypter_hangfire_user;
GRANT CONNECT ON DATABASE crypter_hangfire TO crypter_hangfire_user;
CREATE SCHEMA IF NOT EXISTS hangfire AUTHORIZATION crypter_hangfire_user;
GRANT CREATE ON DATABASE crypter_hangfire TO crypter_hangfire_user;
GRANT CREATE ON SCHEMA public TO crypter_hangfire_user;
GRANT CREATE ON SCHEMA hangfire TO crypter_hangfire_user;
GRANT USAGE ON SCHEMA public TO crypter_hangfire_user;
GRANT USAGE ON SCHEMA hangfire TO crypter_hangfire_user;
EOSQL
- name: Migrate Crypter database
run: |
dotnet tool install --global dotnet-ef
dotnet tool restore
dotnet ef database update -c DataContext -p Crypter.Core -s Crypter.API --connection "host=127.0.0.1:5432;database=crypter;user id=crypter_user;pwd=DEFAULT_PASSWORD;"
- name: Test
run: dotnet test --configuration Release --no-build --verbosity normal
2 changes: 1 addition & 1 deletion Containers/PostgreSQL/.env
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
POSTGRES_SUPERUSER_PASSWORD=CHANGE_ME
POSTGRES_SUPERUSER_PASSWORD=DEFAULT_PASSWORD
POSTGRES_DATA_DIR=./postgres-data
CONTAINER_LISTEN_IP=192.168.1.141
38 changes: 22 additions & 16 deletions Containers/PostgreSQL/postgres-init-files/init.sh
Original file line number Diff line number Diff line change
@@ -1,31 +1,37 @@
#!/bin/bash
set -e

psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
CREATE DATABASE crypter;
# Create hangfire database
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" <<-EOSQL
CREATE DATABASE crypter_hangfire;
EOSQL

# Create crypter_user
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
CREATE USER crypter_user WITH PASSWORD 'CHANGE_ME';
REVOKE ALL PRIVILEGES ON DATABASE postgres FROM crypter_user;
REVOKE ALL PRIVILEGES ON SCHEMA public FROM crypter_user;
REVOKE CREATE ON SCHEMA public FROM PUBLIC;
EOSQL
CREATE USER crypter_user WITH PASSWORD 'DEFAULT_PASSWORD';
REVOKE ALL PRIVILEGES ON DATABASE crypter_hangfire FROM crypter_user;
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "crypter" <<-EOSQL
REVOKE ALL PRIVILEGES ON DATABASE crypter FROM crypter_user;
REVOKE ALL PRIVILEGES ON SCHEMA public FROM crypter_user;
REVOKE CREATE ON SCHEMA public FROM PUBLIC;
GRANT CONNECT ON DATABASE crypter TO crypter_user;
ALTER DEFAULT PRIVILEGES FOR USER postgres IN SCHEMA public GRANT SELECT, INSERT, UPDATE, DELETE ON TABLES TO crypter_user;
CREATE SCHEMA IF NOT EXISTS crypter AUTHORIZATION crypter_user;
GRANT CREATE ON DATABASE crypter TO crypter_user;
GRANT CREATE ON SCHEMA public TO crypter_user;
GRANT CREATE ON SCHEMA crypter TO crypter_user;
GRANT USAGE ON SCHEMA public TO crypter_user;
GRANT USAGE ON SCHEMA crypter TO crypter_user;
EOSQL

# Create crypter_hangfire_user
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "crypter_hangfire" <<-EOSQL
CREATE USER crypter_hangfire_user WITH PASSWORD 'CHANGE_ME';
CREATE USER crypter_hangfire_user WITH PASSWORD 'DEFAULT_PASSWORD';
REVOKE ALL PRIVILEGES ON DATABASE crypter FROM crypter_hangfire_user;
REVOKE ALL PRIVILEGES ON SCHEMA public FROM crypter_hangfire_user;
CREATE SCHEMA IF NOT EXISTS Hangfire AUTHORIZATION crypter_hangfire_user;
GRANT CREATE ON schema Hangfire TO crypter_hangfire_user;
GRANT CONNECT ON DATABASE crypter_hangfire TO crypter_hangfire_user;
CREATE SCHEMA IF NOT EXISTS hangfire AUTHORIZATION crypter_hangfire_user;
GRANT CREATE ON DATABASE crypter_hangfire TO crypter_hangfire_user;
GRANT CREATE ON SCHEMA public TO crypter_hangfire_user;
GRANT CREATE ON SCHEMA hangfire TO crypter_hangfire_user;
GRANT USAGE ON SCHEMA public TO crypter_hangfire_user;
GRANT USAGE ON SCHEMA hangfire TO crypter_hangfire_user;
EOSQL
30 changes: 0 additions & 30 deletions Containers/PostgreSQL_Test/.dockerignore

This file was deleted.

2 changes: 0 additions & 2 deletions Containers/PostgreSQL_Test/.env

This file was deleted.

18 changes: 0 additions & 18 deletions Containers/PostgreSQL_Test/docker-compose.yml

This file was deleted.

31 changes: 0 additions & 31 deletions Containers/PostgreSQL_Test/postgres-init-files/init.sh

This file was deleted.

12 changes: 0 additions & 12 deletions Crypter.API/.config/dotnet-tools.json

This file was deleted.

8 changes: 4 additions & 4 deletions Crypter.API/Crypter.API.csproj
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net7.0</TargetFramework>
<Nullable>disable</Nullable>
<ImplicitUsings>disable</ImplicitUsings>
</PropertyGroup>
Expand All @@ -16,15 +16,15 @@
<ProjectReference Include="..\Crypter.Core\Crypter.Core.csproj" />
</ItemGroup>
<ItemGroup>
<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="7.0.4">
<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="7.0.3">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="7.0.4">
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="7.0.3">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.5.0" />
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="6.0.15" />
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="7.0.5" />
</ItemGroup>
</Project>
9 changes: 2 additions & 7 deletions Crypter.API/Program.cs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@
using Crypter.Core.Identity;
using Crypter.Core.Models;
using Crypter.Core.Settings;
using Hangfire;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
Expand Down Expand Up @@ -139,11 +138,7 @@
app.UseRouting();
app.UseAuthentication();
app.UseAuthorization();
app.UseMiddleware<ExceptionHandlerMiddleware>();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
endpoints.MapHangfireDashboard();
});
app.UseMiddleware<ExceptionHandlerMiddleware>();
app.MapControllers();

app.Run();
4 changes: 2 additions & 2 deletions Crypter.API/Properties/PublishProfiles/FolderProfile.pubxml
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,10 @@ https://go.microsoft.com/fwlink/?LinkID=208121.
<LastUsedBuildConfiguration>Release</LastUsedBuildConfiguration>
<LastUsedPlatform>Any CPU</LastUsedPlatform>
<PublishProvider>FileSystem</PublishProvider>
<PublishUrl>bin\Release\net6.0\publish\</PublishUrl>
<PublishUrl>bin\Release\net7.0\publish\</PublishUrl>
<WebPublishMethod>FileSystem</WebPublishMethod>
<SiteUrlToLaunchAfterPublish />
<TargetFramework>net6.0</TargetFramework>
<TargetFramework>net7.0</TargetFramework>
<ProjectGuid>f9208a53-1847-4b7e-a867-c5d17f52410c</ProjectGuid>
<SelfContained>true</SelfContained>
<RuntimeIdentifier>linux-x64</RuntimeIdentifier>
Expand Down
4 changes: 2 additions & 2 deletions Crypter.API/appsettings.json
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
{
"AllowedHosts": "*",
"ConnectionStrings": {
"DefaultConnection": "host=127.0.0.1;database=crypter;user id=postgres;pwd=CHANGE_ME;",
"HangfireConnection": "host=127.0.0.1;database=crypter_hangfire;user id=crypter_hangfire_user;pwd=CHANGE_ME;"
"DefaultConnection": "host=127.0.0.1;database=crypter;user id=crypter_user;pwd=DEFAULT_PASSWORD;",
"HangfireConnection": "host=127.0.0.1;database=crypter_hangfire;user id=crypter_hangfire_user;pwd=DEFAULT_PASSWORD;"
},
"EmailSettings": {
"Enabled": false,
Expand Down
Loading

0 comments on commit 1698a0f

Please sign in to comment.