Testing is complete!! And a nice build runner script to boot

This commit is contained in:
2025-02-05 13:16:12 -07:00
parent 4864de624c
commit 76ea825509
25 changed files with 1453 additions and 103 deletions
+12 -1
View File
@@ -6,7 +6,7 @@ import 'package:dart_frog/dart_frog.dart';
import 'package:logging/logging.dart';
import 'package:shared_models/room.dart';
final log = Logger('create_room');
final log = Logger('create_room/');
Future<Response> onRequest(RequestContext context) async {
// Only allow POST requests
@@ -28,6 +28,17 @@ Future<Response> onRequest(RequestContext context) async {
// Create the room
final room = await Db.createRoom(roomCode: roomCode);
if (room == null) {
return Response.json(
statusCode: HttpStatus.internalServerError,
body: CreateRoomResponse(
error: 'Unexpected error: unable to create room',
success: false,
roomCode: null,
).toJson(),
);
}
// Return the room code
return Response.json(
body: CreateRoomResponse(success: true, roomCode: room.code).toJson(),
@@ -1,5 +1,5 @@
import 'package:dart_frog/dart_frog.dart';
Response onRequest(RequestContext context) {
return Response(body: 'Welcome to Dart Frog!');
return Response(statusCode: 200);
}
@@ -5,7 +5,7 @@ import 'package:dart_frog/dart_frog.dart';
import 'package:logging/logging.dart';
import 'package:shared_models/user.dart';
final log = Logger('auth/');
final log = Logger('join_room/');
Future<Response> onRequest(RequestContext context) async {
// Only allow POST requests
@@ -20,33 +20,28 @@ Future<Response> onRequest(RequestContext context) async {
// Generate token
final authenticator = context.read<Authenticator>();
final token = await authenticator.generateToken(createUserReq);
final (token, user) = await authenticator.generateToken(createUserReq);
if (token == null) {
if (token == null || user == null) {
final body = CreateUserResponse(
success: false,
token: null,
error: 'Room ${createUserReq.roomCode} requested is not available',
error: user == null ? 'Room ${createUserReq.roomCode} requested is not available' : 'Unexpected error occurred',
uuid: null,
).toJson();
return Response.json(
statusCode: HttpStatus.badRequest,
statusCode: user == null ? HttpStatus.badRequest : HttpStatus.internalServerError,
body: body,
);
}
// Return the token
return Response.json(
body: CreateUserResponse(token: token, success: true).toJson(),
body: CreateUserResponse(token: token, success: true, uuid: user.uuid).toJson(),
);
// }
// on JWTParseException {
// return Response.json(
// statusCode: HttpStatus.badRequest,
// body: {'error': 'Username is required'},
// );
} catch (e) {
log.severe('Error:', e);
final body = CreateUserResponse(success: false, token: null, error: 'Internal server error').toJson();
log.severe('Error:', e, StackTrace.current);
final body = CreateUserResponse(success: false, token: null, error: 'Internal server error', uuid: null).toJson();
return Response.json(
statusCode: HttpStatus.internalServerError,
body: body,
+10
View File
@@ -0,0 +1,10 @@
import 'package:backend/service/db_access.dart';
import 'package:dart_frog/dart_frog.dart';
Future<Response> onRequest(RequestContext context, String roomCode) async {
final gameRoom = await Db.getRoomByCode(roomCode);
if (gameRoom == null) {
return Response(statusCode: 404);
}
return Response(statusCode: 200);
}