mirror of
				https://github.com/zigzap/zap.git
				synced 2025-10-20 15:14:08 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			124 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Zig
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Zig
		
	
	
	
	
	
| //!
 | |
| //! Part of the Zap examples.
 | |
| //!
 | |
| //! Build me with `zig build     app_basic`.
 | |
| //! Run   me with `zig build run-app_basic`.
 | |
| //!
 | |
| const std = @import("std");
 | |
| const Allocator = std.mem.Allocator;
 | |
| 
 | |
| const zap = @import("zap");
 | |
| 
 | |
| // The global Application Context
 | |
| const MyContext = struct {
 | |
|     db_connection: []const u8,
 | |
| 
 | |
|     pub fn init(connection: []const u8) MyContext {
 | |
|         return .{
 | |
|             .db_connection = connection,
 | |
|         };
 | |
|     }
 | |
| };
 | |
| 
 | |
| // A very simple endpoint handling only GET requests
 | |
| const SimpleEndpoint = struct {
 | |
| 
 | |
|     // zap.App.Endpoint Interface part
 | |
|     path: []const u8,
 | |
|     error_strategy: zap.Endpoint.ErrorStrategy = .log_to_response,
 | |
| 
 | |
|     // data specific for this endpoint
 | |
|     some_data: []const u8,
 | |
| 
 | |
|     pub fn init(path: []const u8, data: []const u8) SimpleEndpoint {
 | |
|         return .{
 | |
|             .path = path,
 | |
|             .some_data = data,
 | |
|         };
 | |
|     }
 | |
| 
 | |
|     // handle GET requests
 | |
|     pub fn get(e: *SimpleEndpoint, arena: Allocator, context: *MyContext, r: zap.Request) !void {
 | |
|         const thread_id = std.Thread.getCurrentId();
 | |
| 
 | |
|         r.setStatus(.ok);
 | |
| 
 | |
|         // look, we use the arena allocator here -> no need to free the response_text later!
 | |
|         // and we also just `try` it, not worrying about errors
 | |
|         const response_text = try std.fmt.allocPrint(
 | |
|             arena,
 | |
|             \\Hello!
 | |
|             \\context.db_connection: {s}
 | |
|             \\endpoint.data: {s}
 | |
|             \\arena: {}
 | |
|             \\thread_id: {}
 | |
|             \\
 | |
|         ,
 | |
|             .{ context.db_connection, e.some_data, arena.ptr, thread_id },
 | |
|         );
 | |
|         try r.sendBody(response_text);
 | |
|         std.time.sleep(std.time.ns_per_ms * 300);
 | |
|     }
 | |
| };
 | |
| 
 | |
| const StopEndpoint = struct {
 | |
|     path: []const u8,
 | |
|     error_strategy: zap.Endpoint.ErrorStrategy = .log_to_response,
 | |
| 
 | |
|     pub fn get(_: *StopEndpoint, _: Allocator, context: *MyContext, _: zap.Request) !void {
 | |
|         std.debug.print(
 | |
|             \\Before I stop, let me dump the app context:
 | |
|             \\db_connection='{s}'
 | |
|             \\
 | |
|             \\
 | |
|         , .{context.*.db_connection});
 | |
|         zap.stop();
 | |
|     }
 | |
| };
 | |
| 
 | |
| pub fn main() !void {
 | |
|     // setup allocations
 | |
|     var gpa: std.heap.GeneralPurposeAllocator(.{
 | |
|         // just to be explicit
 | |
|         .thread_safe = true,
 | |
|     }) = .{};
 | |
|     defer std.debug.print("\n\nLeaks detected: {}\n\n", .{gpa.deinit() != .ok});
 | |
|     const allocator = gpa.allocator();
 | |
| 
 | |
|     // create an app context
 | |
|     var my_context = MyContext.init("db connection established!");
 | |
| 
 | |
|     // create an App instance
 | |
|     const App = zap.App.Create(MyContext);
 | |
|     try App.init(allocator, &my_context, .{});
 | |
|     defer App.deinit();
 | |
| 
 | |
|     // create the endpoints
 | |
|     var my_endpoint = SimpleEndpoint.init("/test", "some endpoint specific data");
 | |
|     var stop_endpoint: StopEndpoint = .{ .path = "/stop" };
 | |
|     //
 | |
|     // register the endpoints with the App
 | |
|     try App.register(&my_endpoint);
 | |
|     try App.register(&stop_endpoint);
 | |
| 
 | |
|     // listen on the network
 | |
|     try App.listen(.{
 | |
|         .interface = "0.0.0.0",
 | |
|         .port = 3000,
 | |
|     });
 | |
|     std.debug.print("Listening on 0.0.0.0:3000\n", .{});
 | |
| 
 | |
|     std.debug.print(
 | |
|         \\ Try me via:
 | |
|         \\ curl http://localhost:3000/test
 | |
|         \\ Stop me via:
 | |
|         \\ curl http://localhost:3000/stop
 | |
|         \\
 | |
|     , .{});
 | |
| 
 | |
|     // start worker threads -- only 1 process!!!
 | |
|     zap.start(.{
 | |
|         .threads = 2,
 | |
|         .workers = 1,
 | |
|     });
 | |
| }
 | 
