generated from ElnuDev/rust-project
Compare commits
No commits in common. "341f67c80b5d7efcd017b32a8eddb6845f34975b" and "351ae0248f9aa609cc3bee1f215048409dece2e5" have entirely different histories.
341f67c80b
...
351ae0248f
8 changed files with 39 additions and 1431 deletions
2
.vscode/settings.json
vendored
2
.vscode/settings.json
vendored
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"rust-analyzer.linkedProjects": [
|
"rust-analyzer.linkedProjects": [
|
||||||
"./webcam-streamer/Cargo.toml",
|
"./helloworld/Cargo.toml",
|
||||||
]
|
]
|
||||||
}
|
}
|
1251
Cargo.lock
generated
1251
Cargo.lock
generated
File diff suppressed because it is too large
Load diff
|
@ -1,3 +1,3 @@
|
||||||
[workspace]
|
[workspace]
|
||||||
members = ["webcam-streamer"]
|
members = ["helloworld"]
|
||||||
resolver = "2"
|
resolver = "2"
|
||||||
|
|
96
flake.lock
generated
96
flake.lock
generated
|
@ -1,96 +0,0 @@
|
||||||
{
|
|
||||||
"nodes": {
|
|
||||||
"flake-utils": {
|
|
||||||
"inputs": {
|
|
||||||
"systems": "systems"
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1681202837,
|
|
||||||
"narHash": "sha256-H+Rh19JDwRtpVPAWp64F+rlEtxUWBAQW28eAi3SRSzg=",
|
|
||||||
"owner": "numtide",
|
|
||||||
"repo": "flake-utils",
|
|
||||||
"rev": "cfacdce06f30d2b68473a46042957675eebb3401",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "numtide",
|
|
||||||
"repo": "flake-utils",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs": {
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1699099776,
|
|
||||||
"narHash": "sha256-X09iKJ27mGsGambGfkKzqvw5esP1L/Rf8H3u3fCqIiU=",
|
|
||||||
"owner": "NixOS",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"rev": "85f1ba3e51676fa8cc604a3d863d729026a6b8eb",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "NixOS",
|
|
||||||
"ref": "nixos-unstable",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nixpkgs_2": {
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1681358109,
|
|
||||||
"narHash": "sha256-eKyxW4OohHQx9Urxi7TQlFBTDWII+F+x2hklDOQPB50=",
|
|
||||||
"owner": "NixOS",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"rev": "96ba1c52e54e74c3197f4d43026b3f3d92e83ff9",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "NixOS",
|
|
||||||
"ref": "nixpkgs-unstable",
|
|
||||||
"repo": "nixpkgs",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"root": {
|
|
||||||
"inputs": {
|
|
||||||
"nixpkgs": "nixpkgs",
|
|
||||||
"rust-overlay": "rust-overlay"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"rust-overlay": {
|
|
||||||
"inputs": {
|
|
||||||
"flake-utils": "flake-utils",
|
|
||||||
"nixpkgs": "nixpkgs_2"
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1699236891,
|
|
||||||
"narHash": "sha256-J0uhoYlufJncIFbM/pAoggzHK/qERB9KfQRkmYD56yo=",
|
|
||||||
"owner": "oxalica",
|
|
||||||
"repo": "rust-overlay",
|
|
||||||
"rev": "a7f9bf91dc5065d470cd57169a9f2ebdbdfe1f24",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "oxalica",
|
|
||||||
"repo": "rust-overlay",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"systems": {
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1681028828,
|
|
||||||
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
|
||||||
"owner": "nix-systems",
|
|
||||||
"repo": "default",
|
|
||||||
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "nix-systems",
|
|
||||||
"repo": "default",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"root": "root",
|
|
||||||
"version": 7
|
|
||||||
}
|
|
52
flake.nix
52
flake.nix
|
@ -1,9 +1,20 @@
|
||||||
|
/*
|
||||||
|
TODO
|
||||||
|
1. Find and replace "helloworld" with your package name for **ALL FILES IN REPOSITORY**
|
||||||
|
2. Add a flake description that describes the workspace on line 27
|
||||||
|
3. Add a package description on line 70
|
||||||
|
4. (optional) uncomment `nativeBuildInputs` and `buildInputs` on lines 43 and 44 if you need openssl
|
||||||
|
5. (optional) set your project homepage, license, and maintainers list on lines 48-51
|
||||||
|
6. (optional) uncomment the NixOS module and update it for your needs
|
||||||
|
7. Delete this comment block
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Some utility commands:
|
Some utility commands:
|
||||||
- `nix flake update --commit-lock-file`
|
- `nix flake update --commit-lock-file`
|
||||||
- `nix flake lock update-input <input>`
|
- `nix flake lock update-input <input>`
|
||||||
- `nix build .#webcam-streamer` or `nix build .`
|
- `nix build .#helloworld` or `nix build .`
|
||||||
- `nix run .#webcam-streamer` or `nix run .`
|
- `nix run .#helloworld` or `nix run .`
|
||||||
*/
|
*/
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -23,14 +34,15 @@ Some utility commands:
|
||||||
};
|
};
|
||||||
rustSettings = with pkgs; {
|
rustSettings = with pkgs; {
|
||||||
src = ./.;
|
src = ./.;
|
||||||
buildInputs = with pkgs; [ ffmpeg ];
|
#nativeBuildInputs = [ pkg-config ];
|
||||||
|
#buildInputs = [ openssl ];
|
||||||
cargoHash = nixpkgs.lib.fakeHash;
|
cargoHash = nixpkgs.lib.fakeHash;
|
||||||
};
|
};
|
||||||
meta = with nixpkgs.lib; {
|
meta = with nixpkgs.lib; {
|
||||||
homepage = "https://git.elnu.com/ElnuDev/webcam-streamer";
|
#homepage = "https://example.com";
|
||||||
license = [ licenses.gpl3 ];
|
#license = [ licenses.gpl3 ];
|
||||||
platforms = [ system ];
|
platforms = [ system ];
|
||||||
maintainers = with maintainers; [ elnudev ];
|
#maintainers = with maintainers; [ ];
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
devShells.${system}.default = with pkgs; mkShell {
|
devShells.${system}.default = with pkgs; mkShell {
|
||||||
|
@ -41,14 +53,14 @@ Some utility commands:
|
||||||
cargo-edit
|
cargo-edit
|
||||||
bacon
|
bacon
|
||||||
];
|
];
|
||||||
inputsFrom = with self.packages.${system}; [ webcam-streamer ];
|
inputsFrom = with self.packages.${system}; [ helloworld ];
|
||||||
};
|
};
|
||||||
packages.${system} = {
|
packages.${system} = {
|
||||||
default = self.packages.${system}.webcam-streamer;
|
default = self.packages.${system}.helloworld;
|
||||||
webcam-streamer = pkgs.rustPlatform.buildRustPackage (rustSettings // {
|
helloworld = pkgs.rustPlatform.buildRustPackage (rustSettings // {
|
||||||
pname = "webcam-streamer";
|
pname = "helloworld";
|
||||||
version = "0.1.0";
|
version = "0.1.0";
|
||||||
buildAndTestSubdir = "webcam-streamer";
|
buildAndTestSubdir = "helloworld";
|
||||||
cargoHash = "sha256-+TaGIiKf+Pz2bTABeG8aCZz0/ZTCKl5398+qbas4Nvo=";
|
cargoHash = "sha256-+TaGIiKf+Pz2bTABeG8aCZz0/ZTCKl5398+qbas4Nvo=";
|
||||||
meta = meta // {
|
meta = meta // {
|
||||||
description = "";
|
description = "";
|
||||||
|
@ -59,14 +71,14 @@ Some utility commands:
|
||||||
nixosModules.default = { config, ... }: let
|
nixosModules.default = { config, ... }: let
|
||||||
lib = nixpkgs.lib;
|
lib = nixpkgs.lib;
|
||||||
in {
|
in {
|
||||||
options.services.webcam-streamer = {
|
options.services.helloworld = {
|
||||||
enable = lib.mkEnableOption (lib.mdDoc "webcam-streamer service");
|
enable = lib.mkEnableOption (lib.mdDoc "helloworld service");
|
||||||
package = lib.mkOption {
|
package = lib.mkOption {
|
||||||
type = lib.types.package;
|
type = lib.types.package;
|
||||||
default = self.packages.${system}.webcam-streamer;
|
default = self.packages.${system}.helloworld;
|
||||||
defaultText = "pkgs.webcam-streamer";
|
defaultText = "pkgs.helloworld";
|
||||||
description = lib.mdDoc ''
|
description = lib.mdDoc ''
|
||||||
The webcam-streamer package that should be used.
|
The helloworld package that should be used.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
port = lib.mkOption {
|
port = lib.mkOption {
|
||||||
|
@ -77,16 +89,16 @@ Some utility commands:
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
config.systemd.services.webcam-streamer = let
|
config.systemd.services.helloworld = let
|
||||||
cfg = config.services.webcam-streamer;
|
cfg = config.services.helloworld;
|
||||||
pkg = self.packages.${system}.webcam-streamer;
|
pkg = self.packages.${system}.helloworld;
|
||||||
in lib.mkIf cfg.enable {
|
in lib.mkIf cfg.enable {
|
||||||
description = pkg.meta.description;
|
description = pkg.meta.description;
|
||||||
after = [ "network.target" ];
|
after = [ "network.target" ];
|
||||||
wantedBy = [ "network.target" ];
|
wantedBy = [ "network.target" ];
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
ExecStart = ''
|
ExecStart = ''
|
||||||
${cfg.package}/bin/webcam-streamer --port ${builtins.toString cfg.port}
|
${cfg.package}/bin/helloworld --port ${builtins.toString cfg.port}
|
||||||
'';
|
'';
|
||||||
Restart = "always";
|
Restart = "always";
|
||||||
DynamicUser = true;
|
DynamicUser = true;
|
||||||
|
|
|
@ -1,11 +1,8 @@
|
||||||
[package]
|
[package]
|
||||||
name = "webcam-streamer"
|
name = "helloworld"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
actix-web = "4.4.0"
|
|
||||||
lazy_static = "1.4.0"
|
|
||||||
rscam = { version = "0.5.5", features = ["no_wrapper"] }
|
|
3
helloworld/src/main.rs
Normal file
3
helloworld/src/main.rs
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
fn main() {
|
||||||
|
println!("Hello, world!");
|
||||||
|
}
|
|
@ -1,59 +0,0 @@
|
||||||
use actix_web::{get, App, HttpResponse, HttpServer, Responder};
|
|
||||||
use lazy_static::lazy_static;
|
|
||||||
use rscam::Camera;
|
|
||||||
use std::{
|
|
||||||
sync::Mutex,
|
|
||||||
thread,
|
|
||||||
};
|
|
||||||
|
|
||||||
const FPS: u32 = 30;
|
|
||||||
|
|
||||||
lazy_static! {
|
|
||||||
static ref CAMERA: Camera = {
|
|
||||||
let mut camera = rscam::new("/dev/video0").unwrap();
|
|
||||||
camera
|
|
||||||
.start(&rscam::Config {
|
|
||||||
interval: (1, FPS),
|
|
||||||
resolution: (1280, 720),
|
|
||||||
format: b"MJPG",
|
|
||||||
..Default::default()
|
|
||||||
})
|
|
||||||
.unwrap();
|
|
||||||
camera
|
|
||||||
};
|
|
||||||
static ref CURRENT_FRAME: Mutex<Vec<u8>> = Mutex::new(Vec::new());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[get("/feed.jpg")]
|
|
||||||
async fn get_feed() -> impl Responder {
|
|
||||||
HttpResponse::Ok()
|
|
||||||
.content_type("image/jpeg")
|
|
||||||
.body(CURRENT_FRAME.lock().unwrap().clone())
|
|
||||||
}
|
|
||||||
|
|
||||||
#[get("/")]
|
|
||||||
async fn get_index() -> impl Responder {
|
|
||||||
HttpResponse::Ok().content_type("text/html").body(format!(
|
|
||||||
"
|
|
||||||
<img src=\"feed.jpg\">
|
|
||||||
<script>
|
|
||||||
const img = document.querySelector(\"img\");
|
|
||||||
setInterval(() => {{
|
|
||||||
img.src = \"feed.jpg?\" + new Date().getTime();
|
|
||||||
}}, {});
|
|
||||||
</script>
|
|
||||||
",
|
|
||||||
1000.0 / FPS as f32
|
|
||||||
))
|
|
||||||
}
|
|
||||||
|
|
||||||
#[actix_web::main]
|
|
||||||
async fn main() -> std::io::Result<()> {
|
|
||||||
thread::spawn(move || loop {
|
|
||||||
*CURRENT_FRAME.lock().unwrap() = CAMERA.capture().unwrap()[..].to_owned();
|
|
||||||
});
|
|
||||||
HttpServer::new(|| App::new().service(get_index).service(get_feed))
|
|
||||||
.bind(("127.0.0.1", 8080))?
|
|
||||||
.run()
|
|
||||||
.await
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue