Compare commits
628 Commits
1.36.12_he
...
command_on
Author | SHA1 | Date |
---|---|---|
Isaac Connor | 21218491f7 | |
Isaac Connor | b626de50dc | |
Isaac Connor | d51eb63947 | |
Isaac Connor | f9f2615d48 | |
Isaac Connor | a1bf8f7f5b | |
Isaac Connor | af5436d009 | |
Isaac Connor | e8bb095730 | |
Isaac Connor | e061f3b34a | |
Isaac Connor | 77d3109152 | |
Isaac Connor | 67556430c6 | |
Isaac Connor | 4be9c6cdd2 | |
Isaac Connor | 81ffc6df4e | |
Isaac Connor | ffdb0f9824 | |
Isaac Connor | 46a835b28a | |
Isaac Connor | 1f75b017cc | |
Isaac Connor | cc65c99791 | |
Isaac Connor | 40e7f607f5 | |
Isaac Connor | 2529765df3 | |
Isaac Connor | 2c798069d3 | |
Isaac Connor | 0a30c55042 | |
Isaac Connor | 6ee3c238e7 | |
Isaac Connor | f63c124988 | |
Isaac Connor | 18610fd601 | |
Isaac Connor | 805ef16e73 | |
Isaac Connor | 7b18b22f82 | |
Isaac Connor | 9160ee932f | |
Isaac Connor | 836fe8c2b1 | |
Isaac Connor | b1d881b118 | |
Isaac Connor | a0666e777a | |
Isaac Connor | c37d8eeded | |
Isaac Connor | 96b4af6255 | |
Isaac Connor | 7e1df53aa6 | |
Isaac Connor | 4945a016cf | |
Isaac Connor | 03897bf68e | |
Isaac Connor | 78a803abf8 | |
Isaac Connor | 20629fdf5a | |
Isaac Connor | f48511acba | |
Isaac Connor | 6cbc4c0a7a | |
Isaac Connor | 4e9a56624d | |
Isaac Connor | e63222d733 | |
Isaac Connor | 71c29afa7b | |
Isaac Connor | d00430f799 | |
Isaac Connor | c84f42e280 | |
Isaac Connor | e35dc3902e | |
Isaac Connor | d94c100a72 | |
Isaac Connor | 8872b8be63 | |
Isaac Connor | 795c5bb7d7 | |
Isaac Connor | ac03a88550 | |
Isaac Connor | 529e889d99 | |
Isaac Connor | 14e578cdb2 | |
Isaac Connor | a7fd65d844 | |
Isaac Connor | 6f3e22f2a0 | |
Isaac Connor | 8d0463bbff | |
Isaac Connor | 98e29e7ef6 | |
Isaac Connor | 9d37fbcd8e | |
Isaac Connor | dc9f7b4d1d | |
Isaac Connor | acff4fb9c0 | |
Isaac Connor | c76e688f05 | |
Isaac Connor | 53c57478b8 | |
Isaac Connor | 82a26a1f83 | |
Isaac Connor | bdf55f105e | |
Isaac Connor | 0573c09b50 | |
Isaac Connor | 71931f007a | |
Isaac Connor | 944c04e5b4 | |
Isaac Connor | 9036728bdc | |
Isaac Connor | 01eac4a277 | |
Isaac Connor | 3ac5402699 | |
Isaac Connor | caeaf91cad | |
Isaac Connor | 8868a0fc41 | |
Isaac Connor | 1561adbef9 | |
Isaac Connor | 193f349e38 | |
Isaac Connor | 036d47a832 | |
Isaac Connor | 6d30f5431b | |
Isaac Connor | a0215067e4 | |
Isaac Connor | 883772295d | |
Isaac Connor | 6cd1f6b5f3 | |
Isaac Connor | dc756ad670 | |
Isaac Connor | 9d71f1192a | |
Isaac Connor | 721769993b | |
Isaac Connor | 8d85d0f640 | |
Isaac Connor | 5ac9f88d00 | |
Isaac Connor | 2c0c257d76 | |
Isaac Connor | 0732d4c1b3 | |
Isaac Connor | 377219befe | |
Isaac Connor | ed84b59671 | |
Isaac Connor | 5d0bd978e4 | |
Isaac Connor | 43c1886267 | |
Isaac Connor | b8f6172110 | |
Isaac Connor | 474f65cff3 | |
Isaac Connor | 4c2d50c1f4 | |
Isaac Connor | 44d88edbbb | |
Isaac Connor | f263da8986 | |
Isaac Connor | 30d4900b45 | |
Isaac Connor | 508be72e08 | |
Isaac Connor | 96a58f8c88 | |
Isaac Connor | 66517218f1 | |
Isaac Connor | 5d23362ae0 | |
Isaac Connor | 38105c6796 | |
Isaac Connor | 7aefd657c7 | |
Isaac Connor | 7abbfc2fb5 | |
Isaac Connor | e617eb8615 | |
Isaac Connor | ce81099489 | |
Isaac Connor | 8c2dec03b6 | |
Isaac Connor | 6609c154f2 | |
Isaac Connor | f737e3e945 | |
Isaac Connor | 1fd99424bb | |
Isaac Connor | b2d9e5608f | |
Isaac Connor | 364ae03195 | |
Isaac Connor | 0119ff46aa | |
Isaac Connor | 93055f44e8 | |
Isaac Connor | 814eca2b4f | |
Isaac Connor | a799eb3ad9 | |
Isaac Connor | ae4a33beb2 | |
Isaac Connor | 3208059040 | |
Isaac Connor | 8619971864 | |
Isaac Connor | 61f7989bec | |
Isaac Connor | dd949bb129 | |
Isaac Connor | 0e3f694097 | |
Isaac Connor | 97164fd4d7 | |
Isaac Connor | 3f0bdf6332 | |
Isaac Connor | 224b34d69d | |
Isaac Connor | 1168fc52a5 | |
Isaac Connor | df88c5bbef | |
Isaac Connor | 4122ae99a5 | |
Isaac Connor | b4314e5d46 | |
Isaac Connor | e063f0715f | |
Isaac Connor | dedd755e5c | |
Isaac Connor | 644c6e6b41 | |
Isaac Connor | 76b75cc69b | |
Isaac Connor | fee69d3bc2 | |
Isaac Connor | 0c157904e6 | |
Isaac Connor | 2a160f045d | |
Isaac Connor | c2bd2dc129 | |
Isaac Connor | 9fe2762bc8 | |
Isaac Connor | 5955e4b410 | |
Isaac Connor | d8e4a77424 | |
Isaac Connor | a946c45614 | |
SzymekCRX | 2bcad7bf5e | |
Isaac Connor | 6478999ecf | |
Isaac Connor | a74b785d08 | |
Isaac Connor | a2ec18be5a | |
Isaac Connor | d62d88a0a3 | |
Isaac Connor | c864d0765b | |
Isaac Connor | cebe86feb2 | |
Isaac Connor | d56de57494 | |
Isaac Connor | a55bd23bf6 | |
Isaac Connor | 1e38cf8bb7 | |
Isaac Connor | 51e77438fa | |
Isaac Connor | 0c222f66ee | |
Isaac Connor | 8afed25d18 | |
Isaac Connor | 5e21d4833a | |
Isaac Connor | 9169da6963 | |
Isaac Connor | c6eedd434c | |
Isaac Connor | 4351f51929 | |
Isaac Connor | ccdf002c18 | |
Isaac Connor | ac15ea42cd | |
Isaac Connor | 52f0240334 | |
Isaac Connor | 6d7f752eb0 | |
Isaac Connor | 16d0e269df | |
Isaac Connor | bfcc6ed13e | |
Pascal Muetschard | 14e6d660e7 | |
Isaac Connor | 9f023f7bdd | |
Isaac Connor | 4af605e675 | |
Isaac Connor | d1596dee02 | |
makers-mark | 276add8ee4 | |
Isaac Connor | e1d49ea172 | |
Isaac Connor | 3f6d6fe7a0 | |
Isaac Connor | c05200d2a7 | |
Håvard Flaget Aasen | f2281d1017 | |
Håvard Flaget Aasen | 5970416f0b | |
Isaac Connor | d960f9b6af | |
Isaac Connor | 6c4156a483 | |
Isaac Connor | 1606f7918a | |
Isaac Connor | 809cb651c0 | |
Isaac Connor | 5f381a244f | |
Isaac Connor | d71a5932f5 | |
Isaac Connor | 452d28a66b | |
Isaac Connor | 26ac52aaa9 | |
Isaac Connor | 086bf7a84f | |
Isaac Connor | 411d15605a | |
Isaac Connor | 8a9c283c1c | |
Isaac Connor | 64ab429519 | |
Isaac Connor | 74ac79479f | |
Isaac Connor | 4fee4d01e3 | |
Isaac Connor | 00f9cb791c | |
Isaac Connor | f60282eaf5 | |
Isaac Connor | 6fd33b4627 | |
Mike Dussault | d38a6adec4 | |
Isaac Connor | 2056172ea9 | |
Isaac Connor | 126a102426 | |
Isaac Connor | 0bac052a0a | |
Isaac Connor | 5cdc0efdb8 | |
Isaac Connor | aafec8ead6 | |
Peter Keresztes Schmidt | cd45c61555 | |
Peter Keresztes Schmidt | c027b7a38d | |
Peter Keresztes Schmidt | 97b38bd4ab | |
Isaac Connor | c6cac57fb1 | |
Isaac Connor | 0ba3d863a6 | |
Mike Dussault | 814124251e | |
Mike Dussault | 2cf16eb495 | |
Mike Dussault | 146ff1ac7a | |
Mike Dussault | e4542de6f2 | |
Mike Dussault | 9370cfe25c | |
Mike Dussault | 305af08112 | |
Mike Dussault | 3723e136b1 | |
Isaac Connor | 614750963b | |
Isaac Connor | 7079516e09 | |
Isaac Connor | 2dfbc013cb | |
Isaac Connor | 505f3d1b32 | |
Isaac Connor | a465403c72 | |
Isaac Connor | 7f09cddcd7 | |
Isaac Connor | e394248baf | |
Isaac Connor | 94cd3a6e69 | |
Isaac Connor | 52129c94ec | |
Isaac Connor | ba26235763 | |
Isaac Connor | c72d34f176 | |
Isaac Connor | 75a014321e | |
Isaac Connor | 1f04723f3a | |
haade | a0142d3896 | |
Isaac Connor | 7ed76b5677 | |
TheRealJiffy | ca293eb288 | |
Alejandro Criado-Pérez | 1e71300a3b | |
criadoperez | e462c23115 | |
criadoperez | 9f683c0c91 | |
criadoperez | 8554ccd649 | |
Isaac Connor | 9bbdd36252 | |
Isaac Connor | 509a5549be | |
Isaac Connor | aca477e737 | |
Isaac Connor | 95a7c6c32f | |
Isaac Connor | ac375bc623 | |
Isaac Connor | 9cf4e89254 | |
Isaac Connor | f54e779b21 | |
Isaac Connor | 202d95fc5a | |
Isaac Connor | ee65d3e3dc | |
Isaac Connor | fe734d4e1e | |
Isaac Connor | 1c01936f75 | |
Isaac Connor | ee609ad28b | |
Steve Gilvarry | dcd2c16774 | |
Isaac Connor | 7dbd950574 | |
Isaac Connor | f40e2be28a | |
Isaac Connor | 43dfeb5b84 | |
Isaac Connor | cbc376bb5a | |
Isaac Connor | 2e4bb73204 | |
Isaac Connor | 655daf4fbe | |
Isaac Connor | b8022cdda2 | |
Isaac Connor | e98728c529 | |
Isaac Connor | 568be3fc54 | |
Isaac Connor | 92f6d3cbae | |
Isaac Connor | 6022dd59eb | |
Isaac Connor | 4bdf965dcb | |
Isaac Connor | 2a0ddc6337 | |
5472qaywsx | d81be9701a | |
Andrea Vezzali | e75d5a89e9 | |
Isaac Connor | 0bf417bae0 | |
ColorfullyZhang | 9e4f203632 | |
ColorfullyZhang | 874552c06b | |
Isaac Connor | c233ec3b8c | |
Mike Dussault | e63be2b18e | |
Isaac Connor | c5f4623104 | |
Isaac Connor | 38cda24b53 | |
Isaac Connor | cddb9d88bf | |
Isaac Connor | de299ab882 | |
Isaac Connor | 8272411bb2 | |
Isaac Connor | 120d9764bc | |
Isaac Connor | c7aa41502a | |
Andrea Vezzali | 787b7f1874 | |
Andrea Vezzali | c4a49721d2 | |
Isaac Connor | 6dbfd22190 | |
Andrea Vezzali | 4b4152b837 | |
Peter Keresztes Schmidt | a4ebf533a9 | |
Peter Keresztes Schmidt | 93c5ad0939 | |
Isaac Connor | 94c1b3445d | |
Isaac Connor | 292b3c1d37 | |
Isaac Connor | c66489fb30 | |
Isaac Connor | d98d20958c | |
Isaac Connor | fe72056d73 | |
Isaac Connor | 34d9f87d6d | |
Isaac Connor | 12783f6edf | |
Isaac Connor | 03892796eb | |
Isaac Connor | 888d79706a | |
Isaac Connor | a99f9091fc | |
Isaac Connor | 2f12615f08 | |
Isaac Connor | 7ca7d40b6f | |
Isaac Connor | c78e035057 | |
Isaac Connor | aae967e895 | |
Isaac Connor | 7748307c5a | |
Isaac Connor | d3cfd3c224 | |
Isaac Connor | 30fa641186 | |
Isaac Connor | 1cb9f98e9b | |
Isaac Connor | 160f775f91 | |
Isaac Connor | dd6adc08a8 | |
Isaac Connor | 4b1da156a0 | |
5472qaywsx | a7f13c82d5 | |
Andrea Vezzali | 2724a238e1 | |
Isaac Connor | fba7dba3d0 | |
Isaac Connor | 1700e2f919 | |
ColorfullyZhang | f5d8eaa2ad | |
ColorfullyZhang | 6009bba339 | |
Isaac Connor | e6f4cdb584 | |
Isaac Connor | 547fed2e22 | |
Mike Dussault | 3f97df72c8 | |
Isaac Connor | 1ee85caaae | |
Isaac Connor | d2cf89565e | |
Isaac Connor | 03f0762709 | |
Isaac Connor | bf5c0a8617 | |
Isaac Connor | 167dece604 | |
Isaac Connor | e140620900 | |
Isaac Connor | 7aa955abd2 | |
Isaac Connor | 503f0da9da | |
Andrea Vezzali | 3e5d377f7a | |
Andrea Vezzali | 966749ff86 | |
Isaac Connor | 58f933ba1e | |
Isaac Connor | a05560e797 | |
Isaac Connor | dd2a12675f | |
Andrea Vezzali | 97c10fc135 | |
Peter Keresztes Schmidt | 5fda85bf2e | |
Peter Keresztes Schmidt | ecf6cc80aa | |
Isaac Connor | 15adc47c61 | |
Isaac Connor | 385d1602e0 | |
Isaac Connor | c2472894be | |
Isaac Connor | a9379e5813 | |
Isaac Connor | 009b3ceffc | |
Isaac Connor | e18f8019b0 | |
Isaac Connor | a44bbf8e34 | |
Isaac Connor | 227e5794fa | |
Isaac Connor | c5b097af0a | |
Isaac Connor | b2415643f6 | |
Isaac Connor | 68fc57ef7b | |
Isaac Connor | 4b8ac48590 | |
criadoperez | 4a717820b1 | |
criadoperez | 876fca188b | |
Isaac Connor | f576613c7d | |
Peter Keresztes Schmidt | 6e96cbe14a | |
Peter Keresztes Schmidt | 0ac060fb78 | |
Peter Keresztes Schmidt | 443b84270a | |
Peter Keresztes Schmidt | c9f162f70e | |
Peter Keresztes Schmidt | c83882a4c7 | |
Peter Keresztes Schmidt | 615e3dd76b | |
Peter Keresztes Schmidt | 5dc328e68b | |
Isaac Connor | 263a846251 | |
Isaac Connor | 440bb12a9a | |
Isaac Connor | 9d461203bd | |
Isaac Connor | 8c45739875 | |
Isaac Connor | fe6f71e1dc | |
Isaac Connor | 328bd15360 | |
Isaac Connor | 381fa0d08d | |
Isaac Connor | 8199554217 | |
Isaac Connor | 1a0d488457 | |
Isaac Connor | 6b481fa2b5 | |
Isaac Connor | d102732a7e | |
Isaac Connor | 048b8b13a3 | |
Isaac Connor | 6de8c71d2a | |
Isaac Connor | 4af979c842 | |
Isaac Connor | a52b9057ba | |
Isaac Connor | 11137f9b7a | |
gmanproxtreme | 84ccf10e65 | |
Isaac Connor | a4c079d1b3 | |
Isaac Connor | dbe16a9cb4 | |
Isaac Connor | 7c1c8482c6 | |
Isaac Connor | 2640791b89 | |
Isaac Connor | 848a537a0f | |
Isaac Connor | 4596f61250 | |
r01k | 79e041d0f0 | |
Isaac Connor | 4a5bc88882 | |
Isaac Connor | 68a7635d9b | |
Isaac Connor | 7a6c244aa7 | |
Isaac Connor | 89d7685b14 | |
Isaac Connor | 44823e0c94 | |
Isaac Connor | 8ddec91870 | |
Isaac Connor | 7127a944a1 | |
Isaac Connor | ba9a871daf | |
Isaac Connor | eb1124c406 | |
Isaac Connor | b9efe627f3 | |
Isaac Connor | e7e8996060 | |
Isaac Connor | c12d88d874 | |
Isaac Connor | 301d8fa5fa | |
Andrew Bauer | aa48133096 | |
Isaac Connor | 92a924044a | |
Isaac Connor | a311455526 | |
Isaac Connor | 248ca9a5f9 | |
Isaac Connor | cd3359c3eb | |
Isaac Connor | ccb4bb27dd | |
Isaac Connor | bae8d38301 | |
Isaac Connor | cb4e17e49a | |
Isaac Connor | 066bb891af | |
Isaac Connor | f0b2f75d91 | |
Isaac Connor | 672de6e84f | |
Isaac Connor | 500ced2dc5 | |
Isaac Connor | f2a1d06f64 | |
Isaac Connor | eecf568041 | |
Isaac Connor | 105851b70c | |
Isaac Connor | f236e25e22 | |
Isaac Connor | 1f1678064e | |
Isaac Connor | 222909feb3 | |
Isaac Connor | 7db25a5e1b | |
Isaac Connor | acdd8bb08b | |
Isaac Connor | a3a592d5e1 | |
Isaac Connor | 45bf28a104 | |
Isaac Connor | 7dc36f67db | |
Isaac Connor | 0bcbff5dd5 | |
Isaac Connor | bed41ca44b | |
Isaac Connor | 91903d2822 | |
Isaac Connor | 5bc9cfaa6a | |
Isaac Connor | 85d5dd806e | |
Isaac Connor | dffc7aa2fd | |
Peter Keresztes Schmidt | fb1849ff47 | |
Peter Keresztes Schmidt | cce4b0aac4 | |
Peter Keresztes Schmidt | 2c0cf7a5a7 | |
Peter Keresztes Schmidt | b5765b4535 | |
Peter Keresztes Schmidt | 7d84568b65 | |
Peter Keresztes Schmidt | 50b73cf3d2 | |
Peter Keresztes Schmidt | 4392198d14 | |
Isaac Connor | 9cb19005e5 | |
Steven Gilvarry | cb32630dc0 | |
anon8675309 | 47f171c75c | |
anon8675309 | 649b5585c4 | |
Isaac Connor | 75180f78e2 | |
Isaac Connor | 14047bc820 | |
Isaac Connor | 1766bbdfcd | |
Isaac Connor | b0cf3a4732 | |
Isaac Connor | 413ac984eb | |
Isaac Connor | 4ff4e1f780 | |
Isaac Connor | 54f676a501 | |
Isaac Connor | c6209ce460 | |
Isaac Connor | 3bb2b804b3 | |
Isaac Connor | 24a77d7fb3 | |
Isaac Connor | 8df915e7a4 | |
Isaac Connor | cc486beed5 | |
Isaac Connor | 411a5181e6 | |
Peter Keresztes Schmidt | eaf2e51b0c | |
Peter Keresztes Schmidt | 80b08a2075 | |
Peter Keresztes Schmidt | 65656de6ce | |
Peter Keresztes Schmidt | c60b577aec | |
Peter Keresztes Schmidt | fc15afefcf | |
Peter Keresztes Schmidt | cf9c47149f | |
Isaac Connor | 2b6d54fd81 | |
Isaac Connor | 6373ef9be7 | |
Kendric Evans | 7e8a064725 | |
Isaac Connor | 415dce6548 | |
Pliable Pixels | 6c3f18a347 | |
Isaac Connor | e9845d96f4 | |
anon8675309 | c0875838af | |
anon8675309 | d927db1c0d | |
anon8675309 | f852f1716e | |
anon8675309 | 479385bac7 | |
anon8675309 | 1e834f6088 | |
anon8675309 | 1096fa3f87 | |
Andrew Bauer | 0edc91ffca | |
Andrew Bauer | ec861c5e2b | |
Andrew Bauer | db7c5df8c1 | |
Andrew Bauer | b59e911c43 | |
Isaac Connor | 9438445d74 | |
Isaac Connor | e6b67dcdc2 | |
Isaac Connor | c3fb84bf88 | |
Isaac Connor | 29fb2d3885 | |
Peter Keresztes Schmidt | ea10939970 | |
Peter Keresztes Schmidt | 531694bf8d | |
Isaac Connor | cc2403924a | |
Isaac Connor | 94634f1ca7 | |
Isaac Connor | d221d6ab3b | |
Isaac Connor | da208457b8 | |
Isaac Connor | 0cbb132f08 | |
Isaac Connor | 9001327883 | |
Isaac Connor | 821031f10e | |
Isaac Connor | fa11c20bf8 | |
Peter Keresztes Schmidt | d69afc9672 | |
Peter Keresztes Schmidt | 6114d40593 | |
Peter Keresztes Schmidt | f675afc3f2 | |
Peter Keresztes Schmidt | 3e8b10d813 | |
Peter Keresztes Schmidt | c823b9c00e | |
Peter Keresztes Schmidt | 707975e567 | |
Peter Keresztes Schmidt | dff5452f11 | |
Peter Keresztes Schmidt | 335e950654 | |
Peter Keresztes Schmidt | 7c6a6ac309 | |
Peter Keresztes Schmidt | ce55ba5fb7 | |
Isaac Connor | c2f4d65860 | |
Isaac Connor | c56025beab | |
Isaac Connor | 9f8c8a2664 | |
Peter Keresztes Schmidt | f374b319e0 | |
Peter Keresztes Schmidt | 28d813b95a | |
Peter Keresztes Schmidt | ff8c9f67c1 | |
Peter Keresztes Schmidt | 1fe30c848d | |
Peter Keresztes Schmidt | b2ee71c96e | |
Peter Keresztes Schmidt | e1fe53338c | |
Peter Keresztes Schmidt | 8dae46bc75 | |
Peter Keresztes Schmidt | 95dd0c1491 | |
Isaac Connor | af46f8cad5 | |
Isaac Connor | 7878fbc878 | |
Isaac Connor | 786d0c553e | |
Isaac Connor | fd9bef228d | |
Peter Keresztes Schmidt | 07dbb75c56 | |
Isaac Connor | 46c730e27b | |
Isaac Connor | 268da411d9 | |
Isaac Connor | 4a40214f73 | |
Isaac Connor | 55f2a7f55e | |
Isaac Connor | 0301011f7e | |
Isaac Connor | afecd33879 | |
Isaac Connor | 91892c79b1 | |
Isaac Connor | 97d077d623 | |
Isaac Connor | dbb8019852 | |
Isaac Connor | 84035ef4f7 | |
Isaac Connor | 3d70e621b2 | |
Peter Keresztes Schmidt | b0b2f5fc16 | |
Peter Keresztes Schmidt | 44ace34593 | |
Peter Keresztes Schmidt | 48b1e8a055 | |
Peter Keresztes Schmidt | d8d27bcc92 | |
Peter Keresztes Schmidt | 6c68397249 | |
Peter Keresztes Schmidt | 46155942c1 | |
Peter Keresztes Schmidt | d64b57e63c | |
Peter Keresztes Schmidt | 7474294ac3 | |
Peter Keresztes Schmidt | 129bd3f907 | |
Peter Keresztes Schmidt | 154b17d5f3 | |
Peter Keresztes Schmidt | 2a32f75a24 | |
Steve Gilvarry | b29a785a7c | |
Peter Keresztes Schmidt | 07b81f446f | |
Peter Keresztes Schmidt | f1279a3ebf | |
Isaac Connor | dc6c00ba88 | |
Peter Keresztes Schmidt | 0d81199fc9 | |
Peter Keresztes Schmidt | 2d71743372 | |
Isaac Connor | f0e5eece18 | |
Isaac Connor | bbdf01880a | |
Peter Keresztes Schmidt | 73351f4387 | |
Peter Keresztes Schmidt | f9d859cad8 | |
Peter Keresztes Schmidt | 0625f6ca1c | |
Peter Keresztes Schmidt | 5c96eedac8 | |
Peter Keresztes Schmidt | 3d34e6f177 | |
Peter Keresztes Schmidt | 762476ec76 | |
Peter Keresztes Schmidt | a9ad5c5eee | |
Peter Keresztes Schmidt | 7d15396833 | |
Peter Keresztes Schmidt | 1a6904a297 | |
Peter Keresztes Schmidt | 70c626a30e | |
Peter Keresztes Schmidt | 0b7f9396b4 | |
Peter Keresztes Schmidt | 7d501a6585 | |
Isaac Connor | cca30661d7 | |
Isaac Connor | 9cce9744d2 | |
Isaac Connor | 9f685d6c2b | |
Peter Keresztes Schmidt | 32f139ef7f | |
Peter Keresztes Schmidt | db9b739562 | |
Isaac Connor | a78feb739e | |
Isaac Connor | b16eb510d0 | |
Isaac Connor | 205c488741 | |
Isaac Connor | d713770dea | |
Isaac Connor | 72d07d1428 | |
Isaac Connor | ad0e7a5c1a | |
Isaac Connor | fc6202d349 | |
Isaac Connor | 1b67074d35 | |
Xulunix | 2cbb24d7b9 | |
Isaac Connor | e4d3394888 | |
Isaac Connor | 9a03c2c16a | |
Isaac Connor | ed5262432f | |
Isaac Connor | 5529075fb3 | |
Peter Keresztes Schmidt | 0ea14317a4 | |
Peter Keresztes Schmidt | 7ec37405a6 | |
Peter Keresztes Schmidt | e724a93395 | |
Isaac Connor | bc3d1d161a | |
Peter Keresztes Schmidt | 81a1546a2b | |
Peter Keresztes Schmidt | f2bee0704a | |
Peter Keresztes Schmidt | ed7759897b | |
Isaac Connor | f8b779dc25 | |
Isaac Connor | cc3bce48b7 | |
Isaac Connor | c686fa5949 | |
Isaac Connor | d2941d6b87 | |
Isaac Connor | 50fe7100fa | |
Isaac Connor | 4825370a7f | |
Isaac Connor | 0bcb30b8a9 | |
Isaac Connor | fd21edb7a9 | |
Peter Keresztes Schmidt | f3cb14cc17 | |
Peter Keresztes Schmidt | 764f10bf82 | |
Isaac Connor | 4f2945bd57 | |
Peter Keresztes Schmidt | fead79185b | |
Isaac Connor | dab2792077 | |
Peter Keresztes Schmidt | 8129600a37 | |
Peter Keresztes Schmidt | 5d93555d9f | |
Peter Keresztes Schmidt | 9a983bb321 | |
Peter Keresztes Schmidt | 8b87830e3e | |
Peter Keresztes Schmidt | d2932b5d68 | |
Peter Keresztes Schmidt | 62f60b76d6 | |
Peter Keresztes Schmidt | 837b32ccff | |
Peter Keresztes Schmidt | 2bda413698 | |
Peter Keresztes Schmidt | a8b9d15d1b | |
Isaac Connor | 28a6a3e41e | |
Peter Keresztes Schmidt | e34b6500d9 | |
Peter Keresztes Schmidt | b8178dbb79 | |
Peter Keresztes Schmidt | 45654cb514 | |
Peter Keresztes Schmidt | caadc41bfd | |
Peter Keresztes Schmidt | b81689aa3f | |
Isaac Connor | 2e61ee4c95 | |
Peter Keresztes Schmidt | 339cfd49bc | |
Peter Keresztes Schmidt | e8adf5d331 | |
Isaac Connor | 09b0353592 | |
Isaac Connor | 855a81b975 | |
Isaac Connor | 096581b7f1 | |
Isaac Connor | 8511d814df | |
Isaac Connor | 195f9fc403 | |
Isaac Connor | 7417d32fbc | |
Isaac Connor | 16cc69ca2b | |
Isaac Connor | c590157431 | |
Peter Keresztes Schmidt | 8379ab70be | |
Isaac Connor | 824a6dc15b | |
Isaac Connor | 799a0ed7ba | |
Isaac Connor | 82c7474786 | |
Isaac Connor | a266388898 | |
Isaac Connor | 6e70eb5963 | |
Zoltan Gera | 714dd0aa9f | |
Isaac Connor | cf03bb9548 | |
Isaac Connor | 9e64b912a8 | |
Peter Keresztes Schmidt | 6b478484bd | |
Peter Keresztes Schmidt | d413f3c78f | |
Peter Keresztes Schmidt | 8a8dc48206 | |
Peter Keresztes Schmidt | 9f4e7178d4 | |
Peter Keresztes Schmidt | 0392828ef8 | |
Peter Keresztes Schmidt | e232b5d1a7 | |
Peter Keresztes Schmidt | 9900fc1273 | |
Peter Keresztes Schmidt | e5cac38521 | |
Peter Keresztes Schmidt | 93abbdf964 | |
Shao Yu-Lung (Allen) | 4a1d983ff1 | |
anon8675309 | b2391e952f | |
Isaac Connor | 317ce7692e | |
Isaac Connor | bc384d6fbe | |
Andrew Bauer | 2e12bc08cd | |
Andrew Bauer | 8d8b87743e | |
Peter Keresztes Schmidt | e881e97c06 | |
Andrew Bauer | eb387b5453 | |
Isaac Connor | da8128aba1 | |
Isaac Connor | f4ce2c1ea4 | |
Isaac Connor | fa34d00392 | |
Isaac Connor | a6de3e15f4 | |
Isaac Connor | aa157bfd78 |
|
@ -1,17 +1,19 @@
|
||||||
task:
|
task:
|
||||||
name: freebsd-build
|
name: freebsd-build
|
||||||
freebsd_instance:
|
freebsd_instance:
|
||||||
image_family: freebsd-12-2
|
matrix:
|
||||||
|
- image_family: freebsd-12-2
|
||||||
|
- image_family: freebsd-13-0
|
||||||
|
|
||||||
prepare_script:
|
prepare_script:
|
||||||
- pkg install -yq git cmake jpeg-turbo mysql80-client ffmpeg libvncserver libjwt catch p5-DBI p5-DBD-mysql p5-Date-Manip p5-Test-LWP-UserAgent p5-Sys-Mmap
|
- pkg install -yq git cmake pkgconf jpeg-turbo mysql80-client ffmpeg libvncserver libjwt catch p5-DBI p5-DBD-mysql p5-Date-Manip p5-Test-LWP-UserAgent p5-Sys-Mmap v4l_compat
|
||||||
|
|
||||||
configure_script:
|
configure_script:
|
||||||
- git submodule update --init --recursive
|
- git submodule update --init --recursive
|
||||||
- mkdir build
|
- mkdir build
|
||||||
- cd build
|
- cd build
|
||||||
- cmake --version
|
- cmake --version
|
||||||
- cmake ../ -DBUILD_MAN=0 -DBUILD_TEST_SUITE=1 -DENABLE_WERROR=1
|
- cmake ../ -DBUILD_MAN=0 -DBUILD_TEST_SUITE=1 -DENABLE_WERROR=1 -DCMAKE_C_FLAGS="-Wno-deprecated-declarations" -DCMAKE_CXX_FLAGS="-Wno-deprecated-declarations"
|
||||||
|
|
||||||
build_script:
|
build_script:
|
||||||
- cd build
|
- cd build
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
web/api/lib
|
web/api/lib
|
||||||
web/includes/csrf/
|
web/includes/csrf/
|
||||||
web/js/videojs.zoomrotate.js
|
web/js/videojs.zoomrotate.js
|
||||||
web/skins/classic/js/bootstrap.js
|
web/skins/classic/js/bootstrap-4.5.0.js
|
||||||
web/skins/classic/js/chosen
|
web/skins/classic/js/chosen
|
||||||
web/skins/classic/js/dateTimePicker
|
web/skins/classic/js/dateTimePicker
|
||||||
web/skins/classic/js/jquery-*.js
|
web/skins/classic/js/jquery-*.js
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
github: [connortechnology,pliablepixels] # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
|
github: [connortechnology,pliablepixels] # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
|
||||||
patreon: zoneminder # Replace with a single Patreon username
|
patreon: zoneminder # Replace with a single Patreon username
|
||||||
open_collective: # Replace with a single Open Collective username
|
open_collective: zoneminder # Replace with a single Open Collective username
|
||||||
ko_fi: # Replace with a single Ko-fi username
|
ko_fi: # Replace with a single Ko-fi username
|
||||||
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
||||||
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
|
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
name: CI Ubuntu Bionic (18.04)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
crypto_backend: [ openssl ]
|
||||||
|
jwt_backend: [ libjwt, jwt_cpp ]
|
||||||
|
include:
|
||||||
|
- crypto_backend: openssl
|
||||||
|
crypto_package: libssl-dev
|
||||||
|
jwt_package: libjwt-dev
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: ubuntu:bionic
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Update packages
|
||||||
|
run: apt-get -qq update && apt-get -qq upgrade && apt-get -qq install software-properties-common
|
||||||
|
- name: Install git
|
||||||
|
run: |
|
||||||
|
add-apt-repository ppa:git-core/ppa
|
||||||
|
apt-get -qq update
|
||||||
|
apt-get -qq install git
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: >
|
||||||
|
apt-get -qq install make cmake g++
|
||||||
|
default-libmysqlclient-dev
|
||||||
|
libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev
|
||||||
|
libcurl4-gnutls-dev libvlc-dev libvncserver-dev
|
||||||
|
libdate-manip-perl libdbd-mysql-perl libsys-mmap-perl libwww-perl
|
||||||
|
libpolkit-gobject-1-dev
|
||||||
|
${{ matrix.crypto_package }} ${{ matrix.jwt_package }}
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DENABLE_WERROR=1 -DZM_CRYPTO_BACKEND=${{ matrix.crypto_backend }} -DZM_JWT_BACKEND=${{ matrix.jwt_backend }}
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
|
@ -0,0 +1,57 @@
|
||||||
|
name: CI Debian Bullseye
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
crypto_backend: [ gnutls, openssl ]
|
||||||
|
jwt_backend: [ libjwt, jwt_cpp ]
|
||||||
|
include:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
crypto_package: libgnutls28-dev
|
||||||
|
jwt_package: libjwt-gnutls-dev
|
||||||
|
- crypto_backend: openssl
|
||||||
|
crypto_package: libssl-dev
|
||||||
|
jwt_package: libjwt-dev
|
||||||
|
exclude:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: jwt_cpp
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: debian:bullseye
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Update packages
|
||||||
|
run: apt-get -qq update && apt-get -qq upgrade
|
||||||
|
- name: Install git
|
||||||
|
run: apt-get -qq install git
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: >
|
||||||
|
apt-get -qq install make cmake g++
|
||||||
|
default-libmysqlclient-dev
|
||||||
|
libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev
|
||||||
|
libcurl4-gnutls-dev libvlc-dev libvncserver-dev
|
||||||
|
libdate-manip-perl libdbd-mysql-perl libsys-mmap-perl libwww-perl
|
||||||
|
libpolkit-gobject-1-dev
|
||||||
|
catch2
|
||||||
|
${{ matrix.crypto_package }} ${{ matrix.jwt_package }}
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DBUILD_TEST_SUITE=1 -DENABLE_WERROR=1 -DZM_CRYPTO_BACKEND=${{ matrix.crypto_backend }} -DZM_JWT_BACKEND=${{ matrix.jwt_backend }}
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
||||||
|
- name: Run tests
|
||||||
|
run: cd build/tests && ./tests "~[notCI]"
|
|
@ -0,0 +1,54 @@
|
||||||
|
name: CI Debian Buster
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
crypto_backend: [ gnutls, openssl ]
|
||||||
|
jwt_backend: [ libjwt, jwt_cpp ]
|
||||||
|
include:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
crypto_package: libgnutls28-dev
|
||||||
|
jwt_package: libjwt-gnutls-dev
|
||||||
|
- crypto_backend: openssl
|
||||||
|
crypto_package: libssl-dev
|
||||||
|
jwt_package: libjwt-dev
|
||||||
|
exclude:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: jwt_cpp
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: debian:buster
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Update packages
|
||||||
|
run: apt-get -qq update && apt-get -qq upgrade
|
||||||
|
- name: Install git
|
||||||
|
run: apt-get -qq install git
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: >
|
||||||
|
apt-get -qq install make cmake g++
|
||||||
|
default-libmysqlclient-dev
|
||||||
|
libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev
|
||||||
|
libcurl4-gnutls-dev libvlc-dev libvncserver-dev
|
||||||
|
libdate-manip-perl libdbd-mysql-perl libsys-mmap-perl libwww-perl
|
||||||
|
libpolkit-gobject-1-dev
|
||||||
|
${{ matrix.crypto_package }} ${{ matrix.jwt_package }}
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DENABLE_WERROR=1 -DZM_CRYPTO_BACKEND=${{ matrix.crypto_backend }} -DZM_JWT_BACKEND=${{ matrix.jwt_backend }}
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
|
@ -0,0 +1,39 @@
|
||||||
|
name: CI CentOS 7
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
crypto_backend: [ gnutls, openssl ]
|
||||||
|
jwt_backend: [ libjwt, jwt_cpp ]
|
||||||
|
exclude:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: jwt_cpp
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: libjwt
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: centos:7
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Enable RPMFusion and EPEL
|
||||||
|
run: yum -y install https://mirrors.rpmfusion.org/free/el/rpmfusion-free-release-7.noarch.rpm https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
|
||||||
|
- name: Install git
|
||||||
|
run: yum -y install https://repo.ius.io/ius-release-el7.rpm && yum -y install git224
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yum -y update && yum -y install make cmake3 gcc-c++ mariadb-devel ffmpeg-devel libcurl-devel vlc-devel libvncserver-devel libjpeg-turbo-devel "perl(Date::Manip)" "perl(DBD::mysql)" "perl(ExtUtils::MakeMaker)" "perl(Sys::Mmap)" "perl(Sys::Syslog)" "perl(LWP::UserAgent)" polkit-devel libjwt-devel
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake3 --version && cmake3 .. -DBUILD_MAN=0 -DENABLE_WERROR=1 -DZM_CRYPTO_BACKEND=${{ matrix.crypto_backend }} -DZM_JWT_BACKEND=${{ matrix.jwt_backend }}
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
|
@ -0,0 +1,41 @@
|
||||||
|
name: CI CentOS 8
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
crypto_backend: [ gnutls, openssl ]
|
||||||
|
jwt_backend: [ libjwt, jwt_cpp ]
|
||||||
|
exclude:
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: jwt_cpp
|
||||||
|
- crypto_backend: gnutls
|
||||||
|
jwt_backend: libjwt
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: centos:8
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Enable RPMFusion, EPEL and PowerTools
|
||||||
|
run: yum -y install "dnf-command(config-manager)" https://mirrors.rpmfusion.org/free/el/rpmfusion-free-release-8.noarch.rpm https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm && yum config-manager --set-enabled powertools
|
||||||
|
- name: Install git
|
||||||
|
run: yum -y install git
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yum -y update && yum -y install make cmake gcc-c++ catch-devel mariadb-devel ffmpeg-devel libcurl-devel vlc-devel libvncserver-devel libjpeg-turbo-devel "perl(Date::Manip)" "perl(DBD::mysql)" "perl(ExtUtils::MakeMaker)" "perl(Sys::Mmap)" "perl(Sys::Syslog)" "perl(LWP::UserAgent)" polkit-devel libjwt-devel
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DBUILD_TEST_SUITE=1 -DENABLE_WERROR=1 -DZM_CRYPTO_BACKEND=${{ matrix.crypto_backend }} -DZM_JWT_BACKEND=${{ matrix.jwt_backend }}
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
||||||
|
- name: Run tests
|
||||||
|
run: cd build/tests && ./tests "~[notCI]"
|
|
@ -0,0 +1,21 @@
|
||||||
|
name: CI ESLint
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
eslint:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install ESLint
|
||||||
|
run: npm install eslint@5.12.0 eslint-config-google@0.11.0 eslint-plugin-html@5.0.0 eslint-plugin-php-markup@0.2.5
|
||||||
|
- name: Run ESLint
|
||||||
|
run: npx eslint --ext .php,.js .
|
|
@ -0,0 +1,40 @@
|
||||||
|
name: CI Debian Stretch
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: debian:stretch-backports
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Update packages
|
||||||
|
run: apt-get -qq update && apt-get -qq upgrade
|
||||||
|
- name: Install git
|
||||||
|
run: apt-get -qq install git/stretch-backports git-man/stretch-backports
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Install dependencies
|
||||||
|
run: >
|
||||||
|
apt-get -qq install make cmake g++
|
||||||
|
default-libmysqlclient-dev
|
||||||
|
libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev
|
||||||
|
libcurl4-gnutls-dev libvlc-dev libvncserver-dev
|
||||||
|
libdate-manip-perl libdbd-mysql-perl libsys-mmap-perl libwww-perl
|
||||||
|
libpolkit-gobject-1-dev
|
||||||
|
libssl-dev
|
||||||
|
- name: Prepare
|
||||||
|
run: mkdir build
|
||||||
|
- name: Configure
|
||||||
|
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DENABLE_WERROR=1
|
||||||
|
- name: Build
|
||||||
|
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
|
@ -1,25 +0,0 @@
|
||||||
name: CI Xenial
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- '*'
|
|
||||||
pull_request:
|
|
||||||
branches: [ master ]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-16.04
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
with:
|
|
||||||
submodules: recursive
|
|
||||||
- name: Install dependencies
|
|
||||||
run: sudo apt-get update && sudo apt-get install libavdevice-dev libcurl4-gnutls-dev libvlc-dev libvncserver-dev libdate-manip-perl libdbd-mysql-perl libsys-mmap-perl libpolkit-gobject-1-dev
|
|
||||||
- name: Prepare
|
|
||||||
run: mkdir build
|
|
||||||
- name: Configure
|
|
||||||
run: cd build && cmake --version && cmake .. -DBUILD_MAN=0 -DENABLE_WERROR=1
|
|
||||||
- name: Build
|
|
||||||
run: cd build && make -j3 | grep --line-buffered -Ev '^(cp lib\/|Installing.+\.pm)' && (exit ${PIPESTATUS[0]})
|
|
|
@ -52,8 +52,8 @@ jobs:
|
||||||
git submodule init
|
git submodule init
|
||||||
git submodule update --init --recursive
|
git submodule update --init --recursive
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install libavdevice-dev libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev libjwt-gnutls-dev
|
sudo apt-get install libavcodec-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev libjwt-gnutls-dev
|
||||||
sudo apt-get install libbz2-dev libgcrypt20-dev libcurl4-gnutls-dev libjpeg-turbo8-dev libturbojpeg0-dev
|
sudo apt-get install libbz2-dev libcurl4-gnutls-dev libjpeg-turbo8-dev libturbojpeg0-dev
|
||||||
sudo apt-get install default-libmysqlclient-dev libpcre3-dev libpolkit-gobject-1-dev libv4l-dev libvlc-dev
|
sudo apt-get install default-libmysqlclient-dev libpcre3-dev libpolkit-gobject-1-dev libv4l-dev libvlc-dev
|
||||||
sudo apt-get install libdate-manip-perl libdbd-mysql-perl libphp-serialization-perl libsys-mmap-perl
|
sudo apt-get install libdate-manip-perl libdbd-mysql-perl libphp-serialization-perl libsys-mmap-perl
|
||||||
sudo apt-get install libwww-perl libdata-uuid-perl libssl-dev libcrypt-eksblowfish-perl libdata-entropy-perl
|
sudo apt-get install libwww-perl libdata-uuid-perl libssl-dev libcrypt-eksblowfish-perl libdata-entropy-perl
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
name: Create packages
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- '*'
|
||||||
|
pull_request:
|
||||||
|
branches: [ master ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
package:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
os_dist:
|
||||||
|
- os: debian
|
||||||
|
dist: buster
|
||||||
|
- os: debian
|
||||||
|
dist: bullseye
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: recursive
|
||||||
|
- name: Run packpack
|
||||||
|
env:
|
||||||
|
SMPFLAGS: -j4
|
||||||
|
OS: ${{ matrix.os_dist.os }}
|
||||||
|
DIST: ${{ matrix.os_dist.dist }}
|
||||||
|
DOCKER_REPO: iconzm/packpack
|
||||||
|
run: utils/packpack/startpackpack.sh
|
|
@ -124,6 +124,7 @@ src/zmc
|
||||||
src/zmf
|
src/zmf
|
||||||
src/zms
|
src/zms
|
||||||
src/zmu
|
src/zmu
|
||||||
|
src/zm_rtsp_server
|
||||||
src/zoneminder-zmc.8
|
src/zoneminder-zmc.8
|
||||||
src/zoneminder-zmc.8.gz
|
src/zoneminder-zmc.8.gz
|
||||||
src/zoneminder-zmf.8
|
src/zoneminder-zmf.8
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
default:
|
||||||
|
image:
|
||||||
|
name: ubuntu:latest
|
||||||
|
before_script:
|
||||||
|
- apt-get update -yq
|
||||||
|
- DEBIAN_FRONTEND=noninteractive apt-get install -yq devscripts sudo
|
||||||
|
|
||||||
|
deb:
|
||||||
|
stage: build
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
script:
|
||||||
|
- yes "" | ./utils/do_debian_package.sh --snapshot=stable --type=binary --interactive=no --dput=no --debbuild-extra=--no-sign || true
|
||||||
|
timeout: 2h
|
||||||
|
artifacts:
|
||||||
|
paths:
|
||||||
|
- '*.deb'
|
||||||
|
expire_in: 1 week
|
58
.travis.yml
58
.travis.yml
|
@ -1,58 +0,0 @@
|
||||||
language: cpp
|
|
||||||
sudo: required
|
|
||||||
dist: bionic
|
|
||||||
git:
|
|
||||||
depth: 9999999
|
|
||||||
notifications:
|
|
||||||
irc: chat.freenode.net#zoneminder-dev
|
|
||||||
branches:
|
|
||||||
except:
|
|
||||||
- modern
|
|
||||||
cache: ccache
|
|
||||||
addons:
|
|
||||||
ssh_known_hosts: zmrepo.zoneminder.com
|
|
||||||
apt:
|
|
||||||
sources:
|
|
||||||
- sourceline: ppa:iconnor/zoneminder-master
|
|
||||||
- key_url: http://keyserver.ubuntu.com:11371/pks/lookup?op=get&search=0x4D0BF748776FFB04
|
|
||||||
packages:
|
|
||||||
- gdebi
|
|
||||||
- yum-utils
|
|
||||||
- patch
|
|
||||||
- git
|
|
||||||
- curl
|
|
||||||
- sshfs
|
|
||||||
- sed
|
|
||||||
- binfmt-support
|
|
||||||
- qemu
|
|
||||||
- qemu-user-static
|
|
||||||
- dnsutils
|
|
||||||
- traceroute
|
|
||||||
install:
|
|
||||||
- update-binfmts --enable qemu-arm
|
|
||||||
|
|
||||||
env:
|
|
||||||
- SMPFLAGS=-j4 OS=eslint DIST=eslint
|
|
||||||
- SMPFLAGS=-j4 OS=ubuntu DIST=bionic DOCKER_REPO=iconzm/packpack
|
|
||||||
|
|
||||||
compiler:
|
|
||||||
- gcc
|
|
||||||
services:
|
|
||||||
- mysql
|
|
||||||
- docker
|
|
||||||
|
|
||||||
script:
|
|
||||||
- utils/packpack/startpackpack.sh
|
|
||||||
|
|
||||||
before_deploy:
|
|
||||||
- openssl aes-256-cbc -K $encrypted_62a62750aa73_key -iv $encrypted_62a62750aa73_iv -in ./utils/packpack/deploy_rsa.enc -out /tmp/deploy_rsa -d
|
|
||||||
- eval "$(ssh-agent -s)"
|
|
||||||
- chmod 600 /tmp/deploy_rsa
|
|
||||||
- ssh-add /tmp/deploy_rsa
|
|
||||||
|
|
||||||
deploy:
|
|
||||||
provider: script
|
|
||||||
skip_cleanup: true
|
|
||||||
script: utils/packpack/rsync_xfer.sh
|
|
||||||
on:
|
|
||||||
branch: master
|
|
277
CMakeLists.txt
277
CMakeLists.txt
|
@ -69,9 +69,7 @@ include(GNUInstallDirs)
|
||||||
include(CheckIncludeFile)
|
include(CheckIncludeFile)
|
||||||
include(CheckIncludeFiles)
|
include(CheckIncludeFiles)
|
||||||
include(CheckFunctionExists)
|
include(CheckFunctionExists)
|
||||||
include(CheckPrototypeDefinition_fixed)
|
|
||||||
include(CheckTypeSize)
|
include(CheckTypeSize)
|
||||||
include(CheckStructHasMember)
|
|
||||||
include(CheckSendfile)
|
include(CheckSendfile)
|
||||||
|
|
||||||
# Configuration options
|
# Configuration options
|
||||||
|
@ -169,6 +167,8 @@ set(ZM_NO_X10 "OFF" CACHE BOOL
|
||||||
set(ZM_ONVIF "ON" CACHE BOOL
|
set(ZM_ONVIF "ON" CACHE BOOL
|
||||||
"Set to ON to enable basic ONVIF support. This is EXPERIMENTAL and may not
|
"Set to ON to enable basic ONVIF support. This is EXPERIMENTAL and may not
|
||||||
work with all cameras claiming to be ONVIF compliant. default: ON")
|
work with all cameras claiming to be ONVIF compliant. default: ON")
|
||||||
|
set(ZM_NO_PCRE "OFF" CACHE BOOL
|
||||||
|
"Set to ON to skip libpcre3 checks and force building ZM without libpcre3. default: OFF")
|
||||||
set(ZM_NO_RTSPSERVER "OFF" CACHE BOOL
|
set(ZM_NO_RTSPSERVER "OFF" CACHE BOOL
|
||||||
"Set to ON to skip building ZM with rtsp server support. default: OFF")
|
"Set to ON to skip building ZM with rtsp server support. default: OFF")
|
||||||
set(ZM_PERL_MM_PARMS INSTALLDIRS=vendor NO_PACKLIST=1 NO_PERLLOCAL=1 CACHE STRING
|
set(ZM_PERL_MM_PARMS INSTALLDIRS=vendor NO_PACKLIST=1 NO_PERLLOCAL=1 CACHE STRING
|
||||||
|
@ -192,6 +192,24 @@ set(ZM_MANPAGE_DEST_PREFIX "share/man" CACHE PATH
|
||||||
set(ZM_CAKEPHP_CACHE "Apc" CACHE STRING
|
set(ZM_CAKEPHP_CACHE "Apc" CACHE STRING
|
||||||
"Set the CakePHP cache engine, default: Apc")
|
"Set the CakePHP cache engine, default: Apc")
|
||||||
|
|
||||||
|
# Supported crypto backends. Using OpenSSL by default to be compatible with jwt-cpp.
|
||||||
|
set(ZM_CRYPTO_BACKEND_OPTIONS gnutls openssl)
|
||||||
|
set(ZM_CRYPTO_BACKEND openssl CACHE STRING "Determines which crypto backend should be used.")
|
||||||
|
set_property(CACHE ZM_CRYPTO_BACKEND PROPERTY STRINGS ${ZM_CRYPTO_BACKEND_OPTIONS})
|
||||||
|
|
||||||
|
if(NOT ZM_CRYPTO_BACKEND IN_LIST ZM_CRYPTO_BACKEND_OPTIONS)
|
||||||
|
message(FATAL_ERROR "Invalid value for ZM_CRYPTO_BACKEND. Possible options: ${ZM_CRYPTO_BACKEND_OPTIONS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Supported JWT backends. Using jwt-cpp as default.
|
||||||
|
set(ZM_JWT_BACKEND_OPTIONS libjwt jwt_cpp)
|
||||||
|
set(ZM_JWT_BACKEND jwt_cpp CACHE STRING "Determines which JWT backend should be used.")
|
||||||
|
set_property(CACHE ZM_JWT_BACKEND PROPERTY STRINGS ${ZM_JWT_BACKEND_OPTIONS})
|
||||||
|
|
||||||
|
if(NOT ZM_JWT_BACKEND IN_LIST ZM_JWT_BACKEND_OPTIONS)
|
||||||
|
message(FATAL_ERROR "Invalid value for ZM_JWT_BACKEND. Possible options: ${ZM_JWT_BACKEND_OPTIONS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Reassign some variables if a target distro has been specified
|
# Reassign some variables if a target distro has been specified
|
||||||
if(ZM_TARGET_DISTRO MATCHES "^fc")
|
if(ZM_TARGET_DISTRO MATCHES "^fc")
|
||||||
set(ZM_CAKEPHP_CACHE "Memcached")
|
set(ZM_CAKEPHP_CACHE "Memcached")
|
||||||
|
@ -252,11 +270,6 @@ if(ZM_SYSTEMD OR (IS_DIRECTORY /usr/lib/systemd/system) OR (IS_DIRECTORY /lib/sy
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# System checks
|
# System checks
|
||||||
check_include_file("libv4l1-videodev.h" HAVE_LIBV4L1_VIDEODEV_H)
|
|
||||||
if(NOT HAVE_LIBV4L1_VIDEODEV_H)
|
|
||||||
check_include_file("linux/videodev.h" HAVE_LINUX_VIDEODEV_H)
|
|
||||||
endif()
|
|
||||||
check_include_file("linux/videodev2.h" HAVE_LINUX_VIDEODEV2_H)
|
|
||||||
check_include_file("execinfo.h" HAVE_EXECINFO_H)
|
check_include_file("execinfo.h" HAVE_EXECINFO_H)
|
||||||
if(HAVE_EXECINFO_H)
|
if(HAVE_EXECINFO_H)
|
||||||
check_function_exists("backtrace" HAVE_DECL_BACKTRACE)
|
check_function_exists("backtrace" HAVE_DECL_BACKTRACE)
|
||||||
|
@ -336,19 +349,20 @@ else()
|
||||||
"ZoneMinder requires jpeg but it was not found on your system")
|
"ZoneMinder requires jpeg but it was not found on your system")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# LIBJWT
|
# libjwt
|
||||||
find_package(LibJWT)
|
if (${ZM_JWT_BACKEND} STREQUAL "libjwt")
|
||||||
if(LIBJWT_FOUND)
|
find_package(LibJWT REQUIRED COMPONENTS ${ZM_CRYPTO_BACKEND})
|
||||||
|
if(LIBJWT_FOUND)
|
||||||
set(HAVE_LIBJWT 1)
|
set(HAVE_LIBJWT 1)
|
||||||
set(optlibsfound "${optlibsfound} LIBJWT")
|
set(optlibsfound "${optlibsfound} LIBJWT")
|
||||||
list(APPEND ZM_BIN_LIBS "${LIBJWT_LIBRARY}")
|
else()
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} LIBJWT")
|
set(optlibsnotfound "${optlibsnotfound} LIBJWT")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# gnutls (using find_library and find_path)
|
# GnuTLS
|
||||||
if(HAVE_LIBJWT)
|
if (${ZM_CRYPTO_BACKEND} STREQUAL "gnutls")
|
||||||
find_library(GNUTLS_LIBRARIES gnutls)
|
find_library(GNUTLS_LIBRARIES gnutls REQUIRED)
|
||||||
if(GNUTLS_LIBRARIES)
|
if(GNUTLS_LIBRARIES)
|
||||||
set(HAVE_LIBGNUTLS 1)
|
set(HAVE_LIBGNUTLS 1)
|
||||||
list(APPEND ZM_BIN_LIBS "${GNUTLS_LIBRARIES}")
|
list(APPEND ZM_BIN_LIBS "${GNUTLS_LIBRARIES}")
|
||||||
|
@ -358,23 +372,18 @@ if(HAVE_LIBJWT)
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${GNUTLS_INCLUDE_DIR}")
|
set(CMAKE_REQUIRED_INCLUDES "${GNUTLS_INCLUDE_DIR}")
|
||||||
endif()
|
endif()
|
||||||
mark_as_advanced(FORCE GNUTLS_LIBRARIES GNUTLS_INCLUDE_DIR)
|
mark_as_advanced(FORCE GNUTLS_LIBRARIES GNUTLS_INCLUDE_DIR)
|
||||||
check_include_file("gnutls/gnutls.h" HAVE_GNUTLS_GNUTLS_H)
|
|
||||||
set(optlibsfound "${optlibsfound} GnuTLS")
|
set(optlibsfound "${optlibsfound} GnuTLS")
|
||||||
else()
|
else()
|
||||||
set(optlibsnotfound "${optlibsnotfound} GnuTLS")
|
set(optlibsnotfound "${optlibsnotfound} GnuTLS")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
|
||||||
|
|
||||||
# OpenSSL
|
# OpenSSL
|
||||||
if(NOT HAVE_LIBGNUTLS OR NOT HAVE_LIBJWT)
|
elseif (${ZM_CRYPTO_BACKEND} STREQUAL "openssl")
|
||||||
find_package(OpenSSL)
|
find_package(OpenSSL REQUIRED)
|
||||||
if(OPENSSL_FOUND)
|
if(OPENSSL_FOUND)
|
||||||
set(HAVE_LIBOPENSSL 1)
|
set(HAVE_LIBOPENSSL 1)
|
||||||
set(HAVE_LIBCRYPTO 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${OPENSSL_LIBRARIES}")
|
list(APPEND ZM_BIN_LIBS "${OPENSSL_LIBRARIES}")
|
||||||
include_directories("${OPENSSL_INCLUDE_DIR}")
|
include_directories("${OPENSSL_INCLUDE_DIR}")
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${OPENSSL_INCLUDE_DIR}")
|
set(CMAKE_REQUIRED_INCLUDES "${OPENSSL_INCLUDE_DIR}")
|
||||||
check_include_file("openssl/md5.h" HAVE_OPENSSL_MD5_H)
|
|
||||||
set(optlibsfound "${optlibsfound} OpenSSL")
|
set(optlibsfound "${optlibsfound} OpenSSL")
|
||||||
else()
|
else()
|
||||||
set(optlibsnotfound "${optlibsnotfound} OpenSSL")
|
set(optlibsnotfound "${optlibsnotfound} OpenSSL")
|
||||||
|
@ -400,9 +409,11 @@ else()
|
||||||
message(FATAL_ERROR "ZoneMinder requires pthread but it was not found on your system")
|
message(FATAL_ERROR "ZoneMinder requires pthread but it was not found on your system")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# pcre (using find_library and find_path)
|
# Do not check for cURL if ZM_NO_CURL is on
|
||||||
find_library(PCRE_LIBRARIES pcre)
|
if(NOT ZM_NO_PRCE)
|
||||||
if(PCRE_LIBRARIES)
|
# pcre (using find_library and find_path)
|
||||||
|
find_library(PCRE_LIBRARIES pcre)
|
||||||
|
if(PCRE_LIBRARIES)
|
||||||
set(HAVE_LIBPCRE 1)
|
set(HAVE_LIBPCRE 1)
|
||||||
list(APPEND ZM_BIN_LIBS "${PCRE_LIBRARIES}")
|
list(APPEND ZM_BIN_LIBS "${PCRE_LIBRARIES}")
|
||||||
find_path(PCRE_INCLUDE_DIR pcre.h)
|
find_path(PCRE_INCLUDE_DIR pcre.h)
|
||||||
|
@ -413,25 +424,9 @@ if(PCRE_LIBRARIES)
|
||||||
mark_as_advanced(FORCE PCRE_LIBRARIES PCRE_INCLUDE_DIR)
|
mark_as_advanced(FORCE PCRE_LIBRARIES PCRE_INCLUDE_DIR)
|
||||||
check_include_file("pcre.h" HAVE_PCRE_H)
|
check_include_file("pcre.h" HAVE_PCRE_H)
|
||||||
set(optlibsfound "${optlibsfound} PCRE")
|
set(optlibsfound "${optlibsfound} PCRE")
|
||||||
else()
|
else()
|
||||||
set(optlibsnotfound "${optlibsnotfound} PCRE")
|
set(optlibsnotfound "${optlibsnotfound} PCRE")
|
||||||
endif()
|
|
||||||
|
|
||||||
# gcrypt (using find_library and find_path)
|
|
||||||
find_library(GCRYPT_LIBRARIES gcrypt)
|
|
||||||
if(GCRYPT_LIBRARIES)
|
|
||||||
set(HAVE_LIBGCRYPT 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${GCRYPT_LIBRARIES}")
|
|
||||||
find_path(GCRYPT_INCLUDE_DIR gcrypt.h)
|
|
||||||
if(GCRYPT_INCLUDE_DIR)
|
|
||||||
include_directories("${GCRYPT_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${GCRYPT_INCLUDE_DIR}")
|
|
||||||
endif()
|
endif()
|
||||||
mark_as_advanced(FORCE GCRYPT_LIBRARIES GCRYPT_INCLUDE_DIR)
|
|
||||||
check_include_file("gcrypt.h" HAVE_GCRYPT_H)
|
|
||||||
set(optlibsfound "${optlibsfound} GCrypt")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} GCrypt")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# mysqlclient (using find_library and find_path)
|
# mysqlclient (using find_library and find_path)
|
||||||
|
@ -453,129 +448,19 @@ else()
|
||||||
message(FATAL_ERROR "ZoneMinder requires mysqlclient but it was not found on your system")
|
message(FATAL_ERROR "ZoneMinder requires mysqlclient but it was not found on your system")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
find_package(FFMPEG 55.34.100 REQUIRED
|
||||||
|
COMPONENTS
|
||||||
|
avcodec
|
||||||
|
avformat
|
||||||
|
avutil
|
||||||
|
swresample
|
||||||
|
swscale)
|
||||||
|
|
||||||
|
set(CMAKE_REQUIRED_INCLUDES ${FFMPEG_avutil_INCLUDE_DIRS})
|
||||||
|
check_include_file("libavutil/hwcontext.h" HAVE_LIBAVUTIL_HWCONTEXT_H)
|
||||||
|
|
||||||
set(PATH_FFMPEG "")
|
set(PATH_FFMPEG "")
|
||||||
set(OPT_FFMPEG "no")
|
set(OPT_FFMPEG "no")
|
||||||
# avformat (using find_library and find_path)
|
|
||||||
find_library(AVFORMAT_LIBRARIES avformat)
|
|
||||||
if(AVFORMAT_LIBRARIES)
|
|
||||||
set(HAVE_LIBAVFORMAT 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${AVFORMAT_LIBRARIES}")
|
|
||||||
find_path(AVFORMAT_INCLUDE_DIR "libavformat/avformat.h" /usr/include/ffmpeg)
|
|
||||||
if(AVFORMAT_INCLUDE_DIR)
|
|
||||||
include_directories("${AVFORMAT_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${AVFORMAT_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE AVFORMAT_LIBRARIES AVFORMAT_INCLUDE_DIR)
|
|
||||||
check_include_file("libavformat/avformat.h" HAVE_LIBAVFORMAT_AVFORMAT_H)
|
|
||||||
set(optlibsfound "${optlibsfound} AVFormat")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} AVFormat")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# avcodec (using find_library and find_path)
|
|
||||||
find_library(AVCODEC_LIBRARIES avcodec)
|
|
||||||
if(AVCODEC_LIBRARIES)
|
|
||||||
set(HAVE_LIBAVCODEC 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${AVCODEC_LIBRARIES}")
|
|
||||||
find_path(AVCODEC_INCLUDE_DIR "libavcodec/avcodec.h" /usr/include/ffmpeg)
|
|
||||||
if(AVCODEC_INCLUDE_DIR)
|
|
||||||
include_directories("${AVCODEC_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${AVCODEC_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE AVCODEC_LIBRARIES AVCODEC_INCLUDE_DIR)
|
|
||||||
check_include_file("libavcodec/avcodec.h" HAVE_LIBAVCODEC_AVCODEC_H)
|
|
||||||
set(optlibsfound "${optlibsfound} AVCodec")
|
|
||||||
else()
|
|
||||||
message(WARNING "\nWhile it should be possible to build ZM without AVCODEC the result will pretty useless.")
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} AVCodec")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# avdevice (using find_library and find_path)
|
|
||||||
find_library(AVDEVICE_LIBRARIES avdevice)
|
|
||||||
if(AVDEVICE_LIBRARIES)
|
|
||||||
set(HAVE_LIBAVDEVICE 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${AVDEVICE_LIBRARIES}")
|
|
||||||
find_path(AVDEVICE_INCLUDE_DIR "libavdevice/avdevice.h" /usr/include/ffmpeg)
|
|
||||||
if(AVDEVICE_INCLUDE_DIR)
|
|
||||||
include_directories("${AVDEVICE_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${AVDEVICE_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE AVDEVICE_LIBRARIES AVDEVICE_INCLUDE_DIR)
|
|
||||||
check_include_file("libavdevice/avdevice.h" HAVE_LIBAVDEVICE_AVDEVICE_H)
|
|
||||||
set(optlibsfound "${optlibsfound} AVDevice")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} AVDevice")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# avutil (using find_library and find_path)
|
|
||||||
find_library(AVUTIL_LIBRARIES avutil)
|
|
||||||
if(AVUTIL_LIBRARIES)
|
|
||||||
set(HAVE_LIBAVUTIL 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${AVUTIL_LIBRARIES}")
|
|
||||||
find_path(AVUTIL_INCLUDE_DIR "libavutil/avutil.h" /usr/include/ffmpeg)
|
|
||||||
if(AVUTIL_INCLUDE_DIR)
|
|
||||||
include_directories("${AVUTIL_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${AVUTIL_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE AVUTIL_LIBRARIES AVUTIL_INCLUDE_DIR)
|
|
||||||
check_include_file("libavutil/avutil.h" HAVE_LIBAVUTIL_AVUTIL_H)
|
|
||||||
check_include_file("libavutil/mathematics.h" HAVE_LIBAVUTIL_MATHEMATICS_H)
|
|
||||||
check_include_file("libavutil/hwcontext.h" HAVE_LIBAVUTIL_HWCONTEXT_H)
|
|
||||||
set(optlibsfound "${optlibsfound} AVUtil")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} AVUtil")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# swscale (using find_library and find_path)
|
|
||||||
find_library(SWSCALE_LIBRARIES swscale)
|
|
||||||
if(SWSCALE_LIBRARIES)
|
|
||||||
set(HAVE_LIBSWSCALE 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${SWSCALE_LIBRARIES}")
|
|
||||||
find_path(SWSCALE_INCLUDE_DIR "libswscale/swscale.h" /usr/include/ffmpeg)
|
|
||||||
if(SWSCALE_INCLUDE_DIR)
|
|
||||||
include_directories("${SWSCALE_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${SWSCALE_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE SWSCALE_LIBRARIES SWSCALE_INCLUDE_DIR)
|
|
||||||
check_include_file("libswscale/swscale.h" HAVE_LIBSWSCALE_SWSCALE_H)
|
|
||||||
set(optlibsfound "${optlibsfound} SWScale")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} SWScale")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# SWresample (using find_library and find_path)
|
|
||||||
find_library(SWRESAMPLE_LIBRARIES swresample)
|
|
||||||
if(SWRESAMPLE_LIBRARIES)
|
|
||||||
set(HAVE_LIBSWRESAMPLE 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${SWRESAMPLE_LIBRARIES}")
|
|
||||||
find_path(SWRESAMPLE_INCLUDE_DIR "libswresample/swresample.h" /usr/include/ffmpeg)
|
|
||||||
if(SWRESAMPLE_INCLUDE_DIR)
|
|
||||||
include_directories("${SWRESAMPLE_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${SWRESAMPLE_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE SWRESAMPLE_LIBRARIES SWRESAMPLE_INCLUDE_DIR)
|
|
||||||
check_include_file("libswresample/swresample.h" HAVE_LIBSWRESAMPLE_SWRESAMPLE_H)
|
|
||||||
set(optlibsfound "${optlibsfound} SWResample")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} SWResample")
|
|
||||||
|
|
||||||
# AVresample (using find_library and find_path)
|
|
||||||
find_library(AVRESAMPLE_LIBRARIES avresample)
|
|
||||||
if(AVRESAMPLE_LIBRARIES)
|
|
||||||
set(HAVE_LIBAVRESAMPLE 1)
|
|
||||||
list(APPEND ZM_BIN_LIBS "${AVRESAMPLE_LIBRARIES}")
|
|
||||||
find_path(AVRESAMPLE_INCLUDE_DIR "libavresample/avresample.h" /usr/include/ffmpeg)
|
|
||||||
if(AVRESAMPLE_INCLUDE_DIR)
|
|
||||||
include_directories("${AVRESAMPLE_INCLUDE_DIR}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${AVRESAMPLE_INCLUDE_DIR}")
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(FORCE AVRESAMPLE_LIBRARIES AVRESAMPLE_INCLUDE_DIR)
|
|
||||||
check_include_file("libavresample/avresample.h" HAVE_LIBAVRESAMPLE_AVRESAMPLE_H)
|
|
||||||
set(optlibsfound "${optlibsfound} AVResample")
|
|
||||||
else()
|
|
||||||
set(optlibsnotfound "${optlibsnotfound} AVResample")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Find the path to the ffmpeg executable
|
# Find the path to the ffmpeg executable
|
||||||
find_program(FFMPEG_EXECUTABLE
|
find_program(FFMPEG_EXECUTABLE
|
||||||
|
@ -642,34 +527,25 @@ endif()
|
||||||
#
|
#
|
||||||
# *** END OF LIBRARY CHECKS ***
|
# *** END OF LIBRARY CHECKS ***
|
||||||
|
|
||||||
# Check for gnutls or crypto
|
# If libjwt is not present we fall back to jwt-cpp which requires OpenSSL
|
||||||
if((NOT HAVE_LIBCRYPTO) AND (NOT HAVE_LIBGNUTLS))
|
if((NOT HAVE_LIBJWT) AND (NOT HAVE_LIBOPENSSL))
|
||||||
message(FATAL_ERROR "ZoneMinder requires crypto or gnutls but none were found on your system")
|
message(FATAL_ERROR "Using the jwt-cpp backend requires OpenSSL as crypto backend.")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check for V4L header files and enable ZM_HAS_V4L, ZM_HAS_V4L1, ZM_HAS_V4L2 accordingly
|
find_package(V4L2)
|
||||||
# Setting to zeros first is required because ZM uses #define for these
|
if(TARGET V4L2::videodev2)
|
||||||
set(ZM_HAS_V4L 0)
|
|
||||||
set(ZM_HAS_V4L1 0)
|
|
||||||
set(ZM_HAS_V4L2 0)
|
|
||||||
if(HAVE_LINUX_VIDEODEV_H OR HAVE_LIBV4L1_VIDEODEV_H)
|
|
||||||
set(ZM_HAS_V4L 1)
|
|
||||||
set(ZM_HAS_V4L1 1)
|
|
||||||
endif()
|
|
||||||
if(HAVE_LINUX_VIDEODEV2_H)
|
|
||||||
set(ZM_HAS_V4L 1)
|
|
||||||
set(ZM_HAS_V4L2 1)
|
set(ZM_HAS_V4L2 1)
|
||||||
endif()
|
else()
|
||||||
if((NOT HAVE_LINUX_VIDEODEV_H)
|
set(ZM_HAS_V4L2 0)
|
||||||
AND (NOT HAVE_LIBV4L1_VIDEODEV_H)
|
|
||||||
AND (NOT HAVE_LINUX_VIDEODEV2_H))
|
|
||||||
message(AUTHOR_WARNING "Video 4 Linux headers weren't found - Analog and USB camera support will not be available")
|
message(AUTHOR_WARNING "Video 4 Linux headers weren't found - Analog and USB camera support will not be available")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check for PCRE and enable ZM_PCRE accordingly
|
# Check for PCRE and enable ZM_PCRE accordingly
|
||||||
set(ZM_PCRE 0)
|
set(ZM_PCRE 0)
|
||||||
if(HAVE_LIBPCRE AND HAVE_PCRE_H)
|
if(HAVE_LIBPCRE AND HAVE_PCRE_H)
|
||||||
set(ZM_PCRE 1)
|
set(ZM_PCRE 1)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check for mmap and enable in all components
|
# Check for mmap and enable in all components
|
||||||
set(ZM_MEM_MAPPED 0)
|
set(ZM_MEM_MAPPED 0)
|
||||||
set(ENABLE_MMAP no)
|
set(ENABLE_MMAP no)
|
||||||
|
@ -685,42 +561,6 @@ if(ZM_ONVIF)
|
||||||
set(ZM_HAS_ONVIF 1)
|
set(ZM_HAS_ONVIF 1)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check for authentication functions
|
|
||||||
if(HAVE_OPENSSL_MD5_H)
|
|
||||||
set(CMAKE_REQUIRED_LIBRARIES "${OPENSSL_LIBRARIES}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${OPENSSL_INCLUDE_DIR}")
|
|
||||||
check_prototype_definition(
|
|
||||||
MD5
|
|
||||||
"unsigned char *MD5(const unsigned char *d, size_t n, unsigned char *md)" "NULL" "openssl/md5.h"
|
|
||||||
HAVE_MD5_OPENSSL)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(HAVE_GNUTLS_GNUTLS_H)
|
|
||||||
set(CMAKE_REQUIRED_LIBRARIES "${GNUTLS_LIBRARIES}")
|
|
||||||
set(CMAKE_REQUIRED_INCLUDES "${GNUTLS_INCLUDE_DIR}")
|
|
||||||
check_prototype_definition(
|
|
||||||
gnutls_fingerprint
|
|
||||||
"int gnutls_fingerprint (gnutls_digest_algorithm_t algo, const gnutls_datum_t * data, void *result, size_t * result_size)" "0" "stdlib.h;gnutls/gnutls.h"
|
|
||||||
HAVE_DECL_GNUTLS_FINGERPRINT)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT HAVE_DECL_GNUTLS_FINGERPRINT AND HAVE_MD5_OPENSSL)
|
|
||||||
set(HAVE_DECL_MD5 1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if((NOT HAVE_MD5_OPENSSL) AND (NOT HAVE_DECL_GNUTLS_FINGERPRINT))
|
|
||||||
message(AUTHOR_WARNING
|
|
||||||
"ZoneMinder requires a working MD5 function for hashed authentication but
|
|
||||||
none were found - hashed authentication will not be available")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Dirty fix for zm_user only using openssl's md5 if gnutls and gcrypt are not available.
|
|
||||||
# This needs to be fixed in zm_user.[h,cpp] but such fix will also require changes to configure.ac
|
|
||||||
if(HAVE_LIBCRYPTO AND HAVE_OPENSSL_MD5_H AND HAVE_MD5_OPENSSL)
|
|
||||||
set(HAVE_GCRYPT_H 0)
|
|
||||||
set(HAVE_GNUTLS_OPENSSL_H 0)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Check for Perl
|
# Check for Perl
|
||||||
find_package(Perl)
|
find_package(Perl)
|
||||||
if(NOT PERL_FOUND)
|
if(NOT PERL_FOUND)
|
||||||
|
@ -858,6 +698,9 @@ endif()
|
||||||
message(STATUS "Optional libraries found:${optlibsfound}")
|
message(STATUS "Optional libraries found:${optlibsfound}")
|
||||||
message(STATUS "Optional libraries not found:${optlibsnotfound}")
|
message(STATUS "Optional libraries not found:${optlibsnotfound}")
|
||||||
|
|
||||||
|
message(STATUS "Enabled crypto backend: ${ZM_CRYPTO_BACKEND}")
|
||||||
|
message(STATUS "Enabled JWT backend: ${ZM_JWT_BACKEND}")
|
||||||
|
|
||||||
# Run ZM configuration generator
|
# Run ZM configuration generator
|
||||||
message(STATUS "Running ZoneMinder configuration generator")
|
message(STATUS "Running ZoneMinder configuration generator")
|
||||||
execute_process(COMMAND perl ${CMAKE_CURRENT_BINARY_DIR}/zmconfgen.pl RESULT_VARIABLE ZMCONFGEN_RESULT)
|
execute_process(COMMAND perl ${CMAKE_CURRENT_BINARY_DIR}/zmconfgen.pl RESULT_VARIABLE ZMCONFGEN_RESULT)
|
||||||
|
|
|
@ -30,7 +30,7 @@ This is the recommended method to install ZoneMinder onto your system. ZoneMinde
|
||||||
- Debian from their [default repository](https://packages.debian.org/search?searchon=names&keywords=zoneminder)
|
- Debian from their [default repository](https://packages.debian.org/search?searchon=names&keywords=zoneminder)
|
||||||
- RHEL/CentOS and clones via [RPM Fusion](http://rpmfusion.org)
|
- RHEL/CentOS and clones via [RPM Fusion](http://rpmfusion.org)
|
||||||
- Fedora via [RPM Fusion](http://rpmfusion.org)
|
- Fedora via [RPM Fusion](http://rpmfusion.org)
|
||||||
- OpenSuse via [third party repository](http://www.zoneminder.com/wiki/index.php/Installing_using_ZoneMinder_RPMs_for_SuSE)
|
- OpenSuse via [third party repository](https://wiki.zoneminder.com/Installing_using_ZoneMinder_RPMs_for_SuSE)
|
||||||
- Mageia from their default repository
|
- Mageia from their default repository
|
||||||
- Arch via the [AUR](https://aur.archlinux.org/packages/zoneminder/)
|
- Arch via the [AUR](https://aur.archlinux.org/packages/zoneminder/)
|
||||||
- Gentoo via [Portage Overlays](http://gpo.zugaina.org/www-misc/zoneminder)
|
- Gentoo via [Portage Overlays](http://gpo.zugaina.org/www-misc/zoneminder)
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
@CHECK_PROTOTYPE_DEFINITION_HEADER@
|
|
||||||
|
|
||||||
static void cmakeRequireSymbol(int dummy, ...) {
|
|
||||||
(void) dummy;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void checkSymbol(void) {
|
|
||||||
#ifndef @CHECK_PROTOTYPE_DEFINITION_SYMBOL@
|
|
||||||
cmakeRequireSymbol(0, &@CHECK_PROTOTYPE_DEFINITION_SYMBOL@);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
@CHECK_PROTOTYPE_DEFINITION_PROTO@ {
|
|
||||||
return @CHECK_PROTOTYPE_DEFINITION_RETURN@;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __CLASSIC_C__
|
|
||||||
int main() {
|
|
||||||
int ac;
|
|
||||||
char*av[];
|
|
||||||
#else
|
|
||||||
int main(int ac, char *av[]) {
|
|
||||||
#endif
|
|
||||||
checkSymbol();
|
|
||||||
if (ac > 1000) {
|
|
||||||
return *av[0];
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
|
@ -1,98 +0,0 @@
|
||||||
# - Check if the protoype we expect is correct.
|
|
||||||
# check_prototype_definition(FUNCTION PROTOTYPE RETURN HEADER VARIABLE)
|
|
||||||
# FUNCTION - The name of the function (used to check if prototype exists)
|
|
||||||
# PROTOTYPE- The prototype to check.
|
|
||||||
# RETURN - The return value of the function.
|
|
||||||
# HEADER - The header files required.
|
|
||||||
# VARIABLE - The variable to store the result.
|
|
||||||
# Example:
|
|
||||||
# check_prototype_definition(getpwent_r
|
|
||||||
# "struct passwd *getpwent_r(struct passwd *src, char *buf, int buflen)"
|
|
||||||
# "NULL"
|
|
||||||
# "unistd.h;pwd.h"
|
|
||||||
# SOLARIS_GETPWENT_R)
|
|
||||||
# The following variables may be set before calling this macro to
|
|
||||||
# modify the way the check is run:
|
|
||||||
#
|
|
||||||
# CMAKE_REQUIRED_FLAGS = string of compile command line flags
|
|
||||||
# CMAKE_REQUIRED_DEFINITIONS = list of macros to define (-DFOO=bar)
|
|
||||||
# CMAKE_REQUIRED_INCLUDES = list of include directories
|
|
||||||
# CMAKE_REQUIRED_LIBRARIES = list of libraries to link
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Copyright 2005-2009 Kitware, Inc.
|
|
||||||
# Copyright 2010-2011 Andreas Schneider <asn@cryptomilk.org>
|
|
||||||
#
|
|
||||||
# Distributed under the OSI-approved BSD License (the "License");
|
|
||||||
# see accompanying file Copyright.txt for details.
|
|
||||||
#
|
|
||||||
# This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
||||||
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
# See the License for more information.
|
|
||||||
#=============================================================================
|
|
||||||
# (To distribute this file outside of CMake, substitute the full
|
|
||||||
# License text for the above reference.)
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
get_filename_component(__check_proto_def_dir "${CMAKE_CURRENT_LIST_FILE}" PATH)
|
|
||||||
|
|
||||||
|
|
||||||
function(CHECK_PROTOTYPE_DEFINITION _FUNCTION _PROTOTYPE _RETURN _HEADER _VARIABLE)
|
|
||||||
|
|
||||||
if ("${_VARIABLE}" MATCHES "^${_VARIABLE}$")
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_CONTENT "/* */\n")
|
|
||||||
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_FLAGS ${CMAKE_REQUIRED_FLAGS})
|
|
||||||
if (CMAKE_REQUIRED_LIBRARIES)
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_LIBS
|
|
||||||
LINK_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES})
|
|
||||||
else()
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_LIBS)
|
|
||||||
endif()
|
|
||||||
if (CMAKE_REQUIRED_INCLUDES)
|
|
||||||
set(CMAKE_SYMBOL_EXISTS_INCLUDES
|
|
||||||
"-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}")
|
|
||||||
else()
|
|
||||||
set(CMAKE_SYMBOL_EXISTS_INCLUDES)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
foreach(_FILE ${_HEADER})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_HEADER
|
|
||||||
"${CHECK_PROTOTYPE_DEFINITION_HEADER}#include <${_FILE}>\n")
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_SYMBOL ${_FUNCTION})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_PROTO ${_PROTOTYPE})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_RETURN ${_RETURN})
|
|
||||||
|
|
||||||
configure_file("${__check_proto_def_dir}/CheckPrototypeDefinition.c.in"
|
|
||||||
"${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c" @ONLY)
|
|
||||||
|
|
||||||
file(READ ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c _SOURCE)
|
|
||||||
|
|
||||||
try_compile(${_VARIABLE}
|
|
||||||
${CMAKE_BINARY_DIR}
|
|
||||||
${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c
|
|
||||||
COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS}
|
|
||||||
${CHECK_PROTOTYPE_DEFINITION_LIBS}
|
|
||||||
CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${CHECK_PROTOTYPE_DEFINITION_FLAGS}
|
|
||||||
"${CMAKE_SYMBOL_EXISTS_INCLUDES}"
|
|
||||||
OUTPUT_VARIABLE OUTPUT)
|
|
||||||
|
|
||||||
if (${_VARIABLE})
|
|
||||||
set(${_VARIABLE} 1 CACHE INTERNAL "Have correct prototype for ${_FUNCTION}")
|
|
||||||
message(STATUS "Checking prototype ${_FUNCTION} for ${_VARIABLE} - True")
|
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
|
|
||||||
"Determining if the prototype ${_FUNCTION} exists for ${_VARIABLE} passed with the following output:\n"
|
|
||||||
"${OUTPUT}\n\n")
|
|
||||||
else ()
|
|
||||||
message(STATUS "Checking prototype ${_FUNCTION} for ${_VARIABLE} - False")
|
|
||||||
set(${_VARIABLE} 0 CACHE INTERNAL "Have correct prototype for ${_FUNCTION}")
|
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
|
|
||||||
"Determining if the prototype ${_FUNCTION} exists for ${_VARIABLE} failed with the following output:\n"
|
|
||||||
"${OUTPUT}\n\n${_SOURCE}\n\n")
|
|
||||||
endif ()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endfunction()
|
|
|
@ -1,98 +0,0 @@
|
||||||
# - Check if the protoype we expect is correct.
|
|
||||||
# check_prototype_definition(FUNCTION PROTOTYPE RETURN HEADER VARIABLE)
|
|
||||||
# FUNCTION - The name of the function (used to check if prototype exists)
|
|
||||||
# PROTOTYPE- The prototype to check.
|
|
||||||
# RETURN - The return value of the function.
|
|
||||||
# HEADER - The header files required.
|
|
||||||
# VARIABLE - The variable to store the result.
|
|
||||||
# Example:
|
|
||||||
# check_prototype_definition(getpwent_r
|
|
||||||
# "struct passwd *getpwent_r(struct passwd *src, char *buf, int buflen)"
|
|
||||||
# "NULL"
|
|
||||||
# "unistd.h;pwd.h"
|
|
||||||
# SOLARIS_GETPWENT_R)
|
|
||||||
# The following variables may be set before calling this macro to
|
|
||||||
# modify the way the check is run:
|
|
||||||
#
|
|
||||||
# CMAKE_REQUIRED_FLAGS = string of compile command line flags
|
|
||||||
# CMAKE_REQUIRED_DEFINITIONS = list of macros to define (-DFOO=bar)
|
|
||||||
# CMAKE_REQUIRED_INCLUDES = list of include directories
|
|
||||||
# CMAKE_REQUIRED_LIBRARIES = list of libraries to link
|
|
||||||
|
|
||||||
#=============================================================================
|
|
||||||
# Copyright 2005-2009 Kitware, Inc.
|
|
||||||
# Copyright 2010-2011 Andreas Schneider <asn@cryptomilk.org>
|
|
||||||
#
|
|
||||||
# Distributed under the OSI-approved BSD License (the "License");
|
|
||||||
# see accompanying file Copyright.txt for details.
|
|
||||||
#
|
|
||||||
# This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
||||||
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
# See the License for more information.
|
|
||||||
#=============================================================================
|
|
||||||
# (To distribute this file outside of CMake, substitute the full
|
|
||||||
# License text for the above reference.)
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
get_filename_component(__check_proto_def_dir "${CMAKE_CURRENT_LIST_FILE}" PATH)
|
|
||||||
|
|
||||||
|
|
||||||
function(CHECK_PROTOTYPE_DEFINITION _FUNCTION _PROTOTYPE _RETURN _HEADER _VARIABLE)
|
|
||||||
|
|
||||||
if ("${_VARIABLE}" MATCHES "^${_VARIABLE}$")
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_CONTENT "/* */\n")
|
|
||||||
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_FLAGS ${CMAKE_REQUIRED_FLAGS})
|
|
||||||
if (CMAKE_REQUIRED_LIBRARIES)
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_LIBS
|
|
||||||
${LINK_LIBRARIES} ${CMAKE_REQUIRED_LIBRARIES})
|
|
||||||
else()
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_LIBS)
|
|
||||||
endif()
|
|
||||||
if (CMAKE_REQUIRED_INCLUDES)
|
|
||||||
set(CMAKE_SYMBOL_EXISTS_INCLUDES
|
|
||||||
"-DINCLUDE_DIRECTORIES:STRING=${CMAKE_REQUIRED_INCLUDES}")
|
|
||||||
else()
|
|
||||||
set(CMAKE_SYMBOL_EXISTS_INCLUDES)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
foreach(_FILE ${_HEADER})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_HEADER
|
|
||||||
"${CHECK_PROTOTYPE_DEFINITION_HEADER}#include <${_FILE}>\n")
|
|
||||||
endforeach()
|
|
||||||
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_SYMBOL ${_FUNCTION})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_PROTO ${_PROTOTYPE})
|
|
||||||
set(CHECK_PROTOTYPE_DEFINITION_RETURN ${_RETURN})
|
|
||||||
|
|
||||||
configure_file("${__check_proto_def_dir}/CheckPrototypeDefinition.c.in"
|
|
||||||
"${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c" @ONLY)
|
|
||||||
|
|
||||||
file(READ ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c _SOURCE)
|
|
||||||
|
|
||||||
try_compile(${_VARIABLE}
|
|
||||||
${CMAKE_BINARY_DIR}
|
|
||||||
${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckPrototypeDefinition.c
|
|
||||||
COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS}
|
|
||||||
${CHECK_PROTOTYPE_DEFINITION_LIBS}
|
|
||||||
CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${CHECK_PROTOTYPE_DEFINITION_FLAGS}
|
|
||||||
"${CMAKE_SYMBOL_EXISTS_INCLUDES}"
|
|
||||||
OUTPUT_VARIABLE OUTPUT)
|
|
||||||
|
|
||||||
if (${_VARIABLE})
|
|
||||||
set(${_VARIABLE} 1 CACHE INTERNAL "Have correct prototype for ${_FUNCTION}")
|
|
||||||
message(STATUS "Checking prototype ${_FUNCTION} for ${_VARIABLE} - True")
|
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
|
|
||||||
"Determining if the prototype ${_FUNCTION} exists for ${_VARIABLE} passed with the following output:\n"
|
|
||||||
"${OUTPUT}\n\n")
|
|
||||||
else ()
|
|
||||||
message(STATUS "Checking prototype ${_FUNCTION} for ${_VARIABLE} - False")
|
|
||||||
set(${_VARIABLE} 0 CACHE INTERNAL "Have correct prototype for ${_FUNCTION}")
|
|
||||||
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
|
|
||||||
"Determining if the prototype ${_FUNCTION} exists for ${_VARIABLE} failed with the following output:\n"
|
|
||||||
"${OUTPUT}\n\n${_SOURCE}\n\n")
|
|
||||||
endif ()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endfunction()
|
|
|
@ -0,0 +1,163 @@
|
||||||
|
#[=======================================================================[.rst:
|
||||||
|
FindFFMPEG
|
||||||
|
----------
|
||||||
|
|
||||||
|
Find the FFmpeg and associated libraries.
|
||||||
|
|
||||||
|
|
||||||
|
This module accepts following COMPONENTS::
|
||||||
|
|
||||||
|
avcodec
|
||||||
|
avdevice
|
||||||
|
avfilter
|
||||||
|
avformat
|
||||||
|
avutil
|
||||||
|
swresample
|
||||||
|
swscale
|
||||||
|
|
||||||
|
IMPORTED Targets
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
This module defines the following :prop_tgt:`IMPORTED` targets:
|
||||||
|
|
||||||
|
``FFMPEG::<component>``
|
||||||
|
The FFmpeg component.
|
||||||
|
|
||||||
|
Result Variables
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
``FFMPEG_INCLUDE_DIRS``
|
||||||
|
Include directories necessary to use FFmpeg.
|
||||||
|
``FFMPEG_LIBRARIES``
|
||||||
|
Libraries necessary to use FFmpeg. Note that this only includes libraries for the components requested.
|
||||||
|
``FFMPEG_VERSION``
|
||||||
|
The version of FFMPEG found (avutil).
|
||||||
|
|
||||||
|
|
||||||
|
For each component, the following are provided:
|
||||||
|
|
||||||
|
``FFMPEG_<component>_FOUND``
|
||||||
|
FFmpeg component was found.
|
||||||
|
``FFMPEG_<component>_INCLUDE_DIRS``
|
||||||
|
Include directories for the component.
|
||||||
|
``FFMPEG_<component>_LIBRARIES``
|
||||||
|
Libraries for the component.
|
||||||
|
|
||||||
|
#]=======================================================================]
|
||||||
|
|
||||||
|
function(_ffmpeg_find component pkgconfig_name header)
|
||||||
|
find_package(PkgConfig)
|
||||||
|
pkg_check_modules(PC_FFMPEG_${component} ${pkgconfig_name})
|
||||||
|
|
||||||
|
find_path(FFMPEG_${component}_INCLUDE_DIR
|
||||||
|
NAMES "lib${component}/${header}"
|
||||||
|
HINTS
|
||||||
|
${PC_FFMPEG_${component}_INCLUDEDIR}
|
||||||
|
${PC_FFMPEG_${component}_INCLUDE_DIRS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
ffmpeg)
|
||||||
|
mark_as_advanced("FFMPEG_${component}_INCLUDE_DIR")
|
||||||
|
|
||||||
|
find_library(FFMPEG_${component}_LIBRARY
|
||||||
|
NAMES
|
||||||
|
${component}
|
||||||
|
${PC_FFMPEG_${component}_LIBRARIES}
|
||||||
|
HINTS
|
||||||
|
${PC_FFMPEG_${component}_LIBDIR}
|
||||||
|
${PC_FFMPEG_${component}_LIBRARY_DIRS})
|
||||||
|
mark_as_advanced("${component}_LIBRARY")
|
||||||
|
|
||||||
|
if(FFMPEG_${component}_LIBRARY AND FFMPEG_${component}_INCLUDE_DIR)
|
||||||
|
set(_deps_found TRUE)
|
||||||
|
set(_deps_link)
|
||||||
|
foreach(_ffmpeg_dep IN LISTS ARGN)
|
||||||
|
if(TARGET "FFMPEG::${_ffmpeg_dep}")
|
||||||
|
list(APPEND _deps_link "FFMPEG::${_ffmpeg_dep}")
|
||||||
|
else()
|
||||||
|
set(_deps_found FALSE)
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
if(_deps_found)
|
||||||
|
if(NOT TARGET "FFMPEG::${component}")
|
||||||
|
add_library("FFMPEG::${component}" UNKNOWN IMPORTED)
|
||||||
|
set_target_properties("FFMPEG::${component}" PROPERTIES
|
||||||
|
IMPORTED_LOCATION "${FFMPEG_${component}_LIBRARY}"
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${FFMPEG_${component}_INCLUDE_DIR}"
|
||||||
|
IMPORTED_LINK_INTERFACE_LIBRARIES "${_deps_link}")
|
||||||
|
endif()
|
||||||
|
set(FFMPEG_${component}_FOUND 1 PARENT_SCOPE)
|
||||||
|
set(FFMPEG_${component}_VERSION "${PC_FFMPEG_${component}_VERSION}" PARENT_SCOPE)
|
||||||
|
else()
|
||||||
|
set("FFMPEG_${component}_FOUND" 0 PARENT_SCOPE)
|
||||||
|
set(what)
|
||||||
|
if(NOT FFMPEG_${component}_LIBRARY)
|
||||||
|
set(what "library")
|
||||||
|
endif()
|
||||||
|
if(NOT FFMPEG_${component}_INCLUDE_DIR)
|
||||||
|
if(what)
|
||||||
|
string(APPEND what " or headers")
|
||||||
|
else()
|
||||||
|
set(what "headers")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
set("FFMPEG_${component}_NOT_FOUND_MESSAGE"
|
||||||
|
"Could not find the ${what} for ${component}."
|
||||||
|
PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
_ffmpeg_find(avutil libavutil avutil.h)
|
||||||
|
_ffmpeg_find(swresample libswresample swresample.h
|
||||||
|
avutil)
|
||||||
|
_ffmpeg_find(swscale libswscale swscale.h
|
||||||
|
avutil)
|
||||||
|
_ffmpeg_find(avcodec libavcodec avcodec.h
|
||||||
|
avutil)
|
||||||
|
_ffmpeg_find(avformat libavformat avformat.h
|
||||||
|
avcodec avutil)
|
||||||
|
_ffmpeg_find(avfilter libavfilter avfilter.h
|
||||||
|
avutil)
|
||||||
|
_ffmpeg_find(avdevice libavdevice avdevice.h
|
||||||
|
avformat avutil)
|
||||||
|
|
||||||
|
if(TARGET FFMPEG::avutil)
|
||||||
|
set(FFMPEG_VERSION "${FFMPEG_avutil_VERSION}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(FFMPEG_INCLUDE_DIRS)
|
||||||
|
set(FFMPEG_LIBRARIES)
|
||||||
|
set(_ffmpeg_required_vars)
|
||||||
|
foreach(_ffmpeg_component IN LISTS FFMPEG_FIND_COMPONENTS)
|
||||||
|
if(TARGET "FFMPEG::${_ffmpeg_component}")
|
||||||
|
set(FFMPEG_${_ffmpeg_component}_INCLUDE_DIRS
|
||||||
|
"${FFMPEG_${_ffmpeg_component}_INCLUDE_DIR}")
|
||||||
|
set(FFMPEG_${_ffmpeg_component}_LIBRARIES
|
||||||
|
"${FFMPEG_${_ffmpeg_component}_LIBRARY}")
|
||||||
|
list(APPEND FFMPEG_INCLUDE_DIRS
|
||||||
|
"${FFMPEG_${_ffmpeg_component}_INCLUDE_DIRS}")
|
||||||
|
list(APPEND FFMPEG_LIBRARIES
|
||||||
|
"${FFMPEG_${_ffmpeg_component}_LIBRARIES}")
|
||||||
|
if(FFMEG_FIND_REQUIRED_${_ffmpeg_component})
|
||||||
|
list(APPEND _ffmpeg_required_vars
|
||||||
|
"FFMPEG_${_ffmpeg_required_vars}_INCLUDE_DIRS"
|
||||||
|
"FFMPEG_${_ffmpeg_required_vars}_LIBRARIES")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
unset(_ffmpeg_component)
|
||||||
|
|
||||||
|
if(FFMPEG_INCLUDE_DIRS)
|
||||||
|
list(REMOVE_DUPLICATES FFMPEG_INCLUDE_DIRS)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include(FindPackageHandleStandardArgs)
|
||||||
|
find_package_handle_standard_args(FFMPEG
|
||||||
|
REQUIRED_VARS
|
||||||
|
FFMPEG_INCLUDE_DIRS
|
||||||
|
FFMPEG_LIBRARIES
|
||||||
|
${_ffmpeg_required_vars}
|
||||||
|
VERSION_VAR
|
||||||
|
FFMPEG_VERSION
|
||||||
|
HANDLE_COMPONENTS)
|
||||||
|
unset(_ffmpeg_required_vars)
|
|
@ -1,28 +1,89 @@
|
||||||
include(FindPackageHandleStandardArgs)
|
#[=======================================================================[.rst:
|
||||||
|
FindLibJWT
|
||||||
|
----------
|
||||||
|
|
||||||
|
Find the JWT C Library (libjwt)
|
||||||
|
|
||||||
|
|
||||||
|
This module accepts optional COMPONENTS to select the crypto backend (these are mutually exclusive)::
|
||||||
|
|
||||||
|
openssl (default)
|
||||||
|
gnutls
|
||||||
|
|
||||||
|
IMPORTED Targets
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
This module defines the following :prop_tgt:`IMPORTED` targets:
|
||||||
|
|
||||||
|
``JWT::libjwt``
|
||||||
|
The JWT library, if found with the specified crypto backend.
|
||||||
|
|
||||||
|
Result Variables
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
``LIBJWT_FOUND``
|
||||||
|
System has libjwt
|
||||||
|
``LIBJWT_INCLUDE_DIRS``
|
||||||
|
The libjwt include directory
|
||||||
|
``LIBJWT_LIBRARIES``
|
||||||
|
The libraries needed to use libjwt
|
||||||
|
#]=======================================================================]
|
||||||
|
|
||||||
|
include(FindPackageHandleStandardArgs)
|
||||||
find_package(PkgConfig QUIET)
|
find_package(PkgConfig QUIET)
|
||||||
|
|
||||||
|
if(LibJWT_FIND_COMPONENTS)
|
||||||
|
set(LIBJWT_CRYPTO_BACKEND "")
|
||||||
|
foreach(component IN LISTS LibJWT_FIND_COMPONENTS)
|
||||||
|
if(component MATCHES "^(openssl|gnutls)")
|
||||||
|
if(LIBJWT_CRYPTO_BACKEND)
|
||||||
|
message(FATAL_ERROR "LibJWT: Only one crypto library can be selected.")
|
||||||
|
endif()
|
||||||
|
set(LIBJWT_CRYPTO_BACKEND ${component})
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "LibJWT: Wrong crypto backend specified.")
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
else()
|
||||||
|
set(LIBJWT_CRYPTO_BACKEND "openssl")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(LIBJWT_LIB_NAMES "")
|
||||||
|
if(LIBJWT_CRYPTO_BACKEND STREQUAL "openssl")
|
||||||
|
set(LIBJWT_LIB_NAMES "jwt" "libjwt")
|
||||||
|
elseif(LIBJWT_CRYPTO_BACKEND STREQUAL "gnutls")
|
||||||
|
set(LIBJWT_LIB_NAMES "jwt-gnutls" "libjwt-gnutls")
|
||||||
|
endif()
|
||||||
|
|
||||||
pkg_check_modules(PC_LIBJWT QUIET libjwt)
|
pkg_check_modules(PC_LIBJWT QUIET libjwt)
|
||||||
|
|
||||||
find_path(LIBJWT_INCLUDE_DIR
|
find_path(LIBJWT_INCLUDE_DIR
|
||||||
NAMES jwt.h
|
NAMES jwt.h
|
||||||
HINTS ${PC_LIBJWT_INCLUDEDIR} ${PC_LIBJWT_INCLUDE_DIRS}
|
HINTS
|
||||||
)
|
${PC_LIBJWT_INCLUDEDIR}
|
||||||
|
${PC_LIBJWT_INCLUDE_DIRS})
|
||||||
|
mark_as_advanced(LIBJWT_INCLUDE_DIR)
|
||||||
|
|
||||||
find_library(LIBJWT_LIBRARY
|
find_library(LIBJWT_LIBRARY
|
||||||
NAMES jwt-gnutls libjwt-gnutls liblibjwt-gnutls
|
NAMES ${LIBJWT_LIB_NAMES}
|
||||||
HINTS ${PC_LIBJWT_LIBDIR} ${PC_LIBJWT_LIBRARY_DIR}
|
HINTS
|
||||||
)
|
${PC_LIBJWT_LIBDIR}
|
||||||
|
${PC_LIBJWT_LIBRARY_DIR})
|
||||||
|
mark_as_advanced(LIBJWT_LIBRARY)
|
||||||
|
|
||||||
find_package_handle_standard_args(LibJWT
|
find_package_handle_standard_args(LibJWT
|
||||||
REQUIRED_VARS LIBJWT_INCLUDE_DIR LIBJWT_LIBRARY
|
REQUIRED_VARS
|
||||||
)
|
LIBJWT_INCLUDE_DIR
|
||||||
|
LIBJWT_LIBRARY
|
||||||
|
FAIL_MESSAGE
|
||||||
|
"Could NOT find LibJWT with the crypto backend ${LIBJWT_CRYPTO_BACKEND}.")
|
||||||
|
|
||||||
if(LIBJWT_FOUND)
|
if(LIBJWT_FOUND)
|
||||||
add_library(libjwt STATIC IMPORTED GLOBAL)
|
set(LIBJWT_LIBRARIES ${LIBJWT_LIBRARY})
|
||||||
set_target_properties(libjwt PROPERTIES
|
set(LIBJWT_INCLUDE_DIRS ${LIBJWT_INCLUDE_DIR})
|
||||||
IMPORTED_LOCATION "${LIBJWT_LIBRARY}"
|
|
||||||
INTERFACE_INCLUDE_DIRECTORIES "${LIBJWT_INCLUDE_DIR}"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
mark_as_advanced(LIBJWT_INCLUDE_DIR LIBJWT_LIBRARY)
|
add_library(JWT::libjwt UNKNOWN IMPORTED)
|
||||||
|
set_target_properties(JWT::libjwt PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${LIBJWT_INCLUDE_DIRS}"
|
||||||
|
IMPORTED_LOCATION "${LIBJWT_LIBRARY}")
|
||||||
|
endif()
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
#[=======================================================================[.rst:
|
||||||
|
FindV4L2
|
||||||
|
----------
|
||||||
|
|
||||||
|
Find V4L2 headers and libv4l2
|
||||||
|
|
||||||
|
|
||||||
|
This module accepts optional COMPONENTS:
|
||||||
|
|
||||||
|
videodev2 (default)
|
||||||
|
libv4l2
|
||||||
|
|
||||||
|
IMPORTED Targets
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
This module defines the following :prop_tgt:`IMPORTED` targets::
|
||||||
|
|
||||||
|
``V4L2::videodev2``
|
||||||
|
The Video for Linux Two header file, if found.
|
||||||
|
``V4L2::libv4l2``
|
||||||
|
A thin abstraction layer on top of video4linux2 devices, if found.
|
||||||
|
|
||||||
|
Result Variables
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
``V4L2_FOUND``
|
||||||
|
System has v4l2 support. If no components are specified only the videodev2.h header has to be found.
|
||||||
|
``V4L2_INCLUDE_DIRS``
|
||||||
|
The v4l2 include directories.
|
||||||
|
``V4L2_LIBRARIES``
|
||||||
|
The libraries needed to have v4l2 support according to the specified components.
|
||||||
|
#]=======================================================================]
|
||||||
|
|
||||||
|
find_path(V4L2_VIDEODEV2_INCLUDE_DIR
|
||||||
|
NAMES linux/videodev2.h)
|
||||||
|
mark_as_advanced(V4L2_VIDEODEV2_INCLUDE_DIR)
|
||||||
|
|
||||||
|
if(EXISTS "${V4L2_VIDEODEV2_INCLUDE_DIR}")
|
||||||
|
set(V4L2_videodev2_FOUND TRUE)
|
||||||
|
else()
|
||||||
|
set(V4L2_videodev2_FOUND FALSE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
pkg_check_modules(PC_V4L2_LIBV4L2 QUIET libv4l2)
|
||||||
|
|
||||||
|
find_path(V4L2_LIBV4L2_INCLUDE_DIR
|
||||||
|
NAMES libv4l2.h
|
||||||
|
HINTS
|
||||||
|
${PC_V4L2_LIBV4L2_INCLUDEDIR}
|
||||||
|
${PC_V4L2_LIBV4L2_INCLUDE_DIRS})
|
||||||
|
mark_as_advanced(V4L2_LIBV4L2_INCLUDE_DIR)
|
||||||
|
|
||||||
|
find_library(V4L2_LIBV4L2_LIBRARY
|
||||||
|
NAMES ${PC_V4L2_LIBV4L2_LIBRARIES}
|
||||||
|
HINTS
|
||||||
|
${PC_V4L2_LIBV4L2_LIBDIR}
|
||||||
|
${PC_V4L2_LIBV4L2_LIBRARY_DIR})
|
||||||
|
mark_as_advanced(V4L2_LIBV4L2_LIBRARY)
|
||||||
|
|
||||||
|
if(EXISTS "${V4L2_LIBV4L2_INCLUDE_DIR}" AND
|
||||||
|
EXISTS "${V4L2_LIBV4L2_LIBRARY}")
|
||||||
|
set(V4L2_libv4l2_FOUND TRUE)
|
||||||
|
else()
|
||||||
|
set(V4L2_libv4l2_FOUND FALSE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include(FindPackageHandleStandardArgs)
|
||||||
|
find_package_handle_standard_args(V4L2
|
||||||
|
REQUIRED_VARS
|
||||||
|
V4L2_VIDEODEV2_INCLUDE_DIR
|
||||||
|
HANDLE_COMPONENTS)
|
||||||
|
|
||||||
|
set(V4L2_INCLUDE_DIRS)
|
||||||
|
set(V4L2_LIBRARIES)
|
||||||
|
|
||||||
|
if(V4L2_videodev2_FOUND)
|
||||||
|
set(V4L2_VIDEODEV2_INCLUDE_DIRS ${V4L2_VIDEODEV2_INCLUDE_DIR})
|
||||||
|
list(APPEND V4L2_INCLUDE2_DIRS
|
||||||
|
"${V4L2_VIDEODEV2_INCLUDE_DIRS}")
|
||||||
|
|
||||||
|
add_library(V4L2::videodev2 INTERFACE IMPORTED)
|
||||||
|
set_target_properties(V4L2::videodev2 PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${V4L2_VIDEODEV2_INCLUDE_DIRS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(V4L2_libv4l2_FOUND)
|
||||||
|
set(V4L2_LIBV4L2_INCLUDE_DIRS ${V4L2_LIBV4L2_INCLUDE_DIR})
|
||||||
|
set(V4L2_LIBV4L2_LIBRARIES ${V4L2_LIBV4L2_LIBRARY})
|
||||||
|
|
||||||
|
list(APPEND V4L2_INCLUDE_DIRS
|
||||||
|
"${V4L2_LIBV4L2_INCLUDE_DIRS}")
|
||||||
|
list(APPEND V4L2_LIBRARIES
|
||||||
|
"${V4L2_LIBV4L2_LIBRARIES}")
|
||||||
|
|
||||||
|
add_library(V4L2::libv4l2 UNKNOWN IMPORTED)
|
||||||
|
set_target_properties(V4L2::libv4l2 PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${V4L2_LIBV4L2_INCLUDE_DIRS}"
|
||||||
|
IMPORTED_LOCATION "${V4L2_LIBV4L2_LIBRARY}")
|
||||||
|
endif()
|
|
@ -6,6 +6,7 @@ target_compile_options(zm-warning-interface
|
||||||
-Wformat-security
|
-Wformat-security
|
||||||
-Wno-cast-function-type
|
-Wno-cast-function-type
|
||||||
$<$<VERSION_LESS:$<CXX_COMPILER_VERSION>,11>:-Wno-clobbered>
|
$<$<VERSION_LESS:$<CXX_COMPILER_VERSION>,11>:-Wno-clobbered>
|
||||||
|
$<$<VERSION_LESS:$<CXX_COMPILER_VERSION>,5.1>:-Wno-missing-field-initializers>
|
||||||
-Wno-unused-parameter
|
-Wno-unused-parameter
|
||||||
-Woverloaded-virtual
|
-Woverloaded-virtual
|
||||||
-Wvla)
|
-Wvla)
|
||||||
|
@ -23,7 +24,8 @@ if(ASAN)
|
||||||
-fno-omit-frame-pointer
|
-fno-omit-frame-pointer
|
||||||
-fsanitize=address
|
-fsanitize=address
|
||||||
-fsanitize-recover=address
|
-fsanitize-recover=address
|
||||||
-fsanitize-address-use-after-scope)
|
-fsanitize-address-use-after-scope
|
||||||
|
-Wno-stringop-truncation)
|
||||||
|
|
||||||
target_link_options(zm-compile-option-interface
|
target_link_options(zm-compile-option-interface
|
||||||
INTERFACE
|
INTERFACE
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
configure_file(zm_create.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_create.sql" @ONLY)
|
configure_file(zm_create.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_create.sql" @ONLY)
|
||||||
configure_file(zm_update-1.31.30.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.31.30.sql" @ONLY)
|
configure_file(zm_update-1.31.30.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.31.30.sql" @ONLY)
|
||||||
configure_file(zm_update-1.35.24.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.35.24.sql" @ONLY)
|
configure_file(zm_update-1.35.24.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.35.24.sql" @ONLY)
|
||||||
|
configure_file(zm_update-1.37.4.sql.in "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.37.4.sql" @ONLY)
|
||||||
|
|
||||||
# Glob all database upgrade scripts
|
# Glob all database upgrade scripts
|
||||||
file(GLOB dbfileslist RELATIVE "${CMAKE_CURRENT_SOURCE_DIR}" "zm_update-*.sql")
|
file(GLOB dbfileslist RELATIVE "${CMAKE_CURRENT_SOURCE_DIR}" "zm_update-*.sql")
|
||||||
|
@ -15,6 +16,8 @@ install(FILES ${dbfileslist} DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db
|
||||||
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.31.30.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.31.30.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
# install zm_update-1.35.24.sql
|
# install zm_update-1.35.24.sql
|
||||||
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.35.24.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.35.24.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
# install zm_update-1.37.4.sql
|
||||||
|
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_update-1.37.4.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
|
||||||
# install zm_create.sql
|
# install zm_create.sql
|
||||||
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_create.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_create.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
@ -22,3 +25,8 @@ install(FILES "${CMAKE_CURRENT_BINARY_DIR}/zm_create.sql" DESTINATION "${CMAKE_I
|
||||||
# install triggers.sql
|
# install triggers.sql
|
||||||
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/triggers.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/triggers.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
|
||||||
|
# install manufacturers.sql
|
||||||
|
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/manufacturers.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
|
||||||
|
# install models.sql
|
||||||
|
install(FILES "${CMAKE_CURRENT_SOURCE_DIR}/models.sql" DESTINATION "${CMAKE_INSTALL_DATADIR}/zoneminder/db")
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (1, 'Acti');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (2, 'Amcrest');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (3, 'Airlink101');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (4, 'Arecont Vision');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (5, 'Axis');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (6, 'Dahua');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (7, 'D-Link');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (8, 'Edimax');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (9, 'Foscam');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (10, 'Gadspot');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (11, 'GrandStream');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (12, 'HikVision');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (13, 'JVC');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (14, 'Maginon');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (15, 'Mobotix');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (16, 'Oncam Grandeye');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (17, 'Panasonic');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (18, 'Pelco');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (19, 'Sony');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (20, 'TP-Link');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (21, 'Trendnet');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (22, 'VisionTek');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (23, 'Vivotek');
|
||||||
|
INSERT IGNORE INTO Manufacturers VALUES (24, 'Wansview');
|
|
@ -0,0 +1,56 @@
|
||||||
|
/* INSERT INTO Manufacturers VALUES (1, 'Acti'); */
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A21');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A23');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A24');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A28');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A31');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A310');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A311');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A32');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A41');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A415');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A416');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A418');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A42');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A421');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A43');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A45');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A46');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A48');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (1, 'A74');
|
||||||
|
/*
|
||||||
|
INSERT INTO Manufacturers VALUES (2, 'Amcrest');
|
||||||
|
*/
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (2, 'IP8M-T2499EW');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (2, 'ASH42-B');
|
||||||
|
/*
|
||||||
|
INSERT INTO Manufacturers VALUES (3, 'Airlink101');
|
||||||
|
INSERT INTO Manufacturers VALUES (4, 'Arecont Vision');
|
||||||
|
INSERT INTO Manufacturers VALUES (5, 'Axis');
|
||||||
|
INSERT INTO Manufacturers VALUES (6, 'Dahua');
|
||||||
|
INSERT INTO Manufacturers VALUES (7, 'D-Link');
|
||||||
|
*/
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (7, 'DCS-930L');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (7, 'DCS-932L');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (7, 'DCS-933L');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (7, 'DCS-942L');
|
||||||
|
INSERT IGNORE INTO Models (ManufacturerId,Name) VALUES (7, 'DCS-5020L');
|
||||||
|
/*
|
||||||
|
INSERT INTO Manufacturers VALUES (8, 'Edimax');
|
||||||
|
INSERT INTO Manufacturers VALUES (9, 'Foscam');
|
||||||
|
INSERT INTO Manufacturers VALUES (10, 'Gadspot');
|
||||||
|
INSERT INTO Manufacturers VALUES (11, 'GrandStream');
|
||||||
|
INSERT INTO Manufacturers VALUES (12, 'HikVision');
|
||||||
|
INSERT INTO Manufacturers VALUES (13, 'JVC');
|
||||||
|
INSERT INTO Manufacturers VALUES (14, 'Maginon');
|
||||||
|
INSERT INTO Manufacturers VALUES (15, 'Mobotix');
|
||||||
|
INSERT INTO Manufacturers VALUES (16, 'Oncam Grandeye');
|
||||||
|
INSERT INTO Manufacturers VALUES (17, 'Panasonic');
|
||||||
|
INSERT INTO Manufacturers VALUES (18, 'Pelco');
|
||||||
|
INSERT INTO Manufacturers VALUES (19, 'Sony');
|
||||||
|
INSERT INTO Manufacturers VALUES (20, 'TP-Link');
|
||||||
|
INSERT INTO Manufacturers VALUES (21, 'Trendnet');
|
||||||
|
INSERT INTO Manufacturers VALUES (22, 'VisionTek');
|
||||||
|
INSERT INTO Manufacturers VALUES (23, 'Vivotek');
|
||||||
|
INSERT INTO Manufacturers VALUES (24, 'Wansview');
|
||||||
|
*/
|
|
@ -412,6 +412,7 @@ CREATE TABLE `Models` (
|
||||||
DROP TABLE IF EXISTS `MonitorPresets`;
|
DROP TABLE IF EXISTS `MonitorPresets`;
|
||||||
CREATE TABLE `MonitorPresets` (
|
CREATE TABLE `MonitorPresets` (
|
||||||
`Id` int(10) unsigned NOT NULL auto_increment,
|
`Id` int(10) unsigned NOT NULL auto_increment,
|
||||||
|
`ModelId` int unsigned, FOREIGN KEY (`ModelId`) REFERENCES `Models` (Id),
|
||||||
`Name` varchar(64) NOT NULL default '',
|
`Name` varchar(64) NOT NULL default '',
|
||||||
`Type` enum('Local','Remote','File','Ffmpeg','Libvlc','cURL','WebSite','NVSocket','VNC') NOT NULL default 'Local',
|
`Type` enum('Local','Remote','File','Ffmpeg','Libvlc','cURL','WebSite','NVSocket','VNC') NOT NULL default 'Local',
|
||||||
`Device` tinytext,
|
`Device` tinytext,
|
||||||
|
@ -447,12 +448,16 @@ CREATE TABLE `Monitors` (
|
||||||
`Notes` TEXT,
|
`Notes` TEXT,
|
||||||
`ServerId` int(10) unsigned,
|
`ServerId` int(10) unsigned,
|
||||||
`StorageId` smallint(5) unsigned default 0,
|
`StorageId` smallint(5) unsigned default 0,
|
||||||
|
`ManufacturerId` int unsigned, FOREIGN KEY (`ManufacturerId`) REFERENCES `Manufacturers` (Id),
|
||||||
|
`ModelId` int unsigned, FOREIGN KEY (`ModelId`) REFERENCES `Models` (Id),
|
||||||
`Type` enum('Local','Remote','File','Ffmpeg','Libvlc','cURL','WebSite','NVSocket','VNC') NOT NULL default 'Local',
|
`Type` enum('Local','Remote','File','Ffmpeg','Libvlc','cURL','WebSite','NVSocket','VNC') NOT NULL default 'Local',
|
||||||
`Function` enum('None','Monitor','Modect','Record','Mocord','Nodect') NOT NULL default 'Monitor',
|
`Function` enum('None','Monitor','Modect','Record','Mocord','Nodect') NOT NULL default 'Monitor',
|
||||||
`Enabled` tinyint(3) unsigned NOT NULL default '1',
|
`Enabled` tinyint(3) unsigned NOT NULL default '1',
|
||||||
`DecodingEnabled` tinyint(3) unsigned NOT NULL default '1',
|
`DecodingEnabled` tinyint(3) unsigned NOT NULL default '1',
|
||||||
`LinkedMonitors` varchar(255),
|
`LinkedMonitors` varchar(255),
|
||||||
`Triggers` set('X10') NOT NULL default '',
|
`Triggers` set('X10') NOT NULL default '',
|
||||||
|
`EventStartCommand` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
|
`EventEndCommand` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`ONVIF_URL` VARCHAR(255) NOT NULL DEFAULT '',
|
`ONVIF_URL` VARCHAR(255) NOT NULL DEFAULT '',
|
||||||
`ONVIF_Username` VARCHAR(64) NOT NULL DEFAULT '',
|
`ONVIF_Username` VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
`ONVIF_Password` VARCHAR(64) NOT NULL DEFAULT '',
|
`ONVIF_Password` VARCHAR(64) NOT NULL DEFAULT '',
|
||||||
|
@ -539,7 +544,7 @@ CREATE TABLE `Monitors` (
|
||||||
`Longitude` DECIMAL(11,8),
|
`Longitude` DECIMAL(11,8),
|
||||||
`RTSPServer` BOOLEAN NOT NULL DEFAULT FALSE,
|
`RTSPServer` BOOLEAN NOT NULL DEFAULT FALSE,
|
||||||
`RTSPStreamName` varchar(255) NOT NULL default '',
|
`RTSPStreamName` varchar(255) NOT NULL default '',
|
||||||
`Importance` enum('Not','Less','Normal'),
|
`Importance` enum('Normal','Less','Not') NOT NULL default 'Normal',
|
||||||
PRIMARY KEY (`Id`)
|
PRIMARY KEY (`Id`)
|
||||||
) ENGINE=@ZM_MYSQL_ENGINE@;
|
) ENGINE=@ZM_MYSQL_ENGINE@;
|
||||||
|
|
||||||
|
@ -971,81 +976,81 @@ INSERT INTO `Controls` VALUES (NULL,'Amcrest HTTP API','Ffmpeg','Amcrest_HTTP',0
|
||||||
-- Add some monitor preset values
|
-- Add some monitor preset values
|
||||||
--
|
--
|
||||||
|
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Amcrest, IP8M-T2499EW 640x480, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp','NULL',554,'rtsp://<username>:<password>@<ip-address>/cam/realmonitor?channel=1&subtype=1',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Amcrest, IP8M-T2499EW 640x480, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp','NULL',554,'rtsp://<username>:<password>@<ip-address>/cam/realmonitor?channel=1&subtype=1',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Amcrest, IP8M-T2499EW 3840x2160, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp','NULL',554,'rtsp://<username>:<password>@<ip-address>/cam/realmonitor?channel=1&subtype=0',NULL,3840,2160,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Amcrest, IP8M-T2499EW 3840x2160, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp','NULL',554,'rtsp://<username>:<password>@<ip-address>/cam/realmonitor?channel=1&subtype=0',NULL,3840,2160,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 320x240, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&req_fps=5',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 320x240, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&req_fps=5',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 640x480, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&req_fps=5',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 640x480, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&req_fps=5',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 320x240, mpjpeg, B&W','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&color=0',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 320x240, mpjpeg, B&W','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&color=0',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP, 640x480, mpjpeg, B&W','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&color=0',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP, 640x480, mpjpeg, B&W','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&color=0',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 320x240, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&req_fps=5',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 320x240, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=320x240&req_fps=5',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,5.0,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=320x240',NULL,320,240,3,5.0,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 640x480, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&req_fps=5',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 640x480, mpjpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/mjpg/video.cgi?resolution=640x480&req_fps=5',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,NULL,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis IP PTZ, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,5.0,1,4,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis IP PTZ, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/axis-cgi/jpg/image.cgi?resolution=640x480',NULL,640,480,3,5.0,1,4,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Axis IP, mpeg4, unicast','Remote','rtsp',0,255,'rtsp','rtpUni','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Axis IP, mpeg4, unicast','Remote','rtsp',0,255,'rtsp','rtpUni','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Axis IP, mpeg4, multicast','Remote','rtsp',0,255,'rtsp','rtpMulti','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Axis IP, mpeg4, multicast','Remote','rtsp',0,255,'rtsp','rtpMulti','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Axis IP, mpeg4, RTP/RTSP','Remote','rtsp',0,255,'rtsp','rtpRtsp','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Axis IP, mpeg4, RTP/RTSP','Remote','rtsp',0,255,'rtsp','rtpRtsp','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'Axis IP, mpeg4, RTP/RTSP/HTTP','Remote',NULL,NULL,NULL,'rtsp','rtpRtspHttp','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'Axis IP, mpeg4, RTP/RTSP/HTTP','Remote',NULL,NULL,NULL,'rtsp','rtpRtspHttp','<ip-address>',554,'/mpeg4/media.amp','/trackID=',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'D-link DCS-930L, 640x480, mjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/mjpeg.cgi',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'D-link DCS-930L, 640x480, mjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/mjpeg.cgi',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'D-Link DCS-5020L, 640x480, mjpeg','Remote','http',0,0,'http','simple','<username>:<pwd>@<ip-address>','80','/video.cgi',NULL,640,480,0,NULL,1,'34',NULL,'<username>:<pwd>@<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'D-Link DCS-5020L, 640x480, mjpeg','Remote','http',0,0,'http','simple','<username>:<pwd>@<ip-address>','80','/video.cgi',NULL,640,480,0,NULL,1,'34',NULL,'<username>:<pwd>@<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 320x240, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 320x240, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,5.0,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 320x240, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=320x240&Quality=Standard',NULL,320,240,3,5.0,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 640x480, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/nphMotionJpeg?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 640x480, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,NULL,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Panasonic IP PTZ, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,5.0,1,5,NULL,'<ip-address>:<port>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Panasonic IP PTZ, 640x480, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/SnapshotJPEG?Resolution=640x480&Quality=Standard',NULL,640,480,3,5.0,1,5,NULL,'<ip-address>:<port>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Gadspot IP, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Gadspot IP, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Gadspot IP, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Gadspot IP, jpeg, max 5 FPS','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Gadspot IP, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/GetData.cgi',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Gadspot IP, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/GetData.cgi',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Gadspot IP, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Gadspot IP, mpjpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'IP Webcam by Pavel Khlebovich 1920x1080','Remote','/dev/video<?>','0',255,'http','simple','<ip-address>','8080','/video','',1920,1080,0,NULL,0,'0','','',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'IP Webcam by Pavel Khlebovich 1920x1080','Remote','/dev/video<?>','0',255,'http','simple','<ip-address>','8080','/video','',1920,1080,0,NULL,0,'0','','',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'VEO Observer, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'VEO Observer, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/Jpeg/CamImg.jpg',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Blue Net Video Server, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/cgi-bin/image.cgi?control=0&id=admin&passwd=admin',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Blue Net Video Server, jpeg','Remote','http',0,0,'http','simple','<ip-address>',80,'/cgi-bin/image.cgi?control=0&id=admin&passwd=admin',NULL,320,240,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT into MonitorPresets VALUES (NULL,'ACTi IP, mpeg4, unicast','Remote',NULL,NULL,NULL,'rtsp','rtpUni','<ip-address>',7070,'','/track',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT into MonitorPresets VALUES (NULL,NULL,'ACTi IP, mpeg4, unicast','Remote',NULL,NULL,NULL,'rtsp','rtpUni','<ip-address>',7070,'','/track',NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>/axis-media/media.amp?videocodec=h264',NULL,NULL,NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>/axis-media/media.amp?videocodec=h264',NULL,NULL,NULL,640,480,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Vivotek FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>:554/live.sdp',NULL,NULL,NULL,352,240,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Vivotek FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>:554/live.sdp',NULL,NULL,NULL,352,240,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Axis FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>/axis-media/media.amp',NULL,NULL,NULL,640,480,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Axis FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://<host/address>/axis-media/media.amp',NULL,NULL,NULL,640,480,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'ACTi TCM FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://admin:123456@<host/address>:7070',NULL,NULL,NULL,320,240,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'ACTi TCM FFMPEG','Ffmpeg',NULL,NULL,NULL,NULL,NULL,'rtsp://admin:123456@<host/address>:7070',NULL,NULL,NULL,320,240,NULL,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), PAL, 320x240','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), PAL, 320x240','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), PAL, 320x240, max 5 FPS','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), PAL, 320x240, max 5 FPS','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), PAL, 640x480','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), PAL, 640x480','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), PAL, 640x480, max 5 FPS','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), PAL, 640x480, max 5 FPS','Local','/dev/video<?>',0,255,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), NTSC, 320x240','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), NTSC, 320x240','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), NTSC, 320x240, max 5 FPS','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), NTSC, 320x240, max 5 FPS','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,320,240,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), NTSC, 640x480','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), NTSC, 640x480','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L2), NTSC, 640x480, max 5 FPS','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L2), NTSC, 640x480, max 5 FPS','Local','/dev/video<?>',0,45056,NULL,'v4l2',NULL,NULL,NULL,NULL,640,480,1345466932,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), PAL, 320x240','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), PAL, 320x240','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), PAL, 320x240, max 5 FPS','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), PAL, 320x240, max 5 FPS','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), PAL, 640x480','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), PAL, 640x480','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), PAL, 640x480, max 5 FPS','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), PAL, 640x480, max 5 FPS','Local','/dev/video<?>',0,0,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), NTSC, 320x240','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), NTSC, 320x240','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), NTSC, 320x240, max 5 FPS','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), NTSC, 320x240, max 5 FPS','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,320,240,13,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), NTSC, 640x480','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), NTSC, 640x480','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'BTTV Video (V4L1), NTSC, 640x480, max 5 FPS','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,5.0,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'BTTV Video (V4L1), NTSC, 640x480, max 5 FPS','Local','/dev/video<?>',0,1,NULL,'v4l1',NULL,NULL,NULL,NULL,640,480,13,5.0,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Remote ZoneMinder','Remote',NULL,NULL,NULL,'http','simple','<ip-address>',80,'/cgi-bin/nph-zms?mode=jpeg&monitor=<monitor-id>&scale=100&maxfps=5&buffer=0',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Remote ZoneMinder','Remote',NULL,NULL,NULL,'http','simple','<ip-address>',80,'/cgi-bin/nph-zms?mode=jpeg&monitor=<monitor-id>&scale=100&maxfps=5&buffer=0',NULL,NULL,NULL,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Foscam FI8620 FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:554/11',NULL,704,576,0,NULL,1,'10','<admin_pwd>','<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Foscam FI8620 FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:554/11',NULL,704,576,0,NULL,1,'10','<admin_pwd>','<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Foscam FI8608W FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:554/11',NULL,640,480,0,NULL,1,'11','<admin_pwd>','<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Foscam FI8608W FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:554/11',NULL,640,480,0,NULL,1,'11','<admin_pwd>','<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Foscam FI9821W FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:88/videoMain',NULL,1280,720,0,NULL,1,'12','<admin_pwd>','<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Foscam FI9821W FFMPEG H.264','Ffmpeg',NULL,NULL,NULL,NULL,'','','','rtsp://<username>:<pwd>@<ip-address>:88/videoMain',NULL,1280,720,0,NULL,1,'12','<admin_pwd>','<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Loftek Sentinel PTZ, 640x480, mjpeg','Remote','http',0,0,NULL,NULL,'<ip-address>','80','/videostream.cgi?user=<username>&pwd=<password>&resolution=32&rate=11',NULL,640,480,4,NULL,1,'13','','<username>:<pwd>@<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Loftek Sentinel PTZ, 640x480, mjpeg','Remote','http',0,0,NULL,NULL,'<ip-address>','80','/videostream.cgi?user=<username>&pwd=<password>&resolution=32&rate=11',NULL,640,480,4,NULL,1,'13','','<username>:<pwd>@<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Airlink 777W PTZ, 640x480, mjpeg','Remote','http',0,0,NULL,NULL,'<username>:<password>@<ip-address>','80','/cgi/mjpg/mjpg.cgi',NULL,640,480,4,NULL,1,'7','','<username>:<pwd>@<ip-address>',100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Airlink 777W PTZ, 640x480, mjpeg','Remote','http',0,0,NULL,NULL,'<username>:<password>@<ip-address>','80','/cgi/mjpg/mjpg.cgi',NULL,640,480,4,NULL,1,'7','','<username>:<pwd>@<ip-address>',100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'SunEyes SP-P1802SWPTZ','Libvlc','/dev/video<?>','0',255,'','rtpMulti','','80','rtsp://<ip-address>:554/11','',1920,1080,0,0.00,1,'16','-speed=64','<ip-address>:<port>',100,33);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'SunEyes SP-P1802SWPTZ','Libvlc','/dev/video<?>','0',255,'','rtpMulti','','80','rtsp://<ip-address>:554/11','',1920,1080,0,0.00,1,'16','-speed=64','<ip-address>:<port>',100,33);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Qihan IP, 1280x720, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp',NULL,554,'rtsp://<ip-address>/tcp_live/ch0_0',NULL,1280,720,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Qihan IP, 1280x720, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp',NULL,554,'rtsp://<ip-address>/tcp_live/ch0_0',NULL,1280,720,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
INSERT INTO MonitorPresets VALUES (NULL,'Qihan IP, 1920x1080, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp',NULL,554,'rtsp://<ip-address>/tcp_live/ch0_0',NULL,1920,1080,3,NULL,0,NULL,NULL,NULL,100,100);
|
INSERT INTO MonitorPresets VALUES (NULL,NULL,'Qihan IP, 1920x1080, RTP/RTSP','Ffmpeg','rtsp',0,255,'rtsp','rtpRtsp',NULL,554,'rtsp://<ip-address>/tcp_live/ch0_0',NULL,1920,1080,3,NULL,0,NULL,NULL,NULL,100,100);
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Add some zone preset values
|
-- Add some zone preset values
|
||||||
|
@ -1080,11 +1085,11 @@ CREATE TABLE MontageLayouts (
|
||||||
PRIMARY KEY (`Id`)
|
PRIMARY KEY (`Id`)
|
||||||
);
|
);
|
||||||
|
|
||||||
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('Freeform', '{ "default":{"float":"left","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('Freeform', '{ "default":{"float":"left","left":"0px","right":"0px","top":"0px","bottom":"0px","width":"auto"} }' );
|
||||||
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('2 Wide', '{ "default":{"float":"left", "width":"49%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('2 Wide', '{ "default":{"float":"left", "width":"50%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
||||||
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('3 Wide', '{ "default":{"float":"left", "width":"33%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('3 Wide', '{ "default":{"float":"left", "width":"33%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
||||||
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('4 Wide', '{ "default":{"float":"left", "width":"24.5%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('4 Wide', '{ "default":{"float":"left", "width":"25%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
||||||
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('5 Wide', '{ "default":{"float":"left", "width":"19%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
INSERT INTO MontageLayouts (`Name`,`Positions`) VALUES ('5 Wide', '{ "default":{"float":"left", "width":"20%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' );
|
||||||
|
|
||||||
CREATE TABLE Sessions (
|
CREATE TABLE Sessions (
|
||||||
id char(32) not null,
|
id char(32) not null,
|
||||||
|
@ -1115,6 +1120,9 @@ CREATE TABLE Snapshot_Events (
|
||||||
|
|
||||||
-- We generally don't alter triggers, we drop and re-create them, so let's keep them in a separate file that we can just source in update scripts.
|
-- We generally don't alter triggers, we drop and re-create them, so let's keep them in a separate file that we can just source in update scripts.
|
||||||
source @PKGDATADIR@/db/triggers.sql
|
source @PKGDATADIR@/db/triggers.sql
|
||||||
|
|
||||||
|
source @PKGDATADIR@/db/manufacturers.sql
|
||||||
|
source @PKGDATADIR@/db/models.sql
|
||||||
--
|
--
|
||||||
-- Apply the initial configuration
|
-- Apply the initial configuration
|
||||||
--
|
--
|
||||||
|
|
|
@ -28,8 +28,8 @@ SET @s = (SELECT IF(
|
||||||
AND table_name = 'Monitors'
|
AND table_name = 'Monitors'
|
||||||
AND column_name = 'TotalEvents'
|
AND column_name = 'TotalEvents'
|
||||||
) > 0,
|
) > 0,
|
||||||
"SELECT 'Column TotalEvents is already removed from Monitors'",
|
"ALTER TABLE `Monitors` DROP `TotalEvents`",
|
||||||
"ALTER TABLE `Monitors` DROP `TotalEvents`"
|
"SELECT 'Column TotalEvents is already removed from Monitors'"
|
||||||
));
|
));
|
||||||
PREPARE stmt FROM @s;
|
PREPARE stmt FROM @s;
|
||||||
EXECUTE stmt;
|
EXECUTE stmt;
|
||||||
|
@ -50,8 +50,8 @@ SET @s = (SELECT IF(
|
||||||
AND table_name = 'Monitors'
|
AND table_name = 'Monitors'
|
||||||
AND column_name = 'TotalEventDiskSpace'
|
AND column_name = 'TotalEventDiskSpace'
|
||||||
) > 0,
|
) > 0,
|
||||||
"SELECT 'Column TotalEventDiskSpace is already removed from Monitors'",
|
"ALTER TABLE `Monitors` DROP `TotalEventDiskSpace`",
|
||||||
"ALTER TABLE `Monitors` DROP `TotalEventDiskSpace`"
|
"SELECT 'Column TotalEventDiskSpace is already removed from Monitors'"
|
||||||
));
|
));
|
||||||
PREPARE stmt FROM @s;
|
PREPARE stmt FROM @s;
|
||||||
EXECUTE stmt;
|
EXECUTE stmt;
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ManufacturerId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column ManufacturerId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD `ManufacturerId` int(10) unsigned AFTER `StorageId`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ManufacturerId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'FOREIGN KEY for ManufacturerId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD FOREIGN KEY (`ManufacturerId`) REFERENCES `Manufacturers` (Id)"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column ModelId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD `ModelId` int(10) unsigned AFTER `ManufacturerId`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'FOREIGN KEY for ModelId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD FOREIGN KEY (`ModelId`) REFERENCES `Models` (Id)"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
|
@ -0,0 +1 @@
|
||||||
|
ALTER TABLE `Monitors` MODIFY `Longitude` DECIMAL(11,8);
|
|
@ -0,0 +1,7 @@
|
||||||
|
UPDATE MontageLayouts SET `Positions` = '{ "default":{"float":"left","left":"0px","right":"0px","top":"0px","bottom":"0px","width":"auto"} }' WHERE `Name`='Freeform';
|
||||||
|
UPDATE MontageLayouts SET `Positions` = '{ "default":{"float":"left", "width":"49%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' WHERE `Name`='2 Wide';
|
||||||
|
UPDATE MontageLayouts SET `Positions` = '{ "default":{"float":"left", "width":"25%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' WHERE `Name`='4 Wide';
|
||||||
|
UPDATE MontageLayouts SET `Positions` = '{ "default":{"float":"left", "width":"20%","left":"0px","right":"0px","top":"0px","bottom":"0px"} }' WHERE `Name`='5 Wide';
|
||||||
|
|
||||||
|
UPDATE Monitors set Importance = 'Normal' where Importance IS NULL;
|
||||||
|
ALTER TABLE `Monitors` MODIFY `Importance` enum('Normal','Less','Not') NOT NULL default 'Normal';
|
|
@ -0,0 +1,73 @@
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ManufacturerId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column ManufacturerId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD `ManufacturerId` int(10) unsigned AFTER `StorageId`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ManufacturerId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'FOREIGN KEY for ManufacturerId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD FOREIGN KEY (`ManufacturerId`) REFERENCES `Manufacturers` (Id)"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column ModelId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD `ModelId` int(10) unsigned AFTER `ManufacturerId`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'Monitors'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'FOREIGN KEY for ModelId already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD FOREIGN KEY (`ModelId`) REFERENCES `Models` (Id)"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'MonitorPresets'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column ModelId already exists in MonitorPresets'",
|
||||||
|
"ALTER TABLE `MonitorPresets` ADD `ModelId` int(10) unsigned AFTER `Id`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE table_schema = DATABASE()
|
||||||
|
AND table_name = 'MonitorPresets'
|
||||||
|
AND column_name = 'ModelId'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'FOREIGN KEY for ModelId already exists in MonitorPresets'",
|
||||||
|
"ALTER TABLE `MonitorPresets` ADD FOREIGN KEY (`ModelId`) REFERENCES `Models` (Id)"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
UPDATE `MonitorPresets` SET `ModelId`=(SELECT `Id` FROM `Models` WHERE `Name`='IP8M-T2499EW') WHERE `Name` like 'Amcrest, IP8M-T2499EW
|
||||||
|
%';
|
|
@ -0,0 +1,2 @@
|
||||||
|
source @PKGDATADIR@/db/manufacturers.sql
|
||||||
|
source @PKGDATADIR@/db/models.sql
|
|
@ -0,0 +1,31 @@
|
||||||
|
--
|
||||||
|
-- This update adds EventStartCommand and EventEndCommand
|
||||||
|
--
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*)
|
||||||
|
FROM INFORMATION_SCHEMA.COLUMNS
|
||||||
|
WHERE table_name = 'Monitors'
|
||||||
|
AND table_schema = DATABASE()
|
||||||
|
AND column_name = 'AlarmEndCommand'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column EventEndCommand already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD COLUMN `EventEndCommand` VARCHAR(255) NOT NULL DEFAULT '' AFTER `Triggers`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
||||||
|
|
||||||
|
SET @s = (SELECT IF(
|
||||||
|
(SELECT COUNT(*)
|
||||||
|
FROM INFORMATION_SCHEMA.COLUMNS
|
||||||
|
WHERE table_name = 'Monitors'
|
||||||
|
AND table_schema = DATABASE()
|
||||||
|
AND column_name = 'AlarmStartCommand'
|
||||||
|
) > 0,
|
||||||
|
"SELECT 'Column EventStartCommand already exists in Monitors'",
|
||||||
|
"ALTER TABLE `Monitors` ADD COLUMN `EventStartCommand` VARCHAR(255) NOT NULL DEFAULT '' AFTER `Triggers`"
|
||||||
|
));
|
||||||
|
|
||||||
|
PREPARE stmt FROM @s;
|
||||||
|
EXECUTE stmt;
|
|
@ -5,7 +5,6 @@ Maintainer: Isaac Connor <isaac@zoneminder.com>
|
||||||
Uploaders: Isaac Connor <isaac@zoneminder.com>
|
Uploaders: Isaac Connor <isaac@zoneminder.com>
|
||||||
Build-Depends: debhelper, sphinx-doc, dh-linktree, dh-apache2
|
Build-Depends: debhelper, sphinx-doc, dh-linktree, dh-apache2
|
||||||
,cmake
|
,cmake
|
||||||
,libavdevice-dev
|
|
||||||
,libavcodec-dev
|
,libavcodec-dev
|
||||||
,libavformat-dev
|
,libavformat-dev
|
||||||
,libavutil-dev
|
,libavutil-dev
|
||||||
|
@ -14,7 +13,6 @@ Build-Depends: debhelper, sphinx-doc, dh-linktree, dh-apache2
|
||||||
,ffmpeg
|
,ffmpeg
|
||||||
,net-tools
|
,net-tools
|
||||||
,libbz2-dev
|
,libbz2-dev
|
||||||
,libgcrypt20-dev
|
|
||||||
,libcurl4-gnutls-dev
|
,libcurl4-gnutls-dev
|
||||||
,libturbojpeg0-dev
|
,libturbojpeg0-dev
|
||||||
,default-libmysqlclient-dev | libmysqlclient-dev | libmariadbclient-dev-compat
|
,default-libmysqlclient-dev | libmysqlclient-dev | libmariadbclient-dev-compat
|
||||||
|
|
|
@ -41,7 +41,6 @@ Copyright: 2005-2013 Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||||||
License: Expat
|
License: Expat
|
||||||
|
|
||||||
Files:
|
Files:
|
||||||
cmake/Modules/CheckPrototypeDefinition*.cmake
|
|
||||||
cmake/Modules/FindGLIB2.cmake
|
cmake/Modules/FindGLIB2.cmake
|
||||||
cmake/Modules/FindPolkit.cmake
|
cmake/Modules/FindPolkit.cmake
|
||||||
cmake/Modules/GNUInstallDirs.cmake
|
cmake/Modules/GNUInstallDirs.cmake
|
||||||
|
|
|
@ -9,7 +9,6 @@ Build-Depends: debhelper (>= 9), cmake
|
||||||
, libjpeg8-dev | libjpeg-dev
|
, libjpeg8-dev | libjpeg-dev
|
||||||
, libpcre3-dev
|
, libpcre3-dev
|
||||||
, libavcodec-dev, libavformat-dev (>= 3:0.svn20090204), libswscale-dev (>= 3:0.svn20090204), libavutil-dev
|
, libavcodec-dev, libavformat-dev (>= 3:0.svn20090204), libswscale-dev (>= 3:0.svn20090204), libavutil-dev
|
||||||
, libavdevice-dev
|
|
||||||
, libv4l-dev (>= 0.8.3)
|
, libv4l-dev (>= 0.8.3)
|
||||||
, libbz2-dev
|
, libbz2-dev
|
||||||
, ffmpeg | libav-tools
|
, ffmpeg | libav-tools
|
||||||
|
@ -17,7 +16,7 @@ Build-Depends: debhelper (>= 9), cmake
|
||||||
, libnetpbm10-dev
|
, libnetpbm10-dev
|
||||||
, libvlccore-dev, libvlc-dev
|
, libvlccore-dev, libvlc-dev
|
||||||
, libcurl4-gnutls-dev | libcurl4-nss-dev | libcurl4-openssl-dev
|
, libcurl4-gnutls-dev | libcurl4-nss-dev | libcurl4-openssl-dev
|
||||||
, libgcrypt11-dev, libpolkit-gobject-1-dev
|
, libpolkit-gobject-1-dev
|
||||||
, libphp-serialization-perl
|
, libphp-serialization-perl
|
||||||
, libdate-manip-perl, libmime-lite-perl, libmime-tools-perl, libdbd-mysql-perl
|
, libdate-manip-perl, libmime-lite-perl, libmime-tools-perl, libdbd-mysql-perl
|
||||||
, libwww-perl, libarchive-tar-perl, libarchive-zip-perl, libdevice-serialport-perl
|
, libwww-perl, libarchive-tar-perl, libarchive-zip-perl, libdevice-serialport-perl
|
||||||
|
@ -47,7 +46,7 @@ Depends: ${shlibs:Depends}, ${misc:Depends}, ${perl:Depends}
|
||||||
,libnumber-bytes-human-perl
|
,libnumber-bytes-human-perl
|
||||||
,libfile-slurp-perl
|
,libfile-slurp-perl
|
||||||
, libpcre3
|
, libpcre3
|
||||||
, ffmpeg | libav-tools, libavdevice53 | libavdevice55 | libavdevice57
|
, ffmpeg | libav-tools
|
||||||
, rsyslog | system-log-daemon
|
, rsyslog | system-log-daemon
|
||||||
, netpbm
|
, netpbm
|
||||||
, zip
|
, zip
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
../redhat/misc/redalert.wav
|
../redhat/common/redalert.wav
|
|
@ -27,7 +27,7 @@ Source: ZoneMinder-%{version}.tar.gz
|
||||||
|
|
||||||
BuildRequires: cmake polkit-devel
|
BuildRequires: cmake polkit-devel
|
||||||
BuildRequires: perl-DBI perl-DBD-mysql perl-Date-Manip perl-Sys-Mmap
|
BuildRequires: perl-DBI perl-DBD-mysql perl-Date-Manip perl-Sys-Mmap
|
||||||
BuildRequires: libjpeg62 libjpeg62-devel libmysqld-devel libSDL-devel libgcrypt-devel libgnutls-devel
|
BuildRequires: libjpeg62 libjpeg62-devel libmysqld-devel libSDL-devel libgnutls-devel
|
||||||
BuildRequires: libffmpeg-devel x264
|
BuildRequires: libffmpeg-devel x264
|
||||||
BuildRequires: pcre-devel w32codec-all
|
BuildRequires: pcre-devel w32codec-all
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
%global _hardened_build 1
|
%global _hardened_build 1
|
||||||
|
|
||||||
Name: zoneminder
|
Name: zoneminder
|
||||||
Version: 1.36.5
|
Version: 1.37.3
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: A camera monitoring and analysis tool
|
Summary: A camera monitoring and analysis tool
|
||||||
Group: System Environment/Daemons
|
Group: System Environment/Daemons
|
||||||
|
@ -430,6 +430,9 @@ ln -sf %{_sysconfdir}/zm/www/zoneminder.nginx.conf %{_sysconfdir}/zm/www/zonemin
|
||||||
%dir %attr(755,nginx,nginx) %{_localstatedir}/log/zoneminder
|
%dir %attr(755,nginx,nginx) %{_localstatedir}/log/zoneminder
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jul 05 2021 Andrew Bauer <zonexpertconsulting@outlook.com> - 1.37.1-1
|
||||||
|
- 1.37.x development build
|
||||||
|
|
||||||
* Tue Jun 22 2021 Andrew Bauer <zonexpertconsulting@outlook.com> - 1.36.5-1
|
* Tue Jun 22 2021 Andrew Bauer <zonexpertconsulting@outlook.com> - 1.36.5-1
|
||||||
- 1.36.5 release
|
- 1.36.5 release
|
||||||
|
|
||||||
|
|
|
@ -8,14 +8,14 @@ Build-Depends: debhelper (>= 9), po-debconf (>= 1.0), autoconf, automake, libtoo
|
||||||
, libdate-manip-perl, libwww-perl
|
, libdate-manip-perl, libwww-perl
|
||||||
, libjpeg8-dev | libjpeg9-dev | libjpeg62-turbo-dev
|
, libjpeg8-dev | libjpeg9-dev | libjpeg62-turbo-dev
|
||||||
, libpcre3-dev
|
, libpcre3-dev
|
||||||
, libavcodec-ffmpeg-dev, libavformat-ffmpeg-dev, libswscale-ffmpeg-dev, libavutil-ffmpeg-dev, libavdevice-ffmpeg-dev
|
, libavcodec-ffmpeg-dev, libavformat-ffmpeg-dev, libswscale-ffmpeg-dev, libavutil-ffmpeg-dev
|
||||||
, libv4l-dev (>= 0.8.3)
|
, libv4l-dev (>= 0.8.3)
|
||||||
, libbz2-dev
|
, libbz2-dev
|
||||||
, libsys-mmap-perl
|
, libsys-mmap-perl
|
||||||
, libdevice-serialport-perl, libarchive-zip-perl, libmime-lite-perl
|
, libdevice-serialport-perl, libarchive-zip-perl, libmime-lite-perl
|
||||||
, libvlccore-dev, libvlc-dev
|
, libvlccore-dev, libvlc-dev
|
||||||
, libcurl4-gnutls-dev | libcurl4-nss-dev | libcurl4-openssl-dev
|
, libcurl4-gnutls-dev | libcurl4-nss-dev | libcurl4-openssl-dev
|
||||||
, libgcrypt11-dev | libgcrypt20-dev, libpolkit-gobject-1-dev
|
, libpolkit-gobject-1-dev
|
||||||
, libdbi-perl, libnet-sftp-foreign-perl, libexpect-perl, libmime-tools-perl
|
, libdbi-perl, libnet-sftp-foreign-perl, libexpect-perl, libmime-tools-perl
|
||||||
Standards-Version: 3.9.6
|
Standards-Version: 3.9.6
|
||||||
Homepage: http://www.zoneminder.com/
|
Homepage: http://www.zoneminder.com/
|
||||||
|
|
|
@ -15,7 +15,6 @@ DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE)
|
||||||
DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE)
|
DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE)
|
||||||
|
|
||||||
CFLAGS = -Wall
|
CFLAGS = -Wall
|
||||||
CXXFLAGS = -DHAVE_LIBCRYPTO
|
|
||||||
|
|
||||||
ifneq (,$(findstring debug,$(DEB_BUILD_OPTIONS)))
|
ifneq (,$(findstring debug,$(DEB_BUILD_OPTIONS)))
|
||||||
DEBOPT = --enable-debug
|
DEBOPT = --enable-debug
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
zoneminder (1.28.1-1) unstable; urgency=low
|
|
||||||
|
|
||||||
This version is no longer automatically initialize or upgrade database.
|
|
||||||
See README.Debian for details.
|
|
||||||
|
|
||||||
Changed installation paths (please correct your web server configuration):
|
|
||||||
/usr/share/zoneminder --> /usr/share/zoneminder/www
|
|
||||||
/usr/lib/cgi-bin --> /usr/lib/zoneminder/cgi-bin
|
|
||||||
|
|
||||||
-- Dmitry Smirnov <onlyjob@debian.org> Tue, 31 Mar 2015 15:12:17 +1100
|
|
|
@ -1,130 +0,0 @@
|
||||||
Zoneminder for Debian
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
Initializing database
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
pv /usr/share/zoneminder/db/zm_create.sql | sudo mysql --defaults-file=/etc/mysql/debian.cnf
|
|
||||||
OR
|
|
||||||
cat /usr/share/zoneminder/db/zm_create.sql | sudo mysql --defaults-file=/etc/mysql/debian.cnf
|
|
||||||
|
|
||||||
echo 'grant lock tables,alter,create,index,select,insert,update,delete on zm.* to 'zmuser'@localhost identified by "zmpass";'\
|
|
||||||
| sudo mysql --defaults-file=/etc/mysql/debian.cnf mysql
|
|
||||||
|
|
||||||
Hint: generate secure password with `pwgen` and update "/etc/zm/zm.conf"
|
|
||||||
accordingly.
|
|
||||||
|
|
||||||
The following command can help to ensure that zoneminder can read its
|
|
||||||
configuration file:
|
|
||||||
|
|
||||||
chgrp -c www-data /etc/zm/zm.conf
|
|
||||||
|
|
||||||
|
|
||||||
Upgrading database
|
|
||||||
------------------
|
|
||||||
|
|
||||||
The database is updated automatically on installation. You should not need to take this step.
|
|
||||||
|
|
||||||
Assuming that database is on "localhost" then the following command can be
|
|
||||||
used to upgrade "zm" database:
|
|
||||||
|
|
||||||
zmupdate.pl
|
|
||||||
|
|
||||||
Additional permissions may be required to perform upgrade:
|
|
||||||
|
|
||||||
echo 'grant lock tables, create, alter on zm.* to 'zmuser'@localhost identified by "zmpass";'\
|
|
||||||
| sudo mysql --defaults-file=/etc/mysql/debian.cnf mysql
|
|
||||||
|
|
||||||
The following command prints the current version of zoneminder database:
|
|
||||||
|
|
||||||
echo 'select Value from Config where Name = "ZM_DYN_CURR_VERSION";' \
|
|
||||||
| sudo mysql --defaults-file=/etc/mysql/debian.cnf --skip-column-names zm
|
|
||||||
|
|
||||||
|
|
||||||
Enabling service
|
|
||||||
----------------
|
|
||||||
|
|
||||||
By default Zoneminder service is not automatically started and needs to be
|
|
||||||
manually enabled once database is configured:
|
|
||||||
|
|
||||||
sudo systemctl enable zoneminder.service
|
|
||||||
|
|
||||||
|
|
||||||
Web server set-up
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
There are few manual steps to get the web interface working:
|
|
||||||
|
|
||||||
## Apache2
|
|
||||||
|
|
||||||
Apache can be configured as folder "/zm" using sample .conf:
|
|
||||||
|
|
||||||
sudo a2enconf zoneminder
|
|
||||||
|
|
||||||
Alternatively Apache web site configuration template can be used to setup
|
|
||||||
zoneminder as "http://zoneminder":
|
|
||||||
|
|
||||||
sudo cp -v /usr/share/doc/zoneminder/examples/apache.conf /etc/apache2/sites-available/
|
|
||||||
sudo a2ensite zoneminder.conf
|
|
||||||
|
|
||||||
Common configuration steps for Apache2:
|
|
||||||
|
|
||||||
sudo a2enmod cgi
|
|
||||||
sudo service apache2 reload
|
|
||||||
|
|
||||||
|
|
||||||
## nginx / fcgiwrap
|
|
||||||
|
|
||||||
Nginx needs "php-fpm" package to support PHP and "fcgiwrap" package
|
|
||||||
for binary "cgi-bin" applications:
|
|
||||||
|
|
||||||
sudo apt-get install php-fpm fcgiwrap
|
|
||||||
|
|
||||||
To enable a URL alias that makes Zoneminder available from
|
|
||||||
|
|
||||||
http://yourserver/zm
|
|
||||||
|
|
||||||
the following line is to be added to "server" section of a web site
|
|
||||||
configuration:
|
|
||||||
|
|
||||||
include /usr/share/doc/zoneminder/examples/nginx.conf;
|
|
||||||
|
|
||||||
For "default" web site it would be sufficient to include the above
|
|
||||||
statement to the file
|
|
||||||
|
|
||||||
/etc/nginx/sites-enabled/default
|
|
||||||
|
|
||||||
To avoid problems with feeds from multiple cameras "fcgiwrap" should be
|
|
||||||
configured to start at least as many processes as there are cameras.
|
|
||||||
It can be done by adjusting DAEMON_OPTS in "/etc/default/fcgiwrap".
|
|
||||||
Systemd users may be affected by the following bug:
|
|
||||||
|
|
||||||
http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=792705
|
|
||||||
|
|
||||||
|
|
||||||
## Note:
|
|
||||||
|
|
||||||
When Zoneminder web site is running it may be necessary to set
|
|
||||||
Options/Paths/PATH_ZMS to "/zm/cgi-bin/nph-zms" or according to chosen web
|
|
||||||
site configuration.
|
|
||||||
|
|
||||||
|
|
||||||
Changing the location for images and events
|
|
||||||
-------------------------------------------
|
|
||||||
|
|
||||||
ZoneMinder is now able to be configured to use an alternative location for storing
|
|
||||||
events and images at compile time. This package makes use of that, so symlinks in
|
|
||||||
/usr/share/zoneminder/www are no longer necessary.
|
|
||||||
|
|
||||||
Access to /dev/video*
|
|
||||||
---------------------
|
|
||||||
|
|
||||||
For cameras which require access to /dev/video*, zoneminder may need the
|
|
||||||
www-data user added to the video group in order to see those cameras:
|
|
||||||
|
|
||||||
adduser www-data video
|
|
||||||
|
|
||||||
Note that all web applications running on the zoneminder server will then have
|
|
||||||
access to all video devices on the system.
|
|
||||||
|
|
||||||
-- Vagrant Cascadian <vagrant@debian.org> Sun, 27 Mar 2011 13:06:56 -0700
|
|
|
@ -1,12 +0,0 @@
|
||||||
|
|
||||||
## Separate substantial /usr/share into its own arch-all package.
|
|
||||||
|
|
||||||
## Decide how to handle database updates.
|
|
||||||
|
|
||||||
* Consider possibility that database may be on another machine (#469239).
|
|
||||||
* Consider dbconfig-common? Probably not (what if database is not on localhost?).
|
|
||||||
|
|
||||||
### Run `zmupdate.pl` from service control scripts (init.d, service) on start?
|
|
||||||
|
|
||||||
Automatic upgrade will break "one DB, many zoneminders" setup (unimportant?).
|
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
zoneminder (1.35.6~20200825.27-xenial) xenial; urgency=low
|
|
||||||
*
|
|
||||||
-- Isaac Connor <isaac@zoneminder.com> Tue, 25 Aug 2020 09:28:18 -0400
|
|
|
@ -1,3 +0,0 @@
|
||||||
.gitattributes
|
|
||||||
web/api/.gitattributes
|
|
||||||
web/api/.gitignore
|
|
|
@ -1 +0,0 @@
|
||||||
9
|
|
|
@ -1,57 +0,0 @@
|
||||||
# Remember to enable cgi mod (i.e. "a2enmod cgi").
|
|
||||||
ScriptAlias /zm/cgi-bin "/usr/lib/zoneminder/cgi-bin"
|
|
||||||
<Directory "/usr/lib/zoneminder/cgi-bin">
|
|
||||||
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
|
|
||||||
AllowOverride All
|
|
||||||
Require all granted
|
|
||||||
</Directory>
|
|
||||||
|
|
||||||
|
|
||||||
# Order matters. This alias must come first.
|
|
||||||
Alias /zm/cache /var/cache/zoneminder/cache
|
|
||||||
<Directory /var/cache/zoneminder/cache>
|
|
||||||
Options -Indexes +FollowSymLinks
|
|
||||||
AllowOverride None
|
|
||||||
<IfModule mod_authz_core.c>
|
|
||||||
# Apache 2.4
|
|
||||||
Require all granted
|
|
||||||
</IfModule>
|
|
||||||
<IfModule !mod_authz_core.c>
|
|
||||||
# Apache 2.2
|
|
||||||
Order deny,allow
|
|
||||||
Allow from all
|
|
||||||
</IfModule>
|
|
||||||
</Directory>
|
|
||||||
|
|
||||||
Alias /zm /usr/share/zoneminder/www
|
|
||||||
<Directory /usr/share/zoneminder/www>
|
|
||||||
Options -Indexes +FollowSymLinks
|
|
||||||
<IfModule mod_dir.c>
|
|
||||||
DirectoryIndex index.php
|
|
||||||
</IfModule>
|
|
||||||
</Directory>
|
|
||||||
|
|
||||||
# For better visibility, the following directives have been migrated from the
|
|
||||||
# default .htaccess files included with the CakePHP project.
|
|
||||||
# Parameters not set here are inherited from the parent directive above.
|
|
||||||
<Directory "/usr/share/zoneminder/www/api">
|
|
||||||
RewriteEngine on
|
|
||||||
RewriteRule ^$ app/webroot/ [L]
|
|
||||||
RewriteRule (.*) app/webroot/$1 [L]
|
|
||||||
RewriteBase /zm/api
|
|
||||||
</Directory>
|
|
||||||
|
|
||||||
<Directory "/usr/share/zoneminder/www/api/app">
|
|
||||||
RewriteEngine on
|
|
||||||
RewriteRule ^$ webroot/ [L]
|
|
||||||
RewriteRule (.*) webroot/$1 [L]
|
|
||||||
RewriteBase /zm/api
|
|
||||||
</Directory>
|
|
||||||
|
|
||||||
<Directory "/usr/share/zoneminder/www/api/app/webroot">
|
|
||||||
RewriteEngine On
|
|
||||||
RewriteCond %{REQUEST_FILENAME} !-d
|
|
||||||
RewriteCond %{REQUEST_FILENAME} !-f
|
|
||||||
RewriteRule ^ index.php [L]
|
|
||||||
RewriteBase /zm/api
|
|
||||||
</Directory>
|
|
|
@ -1,165 +0,0 @@
|
||||||
Source: zoneminder
|
|
||||||
Section: net
|
|
||||||
Priority: optional
|
|
||||||
Maintainer: Isaac Connor <isaac@zoneminder.com>
|
|
||||||
Uploaders: Isaac Connor <isaac@zoneminder.com>
|
|
||||||
Build-Depends: debhelper (>= 9), dh-systemd, python3-sphinx, apache2-dev, dh-linktree, dh-systemd, dh-apache2
|
|
||||||
,cmake
|
|
||||||
,libavdevice-dev (>= 6:10~)
|
|
||||||
,libavcodec-dev (>= 6:10~)
|
|
||||||
,libavformat-dev (>= 6:10~)
|
|
||||||
,libavutil-dev (>= 6:10~)
|
|
||||||
,libswresample-dev | libavresample-dev
|
|
||||||
,libswscale-dev (>= 6:10~)
|
|
||||||
,ffmpeg | libav-tools
|
|
||||||
,net-tools
|
|
||||||
,libbz2-dev
|
|
||||||
,libgcrypt-dev | libgcrypt11-dev
|
|
||||||
,libcurl4-gnutls-dev
|
|
||||||
,libgnutls-openssl-dev
|
|
||||||
,libjpeg8-dev | libjpeg9-dev | libjpeg62-turbo-dev
|
|
||||||
,default-libmysqlclient-dev | libmysqlclient-dev | libmariadbclient-dev-compat
|
|
||||||
,libpcre3-dev
|
|
||||||
,libpolkit-gobject-1-dev
|
|
||||||
,libv4l-dev (>= 0.8.3) [!hurd-any]
|
|
||||||
,libvlc-dev
|
|
||||||
,libdate-manip-perl
|
|
||||||
,libdbd-mysql-perl
|
|
||||||
,libphp-serialization-perl
|
|
||||||
,libsys-mmap-perl [!hurd-any]
|
|
||||||
,libwww-perl
|
|
||||||
,libdata-uuid-perl
|
|
||||||
,libssl-dev
|
|
||||||
,libcrypt-eksblowfish-perl
|
|
||||||
,libdata-entropy-perl
|
|
||||||
,libvncserver-dev
|
|
||||||
Standards-Version: 3.9.8
|
|
||||||
Homepage: http://www.zoneminder.com/
|
|
||||||
Vcs-Browser: http://anonscm.debian.org/cgit/collab-maint/zoneminder.git
|
|
||||||
Vcs-Git: git://anonscm.debian.org/collab-maint/zoneminder.git
|
|
||||||
|
|
||||||
Package: zoneminder
|
|
||||||
Architecture: any
|
|
||||||
Depends: ${shlibs:Depends}, ${misc:Depends}, ${perl:Depends}
|
|
||||||
,javascript-common
|
|
||||||
,libswscale-ffmpeg3|libswscale4|libswscale3|libswscale5
|
|
||||||
,libswresample2|libswresample3|libswresample24|libswresample-ffmpeg1
|
|
||||||
,ffmpeg | libav-tools
|
|
||||||
,libdate-manip-perl, libmime-lite-perl, libmime-tools-perl
|
|
||||||
,libdbd-mysql-perl
|
|
||||||
,libphp-serialization-perl
|
|
||||||
,libmodule-load-conditional-perl
|
|
||||||
,libnet-sftp-foreign-perl
|
|
||||||
,libarchive-zip-perl
|
|
||||||
,libdbd-mysql-perl
|
|
||||||
,libdevice-serialport-perl
|
|
||||||
,libimage-info-perl
|
|
||||||
,libjson-maybexs-perl
|
|
||||||
,libsys-mmap-perl [!hurd-any]
|
|
||||||
,liburi-encode-perl
|
|
||||||
,libwww-perl, liburi-perl
|
|
||||||
,libdata-dump-perl
|
|
||||||
,libdatetime-perl
|
|
||||||
,libclass-std-fast-perl
|
|
||||||
,libsoap-wsdl-perl
|
|
||||||
,libio-socket-multicast-perl
|
|
||||||
,libdigest-sha-perl
|
|
||||||
,libsys-cpu-perl, libsys-meminfo-perl
|
|
||||||
,libdata-uuid-perl
|
|
||||||
,libnumber-bytes-human-perl
|
|
||||||
,libfile-slurp-perl
|
|
||||||
,mysql-client | mariadb-client | virtual-mysql-client
|
|
||||||
,perl-modules
|
|
||||||
,php5-mysql | php-mysql, php5-gd | php-gd , php5-apcu | php-apcu , php-apc | php-apcu-bc, php-json | php5-json
|
|
||||||
,policykit-1
|
|
||||||
,rsyslog | system-log-daemon
|
|
||||||
,zip
|
|
||||||
,libpcre3
|
|
||||||
,libssl | libssl1.0.0 | libssl1.1
|
|
||||||
,libcrypt-eksblowfish-perl
|
|
||||||
,libdata-entropy-perl
|
|
||||||
,libvncclient1|libvncclient0
|
|
||||||
Recommends: ${misc:Recommends}
|
|
||||||
,libapache2-mod-php5 | libapache2-mod-php | php5-fpm | php-fpm
|
|
||||||
,mysql-server | mariadb-server | virtual-mysql-server
|
|
||||||
,zoneminder-doc (>= ${source:Version})
|
|
||||||
,ffmpeg
|
|
||||||
Suggests: fcgiwrap, logrotate
|
|
||||||
Description: video camera security and surveillance solution
|
|
||||||
ZoneMinder is intended for use in single or multi-camera video security
|
|
||||||
applications, including commercial or home CCTV, theft prevention and child
|
|
||||||
or family member or home monitoring and other care scenarios. It
|
|
||||||
supports capture, analysis, recording, and monitoring of video data coming
|
|
||||||
from one or more video or network cameras attached to a Linux system.
|
|
||||||
ZoneMinder also support web and semi-automatic control of Pan/Tilt/Zoom
|
|
||||||
cameras using a variety of protocols. It is suitable for use as a home
|
|
||||||
video security system and for commercial or professional video security
|
|
||||||
and surveillance. It can also be integrated into a home automation system
|
|
||||||
via X.10 or other protocols.
|
|
||||||
|
|
||||||
#Package: libzoneminder-perl
|
|
||||||
#Section: perl
|
|
||||||
#Architecture: all
|
|
||||||
#Multi-Arch: foreign
|
|
||||||
#Depends: ${misc:Depends}, ${perl:Depends}
|
|
||||||
# ,libarchive-zip-perl
|
|
||||||
# ,libdbd-mysql-perl
|
|
||||||
# ,libdevice-serialport-perl
|
|
||||||
# ,libimage-info-perl
|
|
||||||
# ,libjson-maybexs-perl
|
|
||||||
# ,libsys-mmap-perl [!hurd-any]
|
|
||||||
# ,liburi-encode-perl
|
|
||||||
# ,libwww-perl
|
|
||||||
#Description: ZoneMinder Perl libraries
|
|
||||||
# ZoneMinder is intended for use in single or multi-camera video security
|
|
||||||
# applications, including commercial or home CCTV, theft prevention and child
|
|
||||||
# or family member or home monitoring and other care scenarios. It
|
|
||||||
# supports capture, analysis, recording, and monitoring of video data coming
|
|
||||||
# from one or more video or network cameras attached to a Linux system.
|
|
||||||
# ZoneMinder also support web and semi-automatic control of Pan/Tilt/Zoom
|
|
||||||
# cameras using a variety of protocols. It is suitable for use as a home
|
|
||||||
# video security system and for commercial or professional video security
|
|
||||||
# and surveillance. It can also be integrated into a home automation system
|
|
||||||
# via X.10 or other protocols.
|
|
||||||
# .
|
|
||||||
# This package provides ZoneMinder Perl libraries; it can be used to
|
|
||||||
# write custom interfaces as well.
|
|
||||||
|
|
||||||
Package: zoneminder-doc
|
|
||||||
Section: doc
|
|
||||||
Architecture: all
|
|
||||||
Multi-Arch: foreign
|
|
||||||
Depends: ${misc:Depends}, ${sphinxdoc:Depends}, python3-sphinx-rtd-theme
|
|
||||||
Suggests: www-browser
|
|
||||||
Description: ZoneMinder documentation
|
|
||||||
ZoneMinder is intended for use in single or multi-camera video security
|
|
||||||
applications, including commercial or home CCTV, theft prevention and child
|
|
||||||
or family member or home monitoring and other care scenarios. It
|
|
||||||
supports capture, analysis, recording, and monitoring of video data coming
|
|
||||||
from one or more video or network cameras attached to a Linux system.
|
|
||||||
ZoneMinder also support web and semi-automatic control of Pan/Tilt/Zoom
|
|
||||||
cameras using a variety of protocols. It is suitable for use as a home
|
|
||||||
video security system and for commercial or professional video security
|
|
||||||
and surveillance. It can also be integrated into a home automation system
|
|
||||||
via X.10 or other protocols.
|
|
||||||
.
|
|
||||||
This package provides ZoneMinder documentation in HTML format.
|
|
||||||
|
|
||||||
Package: zoneminder-dbg
|
|
||||||
Section: debug
|
|
||||||
Priority: extra
|
|
||||||
Architecture: any
|
|
||||||
Depends: zoneminder (= ${binary:Version}), ${misc:Depends}
|
|
||||||
Description: Zoneminder -- debugging symbols
|
|
||||||
ZoneMinder is intended for use in single or multi-camera video security
|
|
||||||
applications, including commercial or home CCTV, theft prevention and child
|
|
||||||
or family member or home monitoring and other care scenarios. It
|
|
||||||
supports capture, analysis, recording, and monitoring of video data coming
|
|
||||||
from one or more video or network cameras attached to a Linux system.
|
|
||||||
ZoneMinder also support web and semi-automatic control of Pan/Tilt/Zoom
|
|
||||||
cameras using a variety of protocols. It is suitable for use as a home
|
|
||||||
video security system and for commercial or professional video security
|
|
||||||
and surveillance. It can also be integrated into a home automation system
|
|
||||||
via X.10 or other protocols.
|
|
||||||
.
|
|
||||||
This package provides debugging symbols
|
|
|
@ -1,168 +0,0 @@
|
||||||
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
|
||||||
Upstream-Name: ZoneMinder
|
|
||||||
Upstream-Contact: Philip Coombes <philip.coombes@zoneminder.com>
|
|
||||||
Source: https://github.com/ZoneMinder/ZoneMinder
|
|
||||||
Comment:
|
|
||||||
This package was originally debianized by matrix <matrix@cecilia>
|
|
||||||
on Mon, 7 Mar 2005 02:07:57 -0500.
|
|
||||||
It was re-done for submission to the Debian project by Peter Howard
|
|
||||||
<pjh@northern-ridge.com.au> on Fri, 8 Dec 2006 10:19:43 +1100
|
|
||||||
Files-Excluded:
|
|
||||||
web/skins/*/js/jquery-*
|
|
||||||
|
|
||||||
Files: *
|
|
||||||
Copyright: 2001-2014 Philip Coombes <philip.coombes@zoneminder.com>
|
|
||||||
2008 Brian Rudy <brudyNO@SPAMpraecogito.com>
|
|
||||||
2014 Vincent Giovannone
|
|
||||||
2013 Tim Craig <timcraigNO@SPAMsonic.net>
|
|
||||||
2003-2008 Corey DeLasaux
|
|
||||||
2001-2010 Chris Kistner
|
|
||||||
License: GPL-2+
|
|
||||||
|
|
||||||
Files: distros/*
|
|
||||||
Copyright: 2001-2008 Philip Coombes <philip.coombes@zoneminder.com>
|
|
||||||
2014 Isaac Connor <iconnor@connortechnology.com>
|
|
||||||
2005 Serg Oskin
|
|
||||||
License: GPL-2+
|
|
||||||
|
|
||||||
Files: web/skins/*/js/jquery-*
|
|
||||||
Copyright: 2010 John Resig
|
|
||||||
2010 The Dojo Foundation
|
|
||||||
License: GPL-2 or Expat
|
|
||||||
Comment:
|
|
||||||
Dual licensed under the MIT or GPL Version 2 licenses.
|
|
||||||
http://jquery.org/license
|
|
||||||
.
|
|
||||||
Includes Sizzle.js http://sizzlejs.com/
|
|
||||||
Released under the MIT, BSD, and GPL Licenses.
|
|
||||||
|
|
||||||
Files: web/api/*
|
|
||||||
Copyright: 2005-2013 Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
||||||
License: Expat
|
|
||||||
|
|
||||||
Files:
|
|
||||||
cmake/Modules/CheckPrototypeDefinition*.cmake
|
|
||||||
cmake/Modules/FindGLIB2.cmake
|
|
||||||
cmake/Modules/FindPolkit.cmake
|
|
||||||
cmake/Modules/GNUInstallDirs.cmake
|
|
||||||
Copyright:
|
|
||||||
2005-2011 Kitware, Inc.
|
|
||||||
2010-2011 Andreas Schneider <asn@cryptomilk.org>
|
|
||||||
2009 Dario Freddi <drf@kde.org>
|
|
||||||
2008 Laurent Montel, <montel@kde.org>
|
|
||||||
2011 Nikita Krupen'ko <krnekit@gmail.com>
|
|
||||||
License: BSD-3-clause
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
|
||||||
modification, are permitted provided that the following conditions are
|
|
||||||
met:
|
|
||||||
.
|
|
||||||
* Redistributions of source code must retain the above copyright notice,
|
|
||||||
this list of conditions and the following disclaimer.
|
|
||||||
.
|
|
||||||
* Redistributions in binary form must reproduce the above copyright notice,
|
|
||||||
this list of conditions and the following disclaimer in the documentation
|
|
||||||
and/or other materials provided with the distribution.
|
|
||||||
.
|
|
||||||
* The names of Kitware, Inc., the Insight Consortium, or the names of
|
|
||||||
any consortium members, or of any contributors, may not be used to
|
|
||||||
endorse or promote products derived from this software without
|
|
||||||
specific prior written permission.
|
|
||||||
.
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS ``AS IS''
|
|
||||||
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
||||||
ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR
|
|
||||||
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
||||||
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
||||||
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
||||||
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
Files: cmake/Modules/FindPerlModules.cmake
|
|
||||||
Copyright: 2012 Iowa State University
|
|
||||||
License: Boost-1.0
|
|
||||||
Boost Software License - Version 1.0 - August 17th, 2003
|
|
||||||
.
|
|
||||||
Permission is hereby granted, free of charge, to any person or organization
|
|
||||||
obtaining a copy of the software and accompanying documentation covered by
|
|
||||||
this license (the "Software") to use, reproduce, display, distribute,
|
|
||||||
execute, and transmit the Software, and to prepare derivative works of the
|
|
||||||
Software, and to permit third-parties to whom the Software is furnished to
|
|
||||||
do so, all subject to the following:
|
|
||||||
.
|
|
||||||
The copyright notices in the Software and this entire statement, including
|
|
||||||
the above license grant, this restriction and the following disclaimer,
|
|
||||||
must be included in all copies of the Software, in whole or in part, and
|
|
||||||
all derivative works of the Software, unless such copies or derivative
|
|
||||||
works are solely in the form of machine-executable object code generated by
|
|
||||||
a source language processor.
|
|
||||||
.
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
||||||
SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
||||||
FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
||||||
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
Files: debian/*
|
|
||||||
Copyright: 2015 Dmitry Smirnov <onlyjob@debian.org>
|
|
||||||
2007-2014 Peter Howard <pjh@northern-ridge.com.au>
|
|
||||||
2010-2012 Vagrant Cascadian <vagrant@debian.org>
|
|
||||||
2001-2008 Philip Coombes <philip.coombes@zoneminder.com>
|
|
||||||
License: GPL-2+
|
|
||||||
|
|
||||||
License: Expat
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
.
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
.
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
|
|
||||||
License: GPL-2+
|
|
||||||
This package is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU General Public License as published by the
|
|
||||||
Free Software Foundation; either version 2 of the License, or (at your
|
|
||||||
option) any later version.
|
|
||||||
.
|
|
||||||
This package is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
General Public License for more details.
|
|
||||||
.
|
|
||||||
You should have received a copy of the GNU General Public
|
|
||||||
License along with this package; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
.
|
|
||||||
The complete text of the GNU General Public License version 2
|
|
||||||
can be found in "/usr/share/common-licenses/GPL-2".
|
|
||||||
|
|
||||||
License: GPL-2
|
|
||||||
This package is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU General Public License as published by the
|
|
||||||
Free Software Foundation; version 2 of the License.
|
|
||||||
.
|
|
||||||
This package is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
General Public License for more details.
|
|
||||||
.
|
|
||||||
You should have received a copy of the GNU General Public
|
|
||||||
License along with this package; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
.
|
|
||||||
The complete text of the GNU General Public License version 2
|
|
||||||
can be found in "/usr/share/common-licenses/GPL-2".
|
|
|
@ -1,32 +0,0 @@
|
||||||
location /zm/cgi-bin {
|
|
||||||
gzip off;
|
|
||||||
alias /usr/lib/zoneminder/cgi-bin;
|
|
||||||
|
|
||||||
include /etc/nginx/fastcgi_params;
|
|
||||||
fastcgi_param SCRIPT_FILENAME $request_filename;
|
|
||||||
fastcgi_pass unix:/var/run/fcgiwrap.socket;
|
|
||||||
}
|
|
||||||
|
|
||||||
location /zm {
|
|
||||||
# if ($scheme ~ ^http:){
|
|
||||||
# rewrite ^(.*)$ https://$host$1 permanent;
|
|
||||||
# }
|
|
||||||
|
|
||||||
gzip off;
|
|
||||||
alias /usr/share/zoneminder/www;
|
|
||||||
index index.php;
|
|
||||||
|
|
||||||
location ~ \.php$ {
|
|
||||||
if (!-f $request_filename) { return 404; }
|
|
||||||
expires epoch;
|
|
||||||
include /etc/nginx/fastcgi_params;
|
|
||||||
fastcgi_param SCRIPT_FILENAME $request_filename;
|
|
||||||
fastcgi_index index.php;
|
|
||||||
fastcgi_pass unix:/var/run/php5-fpm.sock;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ \.(jpg|jpeg|gif|png|ico)$ {
|
|
||||||
access_log off;
|
|
||||||
expires 33d;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
|
|
||||||
[dch]
|
|
||||||
id-length = 0
|
|
||||||
|
|
||||||
[import-orig]
|
|
||||||
pristine-tar = False
|
|
||||||
merge = False
|
|
|
@ -1,2 +0,0 @@
|
||||||
usr/share/man/man3
|
|
||||||
usr/share/perl5
|
|
|
@ -1,96 +0,0 @@
|
||||||
#!/usr/bin/make -f
|
|
||||||
# -*- makefile -*-
|
|
||||||
|
|
||||||
# Uncomment this to turn on verbose mode.
|
|
||||||
#export DH_VERBOSE=1
|
|
||||||
|
|
||||||
export DEB_BUILD_MAINT_OPTIONS = hardening=+all
|
|
||||||
export DEB_LDFLAGS_MAINT_APPEND += -Wl,--as-needed
|
|
||||||
|
|
||||||
ifeq ($(DEB_BUILD_ARCH_OS),hurd)
|
|
||||||
ARGS:= -DZM_NO_MMAP=ON
|
|
||||||
endif
|
|
||||||
|
|
||||||
%:
|
|
||||||
dh $@ --parallel --buildsystem=cmake --builddirectory=dbuild \
|
|
||||||
--with systemd,sphinxdoc,apache2,linktree
|
|
||||||
|
|
||||||
override_dh_auto_configure:
|
|
||||||
dh_auto_configure -- $(ARGS) \
|
|
||||||
-DCMAKE_VERBOSE_MAKEFILE=ON \
|
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
|
||||||
-DZM_CONFIG_DIR="/etc/zm" \
|
|
||||||
-DZM_CONFIG_SUBDIR="/etc/zm/conf.d" \
|
|
||||||
-DZM_RUNDIR="/run/zm" \
|
|
||||||
-DZM_SOCKDIR="/run/zm" \
|
|
||||||
-DZM_TMPDIR="/tmp/zm" \
|
|
||||||
-DZM_CGIDIR="/usr/lib/zoneminder/cgi-bin" \
|
|
||||||
-DZM_CACHEDIR="/var/cache/zoneminder/cache" \
|
|
||||||
-DZM_DIR_EVENTS="/var/cache/zoneminder/events" \
|
|
||||||
-DZM_PATH_SHUTDOWN="/sbin/shutdown" \
|
|
||||||
-DZM_PATH_ZMS="/zm/cgi-bin/nph-zms"
|
|
||||||
|
|
||||||
override_dh_clean:
|
|
||||||
dh_clean $(MANPAGES1)
|
|
||||||
$(RM) -r docs/_build
|
|
||||||
|
|
||||||
build-indep:
|
|
||||||
#$(MAKE) -C docs text
|
|
||||||
$(MAKE) -C docs html
|
|
||||||
|
|
||||||
MANPAGES1 = dbuild/scripts/zmupdate.pl.1
|
|
||||||
$(MANPAGES1):
|
|
||||||
# generate man page(s):
|
|
||||||
pod2man -s1 --stderr --utf8 $(patsubst %.1, %, $@) $@
|
|
||||||
|
|
||||||
## reproducible build:
|
|
||||||
LAST_CHANGE=$(shell dpkg-parsechangelog -S Date)
|
|
||||||
BUILD_DATE=$(shell LC_ALL=C date -u "+%B %d, %Y" -d "$(LAST_CHANGE)")
|
|
||||||
override_dh_installman: $(MANPAGES1)
|
|
||||||
$(MAKE) -C docs man SPHINXOPTS="-D today=\"$(BUILD_DATE)\""
|
|
||||||
dh_installman --language=C $(MANPAGES1)
|
|
||||||
|
|
||||||
override_dh_auto_install:
|
|
||||||
dh_auto_install --destdir=$(CURDIR)/debian/tmp
|
|
||||||
# remove worthless files:
|
|
||||||
$(RM) -v $(CURDIR)/debian/tmp/usr/share/perl5/*/*/*/.packlist
|
|
||||||
$(RM) -v $(CURDIR)/debian/tmp/usr/share/perl5/*/*.in
|
|
||||||
# remove empty directories:
|
|
||||||
find $(CURDIR)/debian/tmp/usr -type d -empty -delete -printf 'removed %p\n'
|
|
||||||
# remove extra-license-file:
|
|
||||||
$(RM) -v $(CURDIR)/debian/tmp/usr/share/zoneminder/www/api/lib/Cake/LICENSE.txt
|
|
||||||
|
|
||||||
override_dh_fixperms:
|
|
||||||
dh_fixperms
|
|
||||||
#
|
|
||||||
# As requested by the Debian Webapps Policy Manual §3.2.1
|
|
||||||
chown root:www-data $(CURDIR)/debian/zoneminder/etc/zm/zm.conf
|
|
||||||
chmod 640 $(CURDIR)/debian/zoneminder/etc/zm/zm.conf
|
|
||||||
|
|
||||||
override_dh_systemd_start:
|
|
||||||
dh_systemd_start --no-start
|
|
||||||
|
|
||||||
override_dh_systemd_enable:
|
|
||||||
dh_systemd_enable --no-enable
|
|
||||||
|
|
||||||
override_dh_apache2:
|
|
||||||
dh_apache2 --noenable
|
|
||||||
|
|
||||||
override_dh_strip:
|
|
||||||
[ -d "$(CURDIR)/debian/zoneminder-dbg" ] \
|
|
||||||
&& dh_strip --dbg-package=zoneminder-dbg \
|
|
||||||
|| dh_strip
|
|
||||||
|
|
||||||
#%:
|
|
||||||
# dh $@ --parallel --buildsystem=autoconf --with autoreconf
|
|
||||||
#
|
|
||||||
#override_dh_auto_configure:
|
|
||||||
# dh_auto_configure -- \
|
|
||||||
# --sysconfdir=/etc/zm \
|
|
||||||
# --with-mysql=/usr \
|
|
||||||
# --with-webdir=/usr/share/zoneminder \
|
|
||||||
# --with-ffmpeg=/usr \
|
|
||||||
# --with-cgidir=/usr/lib/cgi-bin \
|
|
||||||
# --with-webuser=www-data \
|
|
||||||
# --with-webgroup=www-data \
|
|
||||||
# --enable-mmap=yes
|
|
|
@ -1 +0,0 @@
|
||||||
3.0 (quilt)
|
|
|
@ -1,5 +0,0 @@
|
||||||
## We're using "libjs-jquery" instead.
|
|
||||||
source-is-missing web/skins/*/js/jquery-3.5.1.min.js
|
|
||||||
|
|
||||||
## Acknowledged, will repack eventually.
|
|
||||||
source-contains-prebuilt-javascript-object web/skins/*/js/jquery-3.5.1.min.js
|
|
|
@ -1,8 +0,0 @@
|
||||||
Document: zoneminder-doc
|
|
||||||
Title: Zoneminder documentation
|
|
||||||
Abstract: This document describes how to use Zoneminder.
|
|
||||||
Section: System/Administration
|
|
||||||
|
|
||||||
Format: HTML
|
|
||||||
Index: /usr/share/doc/zoneminder-doc/html/index.html
|
|
||||||
Files: /usr/share/doc/zoneminder-doc/html/*
|
|
|
@ -1 +0,0 @@
|
||||||
docs/_build/html usr/share/doc/zoneminder-doc/
|
|
|
@ -1,2 +0,0 @@
|
||||||
## Convenience symlink:
|
|
||||||
/usr/share/doc/zoneminder-doc/html /usr/share/doc/zoneminder/html
|
|
|
@ -1 +0,0 @@
|
||||||
conf debian/conf/apache2/zoneminder.conf nginx
|
|
|
@ -1,5 +0,0 @@
|
||||||
Unless bug is specific to Debian please consider reporting it directly to
|
|
||||||
upstream developer(s):
|
|
||||||
|
|
||||||
https://github.com/ZoneMinder/ZoneMinder/issues
|
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
var/log/zm
|
|
||||||
var/lib/zm
|
|
||||||
var/cache/zoneminder/events
|
|
||||||
var/cache/zoneminder/images
|
|
||||||
var/cache/zoneminder/temp
|
|
||||||
var/cache/zoneminder/cache
|
|
||||||
usr/share/zoneminder/db
|
|
||||||
usr/share/zoneminder/fonts
|
|
||||||
etc/zm/
|
|
||||||
etc/zm/conf.d
|
|
|
@ -1 +0,0 @@
|
||||||
README.md
|
|
|
@ -1,2 +0,0 @@
|
||||||
debian/examples/*
|
|
||||||
dbuild/misc/apache.conf
|
|
|
@ -1,12 +0,0 @@
|
||||||
etc/zm/zm.conf
|
|
||||||
etc/zm/conf.d/*
|
|
||||||
usr/bin
|
|
||||||
usr/lib/zoneminder
|
|
||||||
usr/share/polkit-1
|
|
||||||
usr/share/zoneminder/db
|
|
||||||
usr/share/zoneminder/www
|
|
||||||
usr/share/zoneminder/fonts
|
|
||||||
|
|
||||||
# libzoneminder-perl files:
|
|
||||||
usr/share/man/man3
|
|
||||||
usr/share/perl5
|
|
|
@ -1 +0,0 @@
|
||||||
/var/tmp /usr/share/zoneminder/www/api/app/tmp
|
|
|
@ -1,6 +0,0 @@
|
||||||
## cakephp
|
|
||||||
#replace /usr/share/php/Cake /usr/share/zoneminder/www/api/lib/Cake
|
|
||||||
|
|
||||||
## libjs-jquery
|
|
||||||
#replace /usr/share/javascript/jquery/jquery.min.js /usr/share/zoneminder/www/skins/classic/js/jquery-3.5.1.min.js
|
|
||||||
#replace /usr/share/javascript/jquery/jquery.min.js /usr/share/zoneminder/www/skins/flat/js/jquery-3.5.1.min.js
|
|
|
@ -1,14 +0,0 @@
|
||||||
# Depends: policykit-1
|
|
||||||
unusual-interpreter usr/bin/zmsystemctl.pl #!/usr/bin/pkexec
|
|
||||||
|
|
||||||
# Intentionally not others-readable, #637685.
|
|
||||||
non-standard-file-perm etc/zm/zm.conf 0640 != 0644
|
|
||||||
|
|
||||||
# Bundled Cake PHP framework, not intended for direct execution:
|
|
||||||
script-not-executable usr/share/zoneminder/www/api/*
|
|
||||||
|
|
||||||
# Annoying but seems to be too much troubles to fix; should be fixed upstream:
|
|
||||||
script-with-language-extension usr/bin/*.pl
|
|
||||||
|
|
||||||
# dh-linktree:
|
|
||||||
package-contains-broken-symlink usr/share/zoneminder/www/api/lib/Cake/*
|
|
|
@ -1,13 +0,0 @@
|
||||||
/var/log/zm/*.log {
|
|
||||||
missingok
|
|
||||||
notifempty
|
|
||||||
sharedscripts
|
|
||||||
delaycompress
|
|
||||||
compress
|
|
||||||
postrotate
|
|
||||||
/usr/bin/zmpkg.pl logrot >>/dev/null 2>&1 || :
|
|
||||||
endscript
|
|
||||||
daily
|
|
||||||
rotate 7
|
|
||||||
maxage 7
|
|
||||||
}
|
|
|
@ -1 +0,0 @@
|
||||||
rm_conffile /etc/zm/apache.conf 1.28.1-5~
|
|
|
@ -1 +0,0 @@
|
||||||
docs/_build/man/*.1
|
|
|
@ -1,101 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
|
|
||||||
set +e
|
|
||||||
|
|
||||||
if [ "$1" = "configure" ]; then
|
|
||||||
|
|
||||||
. /etc/zm/zm.conf
|
|
||||||
for CONFFILE in /etc/zm/conf.d/*.conf; do
|
|
||||||
. "$CONFFILE"
|
|
||||||
done
|
|
||||||
|
|
||||||
# The logs can contain passwords, etc... so by setting group root, only www-data can read them, not people in the www-data group
|
|
||||||
chown www-data:root /var/log/zm
|
|
||||||
chown www-data:www-data /var/lib/zm
|
|
||||||
chown www-data:www-data /var/cache/zoneminder /var/cache/zoneminder/*
|
|
||||||
if [ ! -e "/etc/apache2/mods-enabled/cgi.load" ] && [ "$(command -v a2enmod)" != "" ]; then
|
|
||||||
echo "The cgi module is not enabled in apache2. I am enabling it using a2enmod cgi."
|
|
||||||
a2enmod cgi
|
|
||||||
fi
|
|
||||||
if [ ! -e "/etc/apache2/mods-enabled/rewrite.load" ] && [ "$(command -v a2enmod)" != "" ]; then
|
|
||||||
echo "The rewrite module is not enabled in apache2. I am enabling it using a2enmod rewrite."
|
|
||||||
a2enmod rewrite
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$ZM_DB_HOST" = "localhost" ]; then
|
|
||||||
|
|
||||||
if [ -e "/lib/systemd/system/mysql.service" ] || [ -e "/lib/systemd/system/mariadb.service" ] || [ -e "/etc/init.d/mysql" ]; then
|
|
||||||
# Ensure zoneminder is stopped
|
|
||||||
deb-systemd-invoke stop zoneminder.service || exit $?
|
|
||||||
|
|
||||||
#
|
|
||||||
# Get mysql started if it isn't running
|
|
||||||
#
|
|
||||||
|
|
||||||
if [ -e "/lib/systemd/system/mariadb.service" ]; then
|
|
||||||
DBSERVICE="mariadb.service"
|
|
||||||
else
|
|
||||||
DBSERVICE="mysql.service"
|
|
||||||
fi
|
|
||||||
echo "Detected db service is $DBSERVICE"
|
|
||||||
if systemctl is-failed --quiet $DBSERVICE; then
|
|
||||||
echo "$DBSERVICE is in a failed state; it will not be started."
|
|
||||||
echo "If you have already resolved the problem preventing $DBSERVICE from running,"
|
|
||||||
echo "run sudo systemctl restart $DBSERVICE then run sudo dpkg-reconfigure zoneminder."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! systemctl is-active --quiet mysql.service mariadb.service; then
|
|
||||||
# Due to /etc/init.d service autogeneration, mysql.service always returns the status of mariadb.service
|
|
||||||
# However, mariadb.service will not return the status of mysql.service.
|
|
||||||
deb-systemd-invoke start $DBSERVICE
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Make sure systemctl status exit code is 0; i.e. the DB is running
|
|
||||||
if systemctl is-active --quiet "$DBSERVICE"; then
|
|
||||||
mysqladmin --defaults-file=/etc/mysql/debian.cnf -f reload
|
|
||||||
# test if database if already present...
|
|
||||||
if ! $(echo quit | mysql --defaults-file=/etc/mysql/debian.cnf zm > /dev/null 2> /dev/null) ; then
|
|
||||||
echo "Creating zm db"
|
|
||||||
cat /usr/share/zoneminder/db/zm_create.sql | mysql --defaults-file=/etc/mysql/debian.cnf
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo "Error creating db."
|
|
||||||
exit 1;
|
|
||||||
fi
|
|
||||||
# This creates the user.
|
|
||||||
echo "CREATE USER '${ZM_DB_USER}'@localhost IDENTIFIED BY '${ZM_DB_PASS}';" | mysql --defaults-file=/etc/mysql/debian.cnf mysql
|
|
||||||
fi
|
|
||||||
echo "Updating permissions for user ${ZM_DB_USER}@localhost"
|
|
||||||
echo "GRANT LOCK TABLES,ALTER,DROP,SELECT,INSERT,UPDATE,DELETE,CREATE,INDEX,ALTER ROUTINE,CREATE ROUTINE, TRIGGER,EXECUTE,REFERENCES ON ${ZM_DB_NAME}.* TO '${ZM_DB_USER}'@localhost;" | mysql --defaults-file=/etc/mysql/debian.cnf mysql
|
|
||||||
|
|
||||||
zmupdate.pl -s --nointeractive
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo "Error updating db."
|
|
||||||
exit 1;
|
|
||||||
fi
|
|
||||||
zmupdate.pl --nointeractive -f
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo "Error updating config."
|
|
||||||
exit 1;
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Add any new PTZ control configurations to the database (will not overwrite)
|
|
||||||
zmcamtool.pl --import >/dev/null 2>&1
|
|
||||||
echo "Done Updating; starting ZoneMinder."
|
|
||||||
else
|
|
||||||
echo 'NOTE: MySQL/MariaDB not running; please start mysql and run dpkg-reconfigure zoneminder when it is running.'
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo 'MySQL/MariaDB not found; assuming remote server.'
|
|
||||||
fi
|
|
||||||
|
|
||||||
else
|
|
||||||
echo "Not doing database upgrade due to remote db server ($ZM_DB_HOST)."
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Done Updating; starting ZoneMinder."
|
|
||||||
deb-systemd-invoke restart zoneminder.service
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
#DEBHELPER#
|
|
|
@ -1,14 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [ "$1" = "purge" ]; then
|
|
||||||
echo "
|
|
||||||
Reminder: to completely remove \"zoneminder\" it may be necessary
|
|
||||||
* to delete database using the following sample command:
|
|
||||||
sudo mysqladmin --defaults-file=/etc/mysql/debian.cnf -f drop zm
|
|
||||||
* to delete remaining data files in "/var/cache/zoneminder".
|
|
||||||
"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#DEBHELPER#
|
|
|
@ -1,11 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
## Remove obsolete symlink which is in the way of dh_apache2:
|
|
||||||
ol="/etc/apache2/conf-available/zoneminder.conf"
|
|
||||||
if [ -h "${ol}" ]; then
|
|
||||||
[ "$(readlink ${ol})" = "/etc/zm/apache.conf" ] && rm -f "${ol}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#DEBHELPER#
|
|
|
@ -1,23 +0,0 @@
|
||||||
# ZoneMinder systemd unit file
|
|
||||||
# This file is intended to work with Debian distributions
|
|
||||||
|
|
||||||
[Unit]
|
|
||||||
Description=ZoneMinder CCTV recording and surveillance system
|
|
||||||
After=network.target mysql.service
|
|
||||||
# Remarked out so that it will start ZM on machines that don't have mysql installed
|
|
||||||
#Requires=mysql.service
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
#User=www-data
|
|
||||||
Type=forking
|
|
||||||
ExecStart=/usr/bin/zmpkg.pl start
|
|
||||||
ExecReload=/usr/bin/zmpkg.pl restart
|
|
||||||
ExecStop=/usr/bin/zmpkg.pl stop
|
|
||||||
PIDFile=/run/zm/zm.pid
|
|
||||||
Restart=always
|
|
||||||
RestartSec=10
|
|
||||||
Environment=TZ=:/etc/localtime
|
|
||||||
TimeoutSec=600
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
|
@ -1,4 +0,0 @@
|
||||||
d /run/zm 0755 www-data www-data
|
|
||||||
d /tmp/zm 0755 www-data www-data
|
|
||||||
d /var/tmp/zm 0755 www-data www-data
|
|
||||||
d /var/cache/zoneminder/cache 0755 www-data www-data
|
|
|
@ -2,9 +2,8 @@ Source: zoneminder
|
||||||
Section: net
|
Section: net
|
||||||
Priority: optional
|
Priority: optional
|
||||||
Maintainer: Isaac Connor <isaac@zoneminder.com>
|
Maintainer: Isaac Connor <isaac@zoneminder.com>
|
||||||
Build-Depends: debhelper (>= 12), sphinx-doc, python3-sphinx, dh-linktree, dh-apache2
|
Build-Depends: debhelper (>= 11), sphinx-doc, python3-sphinx, dh-linktree, dh-apache2
|
||||||
,cmake
|
,cmake
|
||||||
,libavdevice-dev
|
|
||||||
,libavcodec-dev
|
,libavcodec-dev
|
||||||
,libavformat-dev
|
,libavformat-dev
|
||||||
,libavutil-dev
|
,libavutil-dev
|
||||||
|
@ -13,12 +12,10 @@ Build-Depends: debhelper (>= 12), sphinx-doc, python3-sphinx, dh-linktree, dh-ap
|
||||||
,ffmpeg
|
,ffmpeg
|
||||||
,net-tools
|
,net-tools
|
||||||
,libbz2-dev
|
,libbz2-dev
|
||||||
,libgcrypt20-dev
|
|
||||||
,libcurl4-gnutls-dev
|
,libcurl4-gnutls-dev
|
||||||
,libjpeg-turbo8-dev | libjpeg62-turbo-dev | libjpeg8-dev | libjpeg9-dev
|
,libjpeg-turbo8-dev | libjpeg62-turbo-dev | libjpeg8-dev | libjpeg9-dev
|
||||||
,libturbojpeg0-dev
|
,libturbojpeg0-dev
|
||||||
,default-libmysqlclient-dev | libmysqlclient-dev | libmariadbclient-dev-compat
|
,default-libmysqlclient-dev | libmysqlclient-dev | libmariadbclient-dev-compat
|
||||||
,libpcre3-dev
|
|
||||||
,libpolkit-gobject-1-dev
|
,libpolkit-gobject-1-dev
|
||||||
,libv4l-dev [!hurd-any]
|
,libv4l-dev [!hurd-any]
|
||||||
,libvlc-dev
|
,libvlc-dev
|
||||||
|
@ -39,9 +36,10 @@ Homepage: https://www.zoneminder.com/
|
||||||
Package: zoneminder
|
Package: zoneminder
|
||||||
Architecture: any
|
Architecture: any
|
||||||
Depends: ${shlibs:Depends}, ${misc:Depends}, ${perl:Depends}
|
Depends: ${shlibs:Depends}, ${misc:Depends}, ${perl:Depends}
|
||||||
|
,sudo
|
||||||
,javascript-common
|
,javascript-common
|
||||||
,libswscale5
|
,libswscale5|libswscale4
|
||||||
,libswresample3
|
,libswresample3|libswresample2
|
||||||
,ffmpeg
|
,ffmpeg
|
||||||
,libdate-manip-perl, libmime-lite-perl, libmime-tools-perl
|
,libdate-manip-perl, libmime-lite-perl, libmime-tools-perl
|
||||||
,libdbd-mysql-perl
|
,libdbd-mysql-perl
|
||||||
|
@ -71,11 +69,10 @@ Depends: ${shlibs:Depends}, ${misc:Depends}, ${perl:Depends}
|
||||||
,policykit-1
|
,policykit-1
|
||||||
,rsyslog | system-log-daemon
|
,rsyslog | system-log-daemon
|
||||||
,zip
|
,zip
|
||||||
,libpcre3
|
|
||||||
,libcrypt-eksblowfish-perl
|
,libcrypt-eksblowfish-perl
|
||||||
,libdata-entropy-perl
|
,libdata-entropy-perl
|
||||||
,libvncclient1|libvncclient0
|
,libvncclient1|libvncclient0
|
||||||
,libjwt-gnutls0
|
,libjwt-gnutls0|libjwt0
|
||||||
Recommends: ${misc:Recommends}
|
Recommends: ${misc:Recommends}
|
||||||
,libapache2-mod-php | php-fpm
|
,libapache2-mod-php | php-fpm
|
||||||
,default-mysql-server | mariadb-server | virtual-mysql-server
|
,default-mysql-server | mariadb-server | virtual-mysql-server
|
||||||
|
|
|
@ -41,7 +41,6 @@ Copyright: 2005-2013 Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||||||
License: Expat
|
License: Expat
|
||||||
|
|
||||||
Files:
|
Files:
|
||||||
cmake/Modules/CheckPrototypeDefinition*.cmake
|
|
||||||
cmake/Modules/FindGLIB2.cmake
|
cmake/Modules/FindGLIB2.cmake
|
||||||
cmake/Modules/FindPolkit.cmake
|
cmake/Modules/FindPolkit.cmake
|
||||||
cmake/Modules/GNUInstallDirs.cmake
|
cmake/Modules/GNUInstallDirs.cmake
|
||||||
|
|
|
@ -19,6 +19,7 @@ override_dh_auto_configure:
|
||||||
-DCMAKE_VERBOSE_MAKEFILE=ON \
|
-DCMAKE_VERBOSE_MAKEFILE=ON \
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
-DBUILD_MAN=0 \
|
-DBUILD_MAN=0 \
|
||||||
|
-DZM_NO_PCRE=ON \
|
||||||
-DZM_CONFIG_DIR="/etc/zm" \
|
-DZM_CONFIG_DIR="/etc/zm" \
|
||||||
-DZM_CONFIG_SUBDIR="/etc/zm/conf.d" \
|
-DZM_CONFIG_SUBDIR="/etc/zm/conf.d" \
|
||||||
-DZM_RUNDIR="/run/zm" \
|
-DZM_RUNDIR="/run/zm" \
|
||||||
|
|
|
@ -5,6 +5,12 @@ set +e
|
||||||
create_db () {
|
create_db () {
|
||||||
echo "Checking for db"
|
echo "Checking for db"
|
||||||
mysqladmin --defaults-file=/etc/mysql/debian.cnf -f reload
|
mysqladmin --defaults-file=/etc/mysql/debian.cnf -f reload
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "Cannot talk to database. You will have to create the db manually with something like:";
|
||||||
|
echo "cat /usr/share/zoneminder/db/zm_create.sql | mysql -u root";
|
||||||
|
return;
|
||||||
|
fi
|
||||||
|
|
||||||
# test if database if already present...
|
# test if database if already present...
|
||||||
if ! $(echo quit | mysql --defaults-file=/etc/mysql/debian.cnf zm > /dev/null 2> /dev/null) ; then
|
if ! $(echo quit | mysql --defaults-file=/etc/mysql/debian.cnf zm > /dev/null 2> /dev/null) ; then
|
||||||
echo "Creating zm db"
|
echo "Creating zm db"
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
d /run/zm 0755 www-data www-data
|
d /run/zm 0755 www-data www-data
|
||||||
d /tmp/zm 0755 www-data www-data
|
d /tmp/zm 0755 www-data www-data
|
||||||
d /var/tmp/zm 0755 www-data www-data
|
d /var/tmp/zm 0755 www-data www-data 7d
|
||||||
d /var/cache/zoneminder/cache 0755 www-data www-data
|
d /var/cache/zoneminder/cache 0755 www-data www-data
|
||||||
|
|
|
@ -225,7 +225,7 @@ change the 3 to a 1
|
||||||
|
|
||||||
I can't see more than 6 monitors in montage on my browser
|
I can't see more than 6 monitors in montage on my browser
|
||||||
---------------------------------------------------------
|
---------------------------------------------------------
|
||||||
Browsers such a Chrome and Safari only support upto 6 streams from the same domain. To work around that, take a look at the multi-port configuration discussed in the ``MIN_STREAMING_PORT`` configuration in :doc:`/userguide/options/options_network`
|
Browsers such a Chrome and Safari only support up to 6 streams from the same domain. To work around that, take a look at the multi-port configuration discussed in the ``MIN_STREAMING_PORT`` configuration in :doc:`/userguide/options/options_network`
|
||||||
|
|
||||||
Why is ZoneMinder using so much CPU?
|
Why is ZoneMinder using so much CPU?
|
||||||
---------------------------------------
|
---------------------------------------
|
||||||
|
|
|
@ -3,6 +3,50 @@ Debian
|
||||||
|
|
||||||
.. contents::
|
.. contents::
|
||||||
|
|
||||||
|
Easy Way: Debian 11 (Bullseye)
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
This procedure will guide you through the installation of ZoneMinder on Debian 11 (Bullseye).
|
||||||
|
|
||||||
|
**Step 1:** Setup Sudo (optional but recommended)
|
||||||
|
|
||||||
|
By default Debian does not come with sudo, so you have to install it and configure it manually.
|
||||||
|
This step is optional but recommended and the following instructions assume that you have setup sudo.
|
||||||
|
If you prefer to setup ZoneMinder as root, do it at your own risk and adapt the following instructions accordingly.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
apt install sudo
|
||||||
|
usermod -a -G sudo <username>
|
||||||
|
exit
|
||||||
|
|
||||||
|
Now your terminal session is back under your normal user. You can check that
|
||||||
|
you are now part of the sudo group with the command ``groups``, "sudo" should
|
||||||
|
appear in the list. If not, run ``newgrp sudo`` and check again with ``groups``.
|
||||||
|
|
||||||
|
**Step 2:** Update system and install zoneminder
|
||||||
|
|
||||||
|
Run the following commands.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
sudo apt update
|
||||||
|
sudo apt upgrade
|
||||||
|
sudo apt install mariadb-server
|
||||||
|
sudo apt install zoneminder
|
||||||
|
|
||||||
|
When mariadb is installed for the first time, it doesn't add a password to the root user. Therefore, for security, it is recommended to run ``mysql secure installation``.
|
||||||
|
|
||||||
|
**Step 3:** Setup permissions for zm.conf
|
||||||
|
|
||||||
|
To make sure zoneminder can read the configuration file, run the following command.
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
sudo chgrp -c www-data /etc/zm/zm.conf
|
||||||
|
|
||||||
|
Congratulations! You should now be able to access zoneminder at ``http://yourhostname/zm``
|
||||||
|
|
||||||
Easy Way: Debian Buster
|
Easy Way: Debian Buster
|
||||||
------------------------
|
------------------------
|
||||||
|
|
||||||
|
@ -56,13 +100,13 @@ Add the following to the /etc/apt/sources.list.d/zoneminder.list file
|
||||||
::
|
::
|
||||||
|
|
||||||
# ZoneMinder repository
|
# ZoneMinder repository
|
||||||
deb https://zmrepo.zoneminder.com/debian/release-1.34 buster/
|
deb https://zmrepo.zoneminder.com/debian/release-1.36 buster/
|
||||||
|
|
||||||
You can do this using:
|
You can do this using:
|
||||||
|
|
||||||
.. code-block::
|
.. code-block::
|
||||||
|
|
||||||
echo "deb https://zmrepo.zoneminder.com/debian/release-1.34 buster/" | sudo tee /etc/apt/sources.list.d/zoneminder.list
|
echo "deb https://zmrepo.zoneminder.com/debian/release-1.36 buster/" | sudo tee /etc/apt/sources.list.d/zoneminder.list
|
||||||
|
|
||||||
Because ZoneMinder's package repository provides a secure connection through HTTPS, apt must be enabled for HTTPS.
|
Because ZoneMinder's package repository provides a secure connection through HTTPS, apt must be enabled for HTTPS.
|
||||||
::
|
::
|
||||||
|
@ -158,7 +202,7 @@ You are now ready to go with ZoneMinder. Open a browser and type either ``localh
|
||||||
Easy Way: Debian Stretch
|
Easy Way: Debian Stretch
|
||||||
------------------------
|
------------------------
|
||||||
|
|
||||||
This procedure will guide you through the installation of ZoneMinder on Debian 9 (Stretch). This section has been tested with ZoneMinder 1.34 on Debian 9.8.
|
This procedure will guide you through the installation of ZoneMinder on Debian 9 (Stretch). This section has been tested with ZoneMinder 1.36 on Debian 9.8.
|
||||||
|
|
||||||
**Step 1:** Make sure your system is up to date
|
**Step 1:** Make sure your system is up to date
|
||||||
|
|
||||||
|
@ -204,7 +248,7 @@ Add the following to the bottom of the file
|
||||||
::
|
::
|
||||||
|
|
||||||
# ZoneMinder repository
|
# ZoneMinder repository
|
||||||
deb https://zmrepo.zoneminder.com/debian/release-1.34 stretch/
|
deb https://zmrepo.zoneminder.com/debian/release-1.36 stretch/
|
||||||
|
|
||||||
CTRL+o and <Enter> to save
|
CTRL+o and <Enter> to save
|
||||||
CTRL+x to exit
|
CTRL+x to exit
|
||||||
|
@ -293,175 +337,3 @@ Reload Apache to enable your changes and then start ZoneMinder.
|
||||||
sudo systemctl start zoneminder
|
sudo systemctl start zoneminder
|
||||||
|
|
||||||
You are now ready to go with ZoneMinder. Open a browser and type either ``localhost/zm`` one the local machine or ``{IP-OF-ZM-SERVER}/zm`` if you connect from a remote computer.
|
You are now ready to go with ZoneMinder. Open a browser and type either ``localhost/zm`` one the local machine or ``{IP-OF-ZM-SERVER}/zm`` if you connect from a remote computer.
|
||||||
|
|
||||||
|
|
||||||
Easy Way: Debian Jessie
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
**Step 1:** Setup Sudo
|
|
||||||
|
|
||||||
By default Debian does not come with sudo. Log in as root or use su command.
|
|
||||||
N.B. The instructions below are for setting up sudo for your current account, you can
|
|
||||||
do this as root if you prefer.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
apt-get update
|
|
||||||
apt-get install sudo
|
|
||||||
usermod -a -G sudo <username>
|
|
||||||
exit
|
|
||||||
|
|
||||||
Logout or try ``newgrp`` to reload user groups
|
|
||||||
|
|
||||||
**Step 2:** Run sudo and update
|
|
||||||
|
|
||||||
Now run session using sudo and ensure system is updated.
|
|
||||||
::
|
|
||||||
|
|
||||||
sudo -i
|
|
||||||
apt-get upgrade
|
|
||||||
|
|
||||||
**Step 3:** Install Apache and MySQL
|
|
||||||
|
|
||||||
These are not dependencies for the package as they could
|
|
||||||
be installed elsewhere.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
apt-get install apache2 mysql-server
|
|
||||||
|
|
||||||
**Step 4:** Edit sources.list to add jessie-backports
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
nano /etc/apt/sources.list
|
|
||||||
|
|
||||||
Add the following to the bottom of the file
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
# Backports repository
|
|
||||||
deb http://archive.debian.org/debian/ jessie-backports main contrib non-free
|
|
||||||
|
|
||||||
CTRL+o and <Enter> to save
|
|
||||||
CTRL+x to exit
|
|
||||||
|
|
||||||
Run the following
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
echo 'Acquire::Check-Valid-Until no;' > /etc/apt/apt.conf.d/99no-check-valid-until
|
|
||||||
|
|
||||||
**Step 5:** Install ZoneMinder
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
apt-get update
|
|
||||||
apt-get install zoneminder
|
|
||||||
|
|
||||||
**Step 6:** Read the Readme
|
|
||||||
|
|
||||||
The rest of the install process is covered in the README.Debian, so feel free to have
|
|
||||||
a read.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
zcat /usr/share/doc/zoneminder/README.Debian.gz
|
|
||||||
|
|
||||||
**Step 7:** Setup Database
|
|
||||||
|
|
||||||
Install the zm database and setup the user account. Refer to Hints in Ubuntu install
|
|
||||||
should you choose to change default database user and password.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
cat /usr/share/zoneminder/db/zm_create.sql | sudo mysql --defaults-file=/etc/mysql/debian.cnf
|
|
||||||
echo 'grant lock tables,alter,create,select,insert,update,delete,index on zm.* to 'zmuser'@localhost identified by "zmpass";' | sudo mysql --defaults-file=/etc/mysql/debian.cnf mysql
|
|
||||||
|
|
||||||
**Step 8:** zm.conf Permissions
|
|
||||||
|
|
||||||
Adjust permissions to the zm.conf file to allow web account to access it.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
chgrp -c www-data /etc/zm/zm.conf
|
|
||||||
|
|
||||||
**Step 9:** Setup ZoneMinder service
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
systemctl enable zoneminder.service
|
|
||||||
|
|
||||||
**Step 10:** Configure Apache
|
|
||||||
|
|
||||||
The following commands will setup the default /zm virtual directory and configure
|
|
||||||
required apache modules.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
a2enconf zoneminder
|
|
||||||
a2enmod cgi
|
|
||||||
a2enmod rewrite
|
|
||||||
|
|
||||||
**Step 11:** Edit Timezone in PHP
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
nano /etc/php5/apache2/php.ini
|
|
||||||
|
|
||||||
Search for [Date] (Ctrl + w then type Date and press Enter) and change
|
|
||||||
date.timezone for your time zone. **Don't forget to remove the ; from in front
|
|
||||||
of date.timezone**
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
[Date]
|
|
||||||
; Defines the default timezone used by the date functions
|
|
||||||
; http://php.net/date.timezone
|
|
||||||
date.timezone = America/New_York
|
|
||||||
|
|
||||||
CTRL+o then [Enter] to save
|
|
||||||
|
|
||||||
CTRL+x to exit
|
|
||||||
|
|
||||||
|
|
||||||
**Step 12:** Please check the configuration
|
|
||||||
|
|
||||||
1. Check path of ZM_PATH in '/etc/zm/conf.d/zmcustom.conf' is ZM_PATH_ZMS=/zm/cgi-bin/nph-zms
|
|
||||||
::
|
|
||||||
cat /etc/zm/conf.d/zmcustom.conf
|
|
||||||
|
|
||||||
2. Check config of /etc/apache2/conf-enabled/zoneminder.conf has the same ScriptAlias /zm/cgi-bin that is configured
|
|
||||||
in ZM_PATH. The part /nph-zms has to be left out of the ScriptAlias
|
|
||||||
|
|
||||||
ScriptAlias /zm/cgi-bin "/usr/lib/zoneminder/cgi-bin"
|
|
||||||
<Directory "/usr/lib/zoneminder/cgi-bin">
|
|
||||||
|
|
||||||
::
|
|
||||||
cat /etc/apache2/conf-enabled/zoneminder.conf
|
|
||||||
|
|
||||||
**Step 13:** Start ZoneMinder
|
|
||||||
|
|
||||||
Reload Apache to enable your changes and then start ZoneMinder.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
systemctl reload apache2
|
|
||||||
systemctl start zoneminder
|
|
||||||
|
|
||||||
**Step 14:** Making sure ZoneMinder works
|
|
||||||
|
|
||||||
1. Open up a browser and go to ``http://hostname_or_ip/zm`` - should bring up ZoneMinder Console
|
|
||||||
|
|
||||||
2. (Optional API Check)Open up a tab in the same browser and go to ``http://hostname_or_ip/zm/api/host/getVersion.json``
|
|
||||||
|
|
||||||
If it is working correctly you should get version information similar to the example below:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
{
|
|
||||||
"version": "1.34.0",
|
|
||||||
"apiversion": "1.34.0.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
**Congratulations** Your installation is complete
|
|
||||||
|
|
|
@ -2,7 +2,7 @@ An Easy To Use Docker Image
|
||||||
===========================
|
===========================
|
||||||
If you are interested in trying out ZoneMinder quickly, user Dan Landon maintains an easy to use docker image for ZoneMinder. With a few simple configuration changes, it also provides complete Event Notification Server and Machine Learning hook support. Please follow instructions in his repostory. He maintains two repositories:
|
If you are interested in trying out ZoneMinder quickly, user Dan Landon maintains an easy to use docker image for ZoneMinder. With a few simple configuration changes, it also provides complete Event Notification Server and Machine Learning hook support. Please follow instructions in his repostory. He maintains two repositories:
|
||||||
|
|
||||||
* If you want to run the latest stable release, please use his `zoneminder repository <https://github.com/dlandon/zoneminder>`__.
|
* If you want to run the latest stable release, please use his `zoneminder machine learning repository <https://github.com/dlandon/zoneminder.machine.learning>`__.
|
||||||
* If you want to run the latest zoneminder master, please use his `zoneminder master repository <https://github.com/dlandon/zoneminder.master-docker>`__.
|
* If you want to run the latest zoneminder master, please use his `zoneminder master repository <https://github.com/dlandon/zoneminder.master-docker>`__.
|
||||||
|
|
||||||
In both cases, instructions are provided in the repo README files.
|
In both cases, instructions are provided in the repo README files.
|
||||||
|
|
|
@ -77,7 +77,7 @@ To start the build, simply execute the following command from the root folder of
|
||||||
|
|
||||||
OS=<distroname> DIST=<distrorel> utils/packpack/startpackpack.sh
|
OS=<distroname> DIST=<distrorel> utils/packpack/startpackpack.sh
|
||||||
|
|
||||||
Where <distroname> is the name of the distro you wish to build on, such as fedora, and <distrorev> is release name or number of the distro you wish to build on. Redhat distros expect a number for <distrorev> while Debian and Ubuntu distros expect a name. For example:
|
Where <distroname> is the name of the distro you wish to build on, such as fedora, and <distrorel> is the release name or number of the distro you wish to build on. Redhat distros expect a number for <distrorel> while Debian and Ubuntu distros expect a name. For example:
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ Where <distroname> is the name of the distro you wish to build on, such as fedor
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
OS=ubuntu DIST=xenial utils/packpack/startpackpack.sh
|
OS=ubuntu DIST=hirsute utils/packpack/startpackpack.sh
|
||||||
|
|
||||||
Once you enter the appropriate command, go get a coffee while a ZoneMinder package is built. When the build finished, you can find the resulting packages under a subfolder called "build".
|
Once you enter the appropriate command, go get a coffee while a ZoneMinder package is built. When the build finished, you can find the resulting packages under a subfolder called "build".
|
||||||
|
|
||||||
|
@ -93,13 +93,13 @@ Note that this will build packages with x86_64 architecture. This build method c
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
OS=ubuntu DIST=xenial ARCH=i386 utils/packpack/startpackpack.sh
|
OS=ubuntu DIST=hirsute ARCH=i386 utils/packpack/startpackpack.sh
|
||||||
|
|
||||||
For advanced users who really want to go out into uncharted waters, it is theoretically possible to build arm packages as well, as long as the host architecture is compatible.
|
For advanced users who really want to go out into uncharted waters, it is theoretically possible to build arm packages as well, as long as the host architecture is compatible.
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
OS=ubuntu DIST=xenial ARCH=armhfp utils/packpack/startpackpack.sh
|
OS=ubuntu DIST=hirsute ARCH=armhfp utils/packpack/startpackpack.sh
|
||||||
|
|
||||||
Building arm packages in this manner has not been tested by us, however.
|
Building arm packages in this manner has not been tested by us, however.
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ guide you with a quick search.
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
add-apt-repository ppa:iconnor/zoneminder-1.34
|
add-apt-repository ppa:iconnor/zoneminder-1.36
|
||||||
|
|
||||||
Update repo and upgrade.
|
Update repo and upgrade.
|
||||||
|
|
||||||
|
@ -176,175 +176,6 @@ CTRL+x to exit
|
||||||
|
|
||||||
PPA install may need some tweaking of ZMS_PATH in ZoneMinder options. `Socket_sendto or no live streaming`_
|
PPA install may need some tweaking of ZMS_PATH in ZoneMinder options. `Socket_sendto or no live streaming`_
|
||||||
|
|
||||||
Easy Way: Ubuntu 16.04 (Xenial)
|
|
||||||
-------------------------------
|
|
||||||
These instructions are for a brand new ubuntu 16.04 system which does not have ZM
|
|
||||||
installed.
|
|
||||||
|
|
||||||
|
|
||||||
It is recommended that you use an Ubuntu Server install and select the LAMP option
|
|
||||||
during install to install Apache, MySQL and PHP. If you failed to do this you can
|
|
||||||
achieve the same result by running:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
sudo tasksel install lamp-server
|
|
||||||
|
|
||||||
During installation it will ask you to set up a master/root password for the MySQL.
|
|
||||||
Installing LAMP is not ZoneMinder specific so you will find plenty of resources to
|
|
||||||
guide you with a quick search.
|
|
||||||
|
|
||||||
**Step 1:** Either run commands in this install using sudo or use the below to become root
|
|
||||||
::
|
|
||||||
|
|
||||||
sudo -i
|
|
||||||
|
|
||||||
**Step 2:** Update Repos
|
|
||||||
|
|
||||||
.. topic :: Latest Release
|
|
||||||
|
|
||||||
ZoneMinder is now part of the current standard Ubuntu repository, but
|
|
||||||
sometimes the official repository can lag behind. To find out check our
|
|
||||||
`releases page <https://github.com/ZoneMinder/zoneminder/releases>`_ for
|
|
||||||
the latest release.
|
|
||||||
|
|
||||||
Alternatively, the ZoneMinder project team maintains a `PPA <https://askubuntu.com/questions/4983/what-are-ppas-and-how-do-i-use-them>`_, which is updated immediately
|
|
||||||
following a new release of ZoneMinder. To use this repository instead of the
|
|
||||||
official Ubuntu repository, enter the following from the command line:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
add-apt-repository ppa:iconnor/zoneminder
|
|
||||||
add-apt-repository ppa:iconnor/zoneminder-1.32
|
|
||||||
|
|
||||||
Update repo and upgrade.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
apt-get update
|
|
||||||
apt-get upgrade
|
|
||||||
apt-get dist-upgrade
|
|
||||||
|
|
||||||
|
|
||||||
**Step 3:** Configure MySQL
|
|
||||||
|
|
||||||
.. sidebar :: Note
|
|
||||||
|
|
||||||
The MySQL default configuration file (/etc/mysql/mysql.cnf)is read through
|
|
||||||
several symbolic links beginning with /etc/mysql/my.cnf as follows:
|
|
||||||
|
|
||||||
| /etc/mysql/my.cnf -> /etc/alternatives/my.cnf
|
|
||||||
| /etc/alternatives/my.cnf -> /etc/mysql/mysql.cnf
|
|
||||||
| /etc/mysql/mysql.cnf is a basic file
|
|
||||||
|
|
||||||
Certain new defaults in MySQL 5.7 cause some issues with ZoneMinder < 1.32.0,
|
|
||||||
the workaround is to modify the sql_mode setting of MySQL. Please note that these
|
|
||||||
changes are NOT required for ZoneMinder 1.32.0 and some people have reported them
|
|
||||||
causing problems in 1.32.0.
|
|
||||||
|
|
||||||
To better manage the MySQL server it is recommended to copy the sample config file and
|
|
||||||
replace the default my.cnf symbolic link.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
rm /etc/mysql/my.cnf (this removes the current symbolic link)
|
|
||||||
cp /etc/mysql/mysql.conf.d/mysqld.cnf /etc/mysql/my.cnf
|
|
||||||
|
|
||||||
To change MySQL settings:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
nano /etc/mysql/my.cnf
|
|
||||||
|
|
||||||
In the [mysqld] section add the following
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
sql_mode = NO_ENGINE_SUBSTITUTION
|
|
||||||
|
|
||||||
CTRL+o then [Enter] to save
|
|
||||||
|
|
||||||
CTRL+x to exit
|
|
||||||
|
|
||||||
Restart MySQL
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
systemctl restart mysql
|
|
||||||
|
|
||||||
|
|
||||||
**Step 4:** Install ZoneMinder
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
apt-get install zoneminder
|
|
||||||
|
|
||||||
**Step 5:** Configure the ZoneMinder Database
|
|
||||||
|
|
||||||
This step should not be required on ZoneMinder 1.32.0.
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
mysql -uroot -p < /usr/share/zoneminder/db/zm_create.sql
|
|
||||||
mysql -uroot -p -e "grant lock tables,alter,drop,select,insert,update,delete,create,index,alter routine,create routine, trigger,execute on zm.* to 'zmuser'@localhost identified by 'zmpass';"
|
|
||||||
|
|
||||||
|
|
||||||
**Step 6:** Set permissions
|
|
||||||
|
|
||||||
Set /etc/zm/zm.conf to root:www-data 740 and www-data access to content
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
chmod 740 /etc/zm/zm.conf
|
|
||||||
chown root:www-data /etc/zm/zm.conf
|
|
||||||
chown -R www-data:www-data /usr/share/zoneminder/
|
|
||||||
|
|
||||||
**Step 7:** Configure Apache correctly:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
a2enmod cgi
|
|
||||||
a2enmod rewrite
|
|
||||||
a2enconf zoneminder
|
|
||||||
|
|
||||||
You may also want to enable to following modules to improve caching performance
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
a2enmod expires
|
|
||||||
a2enmod headers
|
|
||||||
|
|
||||||
**Step 8:** Enable and start Zoneminder
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
systemctl enable zoneminder
|
|
||||||
systemctl start zoneminder
|
|
||||||
|
|
||||||
**Step 10:** Reload Apache service
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
systemctl reload apache2
|
|
||||||
|
|
||||||
**Step 11:** Making sure ZoneMinder works
|
|
||||||
|
|
||||||
1. Open up a browser and go to ``http://hostname_or_ip/zm`` - should bring up ZoneMinder Console
|
|
||||||
|
|
||||||
2. (Optional API Check)Open up a tab in the same browser and go to ``http://hostname_or_ip/zm/api/host/getVersion.json``
|
|
||||||
|
|
||||||
If it is working correctly you should get version information similar to the example below:
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
{
|
|
||||||
"version": "1.34.0",
|
|
||||||
"apiversion": "1.34.0.1"
|
|
||||||
}
|
|
||||||
|
|
||||||
**Congratulations** Your installation is complete
|
|
||||||
|
|
||||||
PPA install may need some tweaking of ZMS_PATH in ZoneMinder options. `Socket_sendto or no live streaming`_
|
|
||||||
|
|
||||||
Harder Way: Build Package From Source
|
Harder Way: Build Package From Source
|
||||||
-------------------------------------
|
-------------------------------------
|
||||||
|
@ -382,7 +213,7 @@ To build the latest stable release:
|
||||||
|
|
||||||
|
|
||||||
Note that the distribution will be guessed using ``lsb_release -a 2>/dev/null | grep Codename | awk '{print $2}'``
|
Note that the distribution will be guessed using ``lsb_release -a 2>/dev/null | grep Codename | awk '{print $2}'``
|
||||||
which simply extracts your distribution name - like "xenial", "bionic" etc. You
|
which simply extracts your distribution name - like "bionic", "hirsute" etc. You
|
||||||
can always specify it using --distro=your distro name if you know it. As far as the script
|
can always specify it using --distro=your distro name if you know it. As far as the script
|
||||||
goes, it checks if your distro is "trusty" in which case it pulls in pre-systemd
|
goes, it checks if your distro is "trusty" in which case it pulls in pre-systemd
|
||||||
release configurations and if its not "trusty" it assumes its based on systemd
|
release configurations and if its not "trusty" it assumes its based on systemd
|
||||||
|
|
|
@ -86,7 +86,7 @@ Source Path
|
||||||
Use this field to enter the full URL of the stream or file your camera supports. This is usually an RTSP url. There are several methods to learn this:
|
Use this field to enter the full URL of the stream or file your camera supports. This is usually an RTSP url. There are several methods to learn this:
|
||||||
|
|
||||||
* Check the documentation that came with your camera
|
* Check the documentation that came with your camera
|
||||||
* Look for your camera in the hardware compatibilty list in the `hardware compatibility wiki <https://wiki.zoneminder.com/Hardware_Compatibility_List>`__
|
* Look for your camera in the hardware compatibility list in the `hardware compatibility wiki <https://wiki.zoneminder.com/Hardware_Compatibility_List>`__
|
||||||
* Try ZoneMinder's new ONVIF probe feature
|
* Try ZoneMinder's new ONVIF probe feature
|
||||||
* Download and install the `ONVIF Device Manager <https://sourceforge.net/projects/onvifdm/>`__ onto a Windows machine
|
* Download and install the `ONVIF Device Manager <https://sourceforge.net/projects/onvifdm/>`__ onto a Windows machine
|
||||||
* Use Google to find third party sites, such as ispy, which document this information
|
* Use Google to find third party sites, such as ispy, which document this information
|
||||||
|
@ -179,12 +179,12 @@ Storage Tab
|
||||||
The storage section allows for each monitor to configure if and how video and audio are recorded.
|
The storage section allows for each monitor to configure if and how video and audio are recorded.
|
||||||
|
|
||||||
Save JPEGs
|
Save JPEGs
|
||||||
Records video in individual JPEG frames. Storing JPEG frames requires more storage space than h264 but it allows to view an event anytime while it is being recorded.
|
Records video in individual JPEG frames. Storing JPEG frames requires more storage space than h264 but it allows one to view an event anytime while it is being recorded.
|
||||||
|
|
||||||
* Disabled – video is not recorded as JPEG frames. If this setting is selected, then "Video Writer" should be enabled otherwise there is no video recording at all.
|
* Disabled – video is not recorded as JPEG frames. If this setting is selected, then "Video Writer" should be enabled otherwise there is no video recording at all.
|
||||||
* Frames only – video is recorded in individual JPEG frames.
|
* Frames only – video is recorded in individual JPEG frames.
|
||||||
* Analysis images only (if available) – video is recorded in invidual JPEG frames with an overlay of the motion detection analysis information. Note that this overlay remains permanently visible in the frames.
|
* Analysis images only (if available) – video is recorded in individual JPEG frames with an overlay of the motion detection analysis information. Note that this overlay remains permanently visible in the frames.
|
||||||
* Frames + Analysis images (if available) – video is recorded twice, once as normal individual JPEG frames and once in invidual JPEG frames with analysis information overlaid.
|
* Frames + Analysis images (if available) – video is recorded twice, once as normal individual JPEG frames and once in individual JPEG frames with analysis information overlaid.
|
||||||
|
|
||||||
Video Writer
|
Video Writer
|
||||||
Records video in real video format. It provides much better compression results than saving JPEGs, thus longer video history can be stored.
|
Records video in real video format. It provides much better compression results than saving JPEGs, thus longer video history can be stored.
|
||||||
|
|
|
@ -34,7 +34,7 @@ Here is what the filter window looks like
|
||||||
* Update used disk space: calculates how much disk space is currently taken by the event and updates the db record.
|
* Update used disk space: calculates how much disk space is currently taken by the event and updates the db record.
|
||||||
* Create video for all matches: creates a video file of all the events that match
|
* Create video for all matches: creates a video file of all the events that match
|
||||||
* Create video for all matches: ffmpeg will be used to create a video file (mp4) out of all the stored jpgs if using jpeg storage.
|
* Create video for all matches: ffmpeg will be used to create a video file (mp4) out of all the stored jpgs if using jpeg storage.
|
||||||
* Execute command on all matches: Allows you to execute any arbitrary command on the matched events. You can use replacement tokens as subsequent arguents to the command, the last argument will be the absolute path to the event, preceeded by replacement arguents. eg: /usr/bin/script.sh %MN% will excecute as /usr/bin/script.sh MonitorName /path/to/event. Please note that urls may contain characters like & that need quoting. So you may need to put quotes around them like /usr/bin/scrupt.sh "%MN%".
|
* Execute command on all matches: Allows you to execute any arbitrary command on the matched events. You can use replacement tokens as subsequent arguents to the command, the last argument will be the absolute path to the event, preceded by replacement arguents. eg: /usr/bin/script.sh %MN% will execute as /usr/bin/script.sh MonitorName /path/to/event. Please note that urls may contain characters like & that need quoting. So you may need to put quotes around them like /usr/bin/scrupt.sh "%MN%".
|
||||||
* Delete all matches: Deletes all the matched events.
|
* Delete all matches: Deletes all the matched events.
|
||||||
* Email details of all matches: Sends an email to the configured address with details about the event.
|
* Email details of all matches: Sends an email to the configured address with details about the event.
|
||||||
* Copy all matches: copies the event files to another location, specified in the Copy To dropdown. The other location must be setup in the Storage Tab under options.
|
* Copy all matches: copies the event files to another location, specified in the Copy To dropdown. The other location must be setup in the Storage Tab under options.
|
||||||
|
|
|
@ -53,7 +53,7 @@ This screen is called the "console" screen in ZoneMinder and shows a summary of
|
||||||
* **B**: This brings up a color coded log window that shows various system and component level logs. This window is useful if you are trying to diagnose issues. Refer to :doc:`logging`.
|
* **B**: This brings up a color coded log window that shows various system and component level logs. This window is useful if you are trying to diagnose issues. Refer to :doc:`logging`.
|
||||||
* **C**: ZoneMinder allows you to group monitors for logical separation. This option lets you create new groups, associate monitors to them and edit/delete existing groups.
|
* **C**: ZoneMinder allows you to group monitors for logical separation. This option lets you create new groups, associate monitors to them and edit/delete existing groups.
|
||||||
* **D**: Filters are a powerful mechanism to perform actions when certain conditions are met. ZoneMinder comes with some preset filters that keep a tab of disk space and others. Many users create their own filters for more advanced actions like sending emails when certain events occur and more. Refer to :doc:`filterevents`.
|
* **D**: Filters are a powerful mechanism to perform actions when certain conditions are met. ZoneMinder comes with some preset filters that keep a tab of disk space and others. Many users create their own filters for more advanced actions like sending emails when certain events occur and more. Refer to :doc:`filterevents`.
|
||||||
* **E**: The Cycle option allows you to rotate between live views of each cofigured monitor.
|
* **E**: The Cycle option allows you to rotate between live views of each configured monitor.
|
||||||
* **F**: The Montage option shows a collage of your monitors. You can customize them including moving them around.
|
* **F**: The Montage option shows a collage of your monitors. You can customize them including moving them around.
|
||||||
* **G**: Montage Review allows you to simultaneously view past events for different monitors. Note that this is a very resource intensive page and its performance will vary based on your system capabilities.
|
* **G**: Montage Review allows you to simultaneously view past events for different monitors. Note that this is a very resource intensive page and its performance will vary based on your system capabilities.
|
||||||
* **H**: Audit Events Report is more of a power user feature. This option looks for recording gaps in events and recording issues in mp4 files.
|
* **H**: Audit Events Report is more of a power user feature. This option looks for recording gaps in events and recording issues in mp4 files.
|
||||||
|
|
|
@ -6,7 +6,7 @@ Here are some options for using ZoneMinder on Mobile devices:
|
||||||
Third party mobile clients
|
Third party mobile clients
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
* zmNinja (`source code <https://github.com/pliablepixels/zmNinja>`__, needs APIs to be installed to work)
|
* zmNinja (`source code <https://github.com/pliablepixels/zmNinja>`__, needs APIs to be installed to work)
|
||||||
* Available in App Store, Play Store and for Desktops - `website <http://pliablepixels.github.io/zmNinja/>`__
|
* Available in App Store, Play Store and for Desktops - `website <http://pliablepixels.github.io/>`__
|
||||||
|
|
||||||
Using the existing web console
|
Using the existing web console
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
|
@ -101,6 +101,6 @@ FROM_EMAIL - The emails or messages that will be sent to you informing you of ev
|
||||||
|
|
||||||
URL - The emails or messages that will be sent to you informing you of events can include a link to the events themselves for easy viewing. If you intend to use this feature then set this option to the url of your installation as it would appear from where you read your email, e.g. ``http://host.your.domain/zm/index.php``.
|
URL - The emails or messages that will be sent to you informing you of events can include a link to the events themselves for easy viewing. If you intend to use this feature then set this option to the url of your installation as it would appear from where you read your email, e.g. ``http://host.your.domain/zm/index.php``.
|
||||||
|
|
||||||
SSMTP_MAIL - SSMTP is a lightweight and efficient method to send email. The SSMTP application is not installed by default. NEW_MAIL_MODULES must also be enabled. Please visit the ZoneMinder `SSMTP Wiki page <http://www.zoneminder.com/wiki/index.php/How_to_get_ssmtp_working_with_Zoneminder>`__ for setup and configuration help.
|
SSMTP_MAIL - SSMTP is a lightweight and efficient method to send email. The SSMTP application is not installed by default. NEW_MAIL_MODULES must also be enabled. Please visit the ZoneMinder `SSMTP Wiki page <https://wiki.zoneminder.com/How_to_get_ssmtp_working_with_Zoneminder>`__ for setup and configuration help.
|
||||||
|
|
||||||
SSMTP_PATH - The path to the SSMTP application. If path is not defined. Zoneminder will try to determine the path via shell command. Example path: /usr/sbin/ssmtp.
|
SSMTP_PATH - The path to the SSMTP application. If path is not defined. Zoneminder will try to determine the path via shell command. Example path: /usr/sbin/ssmtp.
|
|
@ -30,7 +30,7 @@ This screen allows you to configure various permissions on a per user basis. The
|
||||||
.. note:: if you are using zmNinja, users are required to have 'View' access to system because multi-server information is only available as part of this permission
|
.. note:: if you are using zmNinja, users are required to have 'View' access to system because multi-server information is only available as part of this permission
|
||||||
|
|
||||||
- Bandwidth
|
- Bandwidth
|
||||||
- Specifies the maximum bandwith that this user can configure (Low, Medium or High)
|
- Specifies the maximum bandwidth that this user can configure (Low, Medium or High)
|
||||||
|
|
||||||
- API enabled
|
- API enabled
|
||||||
- Specifies if the ZoneMinder API is enabled for this user (needs to be on, if you are using a mobile app such as zmNinja)
|
- Specifies if the ZoneMinder API is enabled for this user (needs to be on, if you are using a mobile app such as zmNinja)
|
||||||
|
|
|
@ -5,10 +5,7 @@ This screen lets you customize several aspects of the web interface of ZoneMinde
|
||||||
.. image:: images/Options_web.png
|
.. image:: images/Options_web.png
|
||||||
|
|
||||||
|
|
||||||
WEB_TITLE -
|
WEB_TITLE - The actual text that is shown on the login screen. It is possible that it also appears in other areas.
|
||||||
|
|
||||||
.. todo ::
|
|
||||||
not quite sure what this does. Seems to change the "target" name - not sure what effect it is supposed to have.
|
|
||||||
|
|
||||||
WEB_TITLE_PREFIX - If you have more than one installation of ZoneMinder it can be helpful to display different titles for each one. Changing this option allows you to customise the window titles to include further information to aid identification.
|
WEB_TITLE_PREFIX - If you have more than one installation of ZoneMinder it can be helpful to display different titles for each one. Changing this option allows you to customise the window titles to include further information to aid identification.
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
failregex = ^\s*web_php\[\d+\]\.ERR \[<HOST>\].*includes/auth.php
|
||||||
|
datepattern = ^%%m/%%d/%%y %%H:%%M:%%S(?:\.%%f)
|
|
@ -147,7 +147,7 @@ This attribute is of type L<SOAP::WSDL::XSD::Typelib::Builtin::integer|SOAP::WSD
|
||||||
|
|
||||||
=item * Cells
|
=item * Cells
|
||||||
|
|
||||||
A “1” denotes a cell where motion is detected and a “0” an empty cell. The first cell is in the upper left corner. Then the cell order goes first from left to right and then from up to down. If the number of cells is not a multiple of 8 the last byte is filled with zeros. The information is run length encoded according to Packbit coding in ISO 12369 (TIFF, Revision 6.0).
|
A "1" denotes a cell where motion is detected and a "0" an empty cell. The first cell is in the upper left corner. Then the cell order goes first from left to right and then from up to down. If the number of cells is not a multiple of 8 the last byte is filled with zeros. The information is run length encoded according to Packbit coding in ISO 12369 (TIFF, Revision 6.0).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2709,7 +2709,7 @@ Returns a L<ONVIF::Device::Elements::GetNetworkInterfacesResponse|ONVIF::Device:
|
||||||
|
|
||||||
=head3 SetNetworkInterfaces
|
=head3 SetNetworkInterfaces
|
||||||
|
|
||||||
For interoperability with a client unaware of the IEEE 802.11 extension a device shall retain its IEEE 802.11 configuration if the IEEE 802.11 configuration element isn’t present in the request.
|
For interoperability with a client unaware of the IEEE 802.11 extension a device shall retain its IEEE 802.11 configuration if the IEEE 802.11 configuration element isn't present in the request.
|
||||||
|
|
||||||
Returns a L<ONVIF::Device::Elements::SetNetworkInterfacesResponse|ONVIF::Device::Elements::SetNetworkInterfacesResponse> object.
|
Returns a L<ONVIF::Device::Elements::SetNetworkInterfacesResponse|ONVIF::Device::Elements::SetNetworkInterfacesResponse> object.
|
||||||
|
|
||||||
|
@ -3093,7 +3093,7 @@ Returns a L<ONVIF::Device::Elements::SetRelayOutputStateResponse|ONVIF::Device::
|
||||||
|
|
||||||
=head3 SendAuxiliaryCommand
|
=head3 SendAuxiliaryCommand
|
||||||
|
|
||||||
tt:IRLamp|Auto – Request to configure an IR illuminator attached to the unit so that it automatically turns ON and OFF. A device that indicates auxiliary service capability shall support this command.
|
tt:IRLamp|Auto - Request to configure an IR illuminator attached to the unit so that it automatically turns ON and OFF. A device that indicates auxiliary service capability shall support this command.
|
||||||
|
|
||||||
Returns a L<ONVIF::Device::Elements::SendAuxiliaryCommandResponse|ONVIF::Device::Elements::SendAuxiliaryCommandResponse> object.
|
Returns a L<ONVIF::Device::Elements::SendAuxiliaryCommandResponse|ONVIF::Device::Elements::SendAuxiliaryCommandResponse> object.
|
||||||
|
|
||||||
|
@ -3288,7 +3288,7 @@ Returns a L<ONVIF::Device::Elements::GetSystemUrisResponse|ONVIF::Device::Elemen
|
||||||
|
|
||||||
=head3 StartFirmwareUpgrade
|
=head3 StartFirmwareUpgrade
|
||||||
|
|
||||||
The value of the Content-Type header in the HTTP POST request shall be “application/octetstream”.
|
The value of the Content-Type header in the HTTP POST request shall be "application/octetstream".
|
||||||
|
|
||||||
Returns a L<ONVIF::Device::Elements::StartFirmwareUpgradeResponse|ONVIF::Device::Elements::StartFirmwareUpgradeResponse> object.
|
Returns a L<ONVIF::Device::Elements::StartFirmwareUpgradeResponse|ONVIF::Device::Elements::StartFirmwareUpgradeResponse> object.
|
||||||
|
|
||||||
|
@ -3298,7 +3298,7 @@ Returns a L<ONVIF::Device::Elements::StartFirmwareUpgradeResponse|ONVIF::Device:
|
||||||
|
|
||||||
=head3 StartSystemRestore
|
=head3 StartSystemRestore
|
||||||
|
|
||||||
The value of the Content-Type header in the HTTP POST request shall be “application/octetstream”.
|
The value of the Content-Type header in the HTTP POST request shall be "application/octetstream".
|
||||||
|
|
||||||
Returns a L<ONVIF::Device::Elements::StartSystemRestoreResponse|ONVIF::Device::Elements::StartSystemRestoreResponse> object.
|
Returns a L<ONVIF::Device::Elements::StartSystemRestoreResponse|ONVIF::Device::Elements::StartSystemRestoreResponse> object.
|
||||||
|
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue