guino / BazzDoorbell

128 stars 22 forks source link

Chacon FI02 #24

Open SamThing opened 3 years ago

SamThing commented 3 years ago

Hi. I recently bought this camera https://chacon.com/pt/camaras-ip/1238-camara-ip-wi-fi-interior-mini-1080p-5411478345268.html. Which is basically a smartlife(tuya) camera running firmware 2.9.5 Port 80 is open but when i try to http i get prompt to login with username and password which i was not able to find. I was able to gain access with #13 Now I have telnet and the hack file is done.

But I'm still getting prompted to login with username and password. (already tried all possible combinations, the serial number and etc) Also, snap and mjpeg don't work (tiny blank square image)

Some informations about the cam (I was able to get them running /tmp/PPStart ): name: Smart Home Camera factory: PPSTRONG device_type: 74 model: Mini 8S hardware_version: M8S_H1_V10_F23 software_version: 2.9.5 firmware_version: ppstrong-c51-s_chacon-2.9.5.20200205 sn: 059554188

I got UART to work (readonly it seems) and the hardware aspects are very similar to this one https://github.com/guino/BazzDoorbell/issues/2#issuecomment-774789777

Great work you've done! Thanks for your time and effort!

SamThing commented 3 years ago

Some things I noted:

mem=37M console=ttyAMA0,115200n8 mtdparts=hisfc:192k(bld)ro,64k(env)ro,64k(enc)ro,64k(sysflg)ro,3136k(sys),4352k(app),320k(cfg) ppsAppParts=5 ppsWatchInitEnd - ip=${T///$'\x20'}:::::;T=\"sleep5;mkdir-p/mnt/mmc01;mount-tvfat/dev/mmcblk0p1_/mnt/mmc01;/mnt/mmc01/initrun.sh&\";eval mtdparts=hi_sfc:192k(bld)ro,64k(env)ro,64k(enc)ro,64k(sysflg)ro,3136k(sys),4224k(app),448k(cfg) ppsAppParts=5 ppsWatchInitEnd

SamThing commented 3 years ago
binwalk flash.bin

DECIMAL       HEXADECIMAL     DESCRIPTION
--------------------------------------------------------------------------------
18304         0x4780          gzip compressed data, has original file name: "u-boot.bin", from Unix, last modified: 2019-07-22 08:33:20
393216        0x60000         uImage header, header size: 64 bytes, header CRC: 0xB176B747, created: 2019-07-22 07:52:05, image size: 3205538 bytes, Data Address: 0x40008000, Entry Point: 0x40008000, data CRC: 0x8846780B, OS: Linux, CPU: ARM, image type: OS Kernel Image, compression type: none, image name: "Linux-4.9.37"
393280        0x60040         Linux kernel ARM boot executable zImage (little-endian)
395744        0x609E0         device tree image (dtb)
409272        0x63EB8         device tree image (dtb)
415228        0x655FC         device tree image (dtb)
419444        0x66674         gzip compressed data, maximum compression, from Unix, last modified: 1970-01-01 00:00:00 (null date)
3584680       0x36B2A8        device tree image (dtb)
3604480       0x370000        CramFS filesystem, little endian, size: 4136960, version 2, sorted_dirs, CRC 0x54D40DD5, edition 1, 1010 blocks, 3 files
7929856       0x790000        JFFS2 filesystem, little endian
8192248       0x7D00F8        Zlib compressed data, compressed
8192496       0x7D01F0        Zlib compressed data, compressed
8194704       0x7D0A90        Zlib compressed data, compressed
8194952       0x7D0B88        Zlib compressed data, compressed
8198124       0x7D17EC        Zlib compressed data, compressed
8198372       0x7D18E4        Zlib compressed data, compressed
8200640       0x7D21C0        Zlib compressed data, compressed
8200888       0x7D22B8        Zlib compressed data, compressed
8203096       0x7D2B58        Zlib compressed data, compressed
8203344       0x7D2C50        Zlib compressed data, compressed
8205552       0x7D34F0        Zlib compressed data, compressed
8205800       0x7D35E8        Zlib compressed data, compressed
8208652       0x7D410C        Zlib compressed data, compressed
8208900       0x7D4204        Zlib compressed data, compressed
8210932       0x7D49F4        Zlib compressed data, compressed
8211180       0x7D4AEC        Zlib compressed data, compressed
8213388       0x7D538C        Zlib compressed data, compressed
8213636       0x7D5484        Zlib compressed data, compressed
8217552       0x7D63D0        Zlib compressed data, compressed
8217800       0x7D64C8        Zlib compressed data, compressed
8221032       0x7D7168        Zlib compressed data, compressed
8221280       0x7D7260        Zlib compressed data, compressed
8225488       0x7D82D0        Zlib compressed data, compressed
8225736       0x7D83C8        Zlib compressed data, compressed
8226992       0x7D88B0        Zlib compressed data, compressed
8227240       0x7D89A8        Zlib compressed data, compressed
8229276       0x7D919C        Zlib compressed data, compressed
8229524       0x7D9294        Zlib compressed data, compressed
8231444       0x7D9A14        Zlib compressed data, compressed
8231692       0x7D9B0C        Zlib compressed data, compressed
8233612       0x7DA28C        Zlib compressed data, compressed
8233860       0x7DA384        Zlib compressed data, compressed
8235780       0x7DAB04        Zlib compressed data, compressed
8236028       0x7DABFC        Zlib compressed data, compressed
8237284       0x7DB0E4        Zlib compressed data, compressed
8237532       0x7DB1DC        Zlib compressed data, compressed
8239568       0x7DB9D0        Zlib compressed data, compressed
8239816       0x7DBAC8        Zlib compressed data, compressed
8242176       0x7DC400        Zlib compressed data, compressed
8242424       0x7DC4F8        Zlib compressed data, compressed
8244340       0x7DCC74        Zlib compressed data, compressed
8244588       0x7DCD6C        Zlib compressed data, compressed
8246504       0x7DD4E8        Zlib compressed data, compressed
8246752       0x7DD5E0        Zlib compressed data, compressed
8248004       0x7DDAC4        Zlib compressed data, compressed
8248252       0x7DDBBC        Zlib compressed data, compressed
8250284       0x7DE3AC        Zlib compressed data, compressed
8250532       0x7DE4A4        Zlib compressed data, compressed
8252448       0x7DEC20        Zlib compressed data, compressed
8252696       0x7DED18        Zlib compressed data, compressed
8254612       0x7DF494        Zlib compressed data, compressed
8254860       0x7DF58C        Zlib compressed data, compressed
8257096       0x7DFE48        Zlib compressed data, compressed
8257344       0x7DFF40        Zlib compressed data, compressed
8257732       0x7E00C4        Zlib compressed data, compressed
8258032       0x7E01F0        Zlib compressed data, compressed
8260180       0x7E0A54        Zlib compressed data, compressed
8260428       0x7E0B4C        Zlib compressed data, compressed
8261492       0x7E0F74        Zlib compressed data, compressed
8261740       0x7E106C        Zlib compressed data, compressed
8263336       0x7E16A8        JFFS2 filesystem, little endian
8263776       0x7E1860        Zlib compressed data, compressed
8264028       0x7E195C        Zlib compressed data, compressed
8265184       0x7E1DE0        JFFS2 filesystem, little endian
8265388       0x7E1EAC        Zlib compressed data, compressed
8265640       0x7E1FA8        Zlib compressed data, compressed
8266600       0x7E2368        Zlib compressed data, compressed
8266852       0x7E2464        Zlib compressed data, compressed
8272436       0x7E3A34        Zlib compressed data, compressed
8272804       0x7E3BA4        Zlib compressed data, compressed
8273176       0x7E3D18        Zlib compressed data, compressed
8273544       0x7E3E88        Zlib compressed data, compressed
8273848       0x7E3FB8        Zlib compressed data, compressed
8274100       0x7E40B4        Zlib compressed data, compressed
8274416       0x7E41F0        Zlib compressed data, compressed
8276016       0x7E4830        Zlib compressed data, compressed
8276268       0x7E492C        Zlib compressed data, compressed
8276584       0x7E4A68        Zlib compressed data, compressed
8278300       0x7E511C        Zlib compressed data, compressed
8278548       0x7E5214        Zlib compressed data, compressed
8280520       0x7E59C8        Zlib compressed data, compressed
8280768       0x7E5AC0        Zlib compressed data, compressed
8285432       0x7E6CF8        Zlib compressed data, compressed
8285728       0x7E6E20        Zlib compressed data, compressed
8285976       0x7E6F18        Zlib compressed data, compressed
8286292       0x7E7054        Zlib compressed data, compressed
8287228       0x7E73FC        Zlib compressed data, compressed
8287476       0x7E74F4        Zlib compressed data, compressed
8287792       0x7E7630        Zlib compressed data, compressed
8289392       0x7E7C70        Zlib compressed data, compressed
8289640       0x7E7D68        Zlib compressed data, compressed
8289956       0x7E7EA4        Zlib compressed data, compressed
8290480       0x7E80B0        Zlib compressed data, compressed
8290660       0x7E8164        Zlib compressed data, compressed
8290912       0x7E8260        Zlib compressed data, compressed
8291228       0x7E839C        Zlib compressed data, compressed
8292948       0x7E8A54        Zlib compressed data, compressed
8293196       0x7E8B4C        Zlib compressed data, compressed
8293512       0x7E8C88        Zlib compressed data, compressed
8295112       0x7E92C8        Zlib compressed data, compressed
8295360       0x7E93C0        Zlib compressed data, compressed
8295676       0x7E94FC        Zlib compressed data, compressed
8297276       0x7E9B3C        Zlib compressed data, compressed
8297524       0x7E9C34        Zlib compressed data, compressed
8297840       0x7E9D70        Zlib compressed data, compressed
8299588       0x7EA444        Zlib compressed data, compressed
8300036       0x7EA604        Zlib compressed data, compressed
8300480       0x7EA7C0        Zlib compressed data, compressed
8300928       0x7EA980        Zlib compressed data, compressed
8301296       0x7EAAF0        Zlib compressed data, compressed
8301664       0x7EAC60        Zlib compressed data, compressed
8302108       0x7EAE1C        Zlib compressed data, compressed
8302408       0x7EAF48        Zlib compressed data, compressed
8302656       0x7EB040        Zlib compressed data, compressed
8302972       0x7EB17C        Zlib compressed data, compressed
8304576       0x7EB7C0        Zlib compressed data, compressed
8304824       0x7EB8B8        Zlib compressed data, compressed
8305140       0x7EB9F4        Zlib compressed data, compressed
8306860       0x7EC0AC        Zlib compressed data, compressed
8307108       0x7EC1A4        Zlib compressed data, compressed
8309316       0x7ECA44        Zlib compressed data, compressed
8309564       0x7ECB3C        Zlib compressed data, compressed
8311216       0x7ED1B0        Zlib compressed data, compressed
8311468       0x7ED2AC        Zlib compressed data, compressed
8312984       0x7ED898        Zlib compressed data, compressed
8313232       0x7ED990        Zlib compressed data, compressed
8315204       0x7EE144        Zlib compressed data, compressed
8315452       0x7EE23C        Zlib compressed data, compressed
8317616       0x7EEAB0        Zlib compressed data, compressed
8317864       0x7EEBA8        Zlib compressed data, compressed
8319836       0x7EF35C        Zlib compressed data, compressed
8320084       0x7EF454        Zlib compressed data, compressed
8322248       0x7EFCC8        Zlib compressed data, compressed
8322496       0x7EFDC0        Zlib compressed data, compressed
8322872       0x7EFF38        Zlib compressed data, compressed
8324720       0x7F0670        Zlib compressed data, compressed
8324968       0x7F0768        Zlib compressed data, compressed
8325928       0x7F0B28        Zlib compressed data, compressed
8326180       0x7F0C24        Zlib compressed data, compressed
8327140       0x7F0FE4        Zlib compressed data, compressed
8327392       0x7F10E0        Zlib compressed data, compressed
8328352       0x7F14A0        Zlib compressed data, compressed
8328604       0x7F159C        Zlib compressed data, compressed
8329560       0x7F1958        Zlib compressed data, compressed
8329808       0x7F1A50        Zlib compressed data, compressed
8330768       0x7F1E10        Zlib compressed data, compressed
8331020       0x7F1F0C        Zlib compressed data, compressed
8332096       0x7F2340        Zlib compressed data, compressed
8332344       0x7F2438        Zlib compressed data, compressed
8333304       0x7F27F8        Zlib compressed data, compressed
8333556       0x7F28F4        Zlib compressed data, compressed
8334516       0x7F2CB4        Zlib compressed data, compressed
8334768       0x7F2DB0        Zlib compressed data, compressed
8335728       0x7F3170        Zlib compressed data, compressed
8335980       0x7F326C        Zlib compressed data, compressed
8336936       0x7F3628        Zlib compressed data, compressed
8337184       0x7F3720        Zlib compressed data, compressed
8338144       0x7F3AE0        Zlib compressed data, compressed
8338396       0x7F3BDC        Zlib compressed data, compressed
8339356       0x7F3F9C        Zlib compressed data, compressed
8339608       0x7F4098        Zlib compressed data, compressed
8340884       0x7F4594        Zlib compressed data, compressed
8341132       0x7F468C        Zlib compressed data, compressed
8342092       0x7F4A4C        Zlib compressed data, compressed
8342344       0x7F4B48        Zlib compressed data, compressed
8343304       0x7F4F08        Zlib compressed data, compressed
8343556       0x7F5004        Zlib compressed data, compressed
8344516       0x7F53C4        Zlib compressed data, compressed
8344768       0x7F54C0        Zlib compressed data, compressed
8345724       0x7F587C        Zlib compressed data, compressed
8345972       0x7F5974        Zlib compressed data, compressed
8346932       0x7F5D34        Zlib compressed data, compressed
8347184       0x7F5E30        Zlib compressed data, compressed
8348336       0x7F62B0        Zlib compressed data, compressed
8348588       0x7F63AC        Zlib compressed data, compressed
8349816       0x7F6878        Zlib compressed data, compressed
8350064       0x7F6970        Zlib compressed data, compressed
8352824       0x7F7438        Zlib compressed data, compressed
8353072       0x7F7530        Zlib compressed data, compressed
8354324       0x7F7A14        Zlib compressed data, compressed
8354572       0x7F7B0C        Zlib compressed data, compressed
8355720       0x7F7F88        Zlib compressed data, compressed
8355972       0x7F8084        Zlib compressed data, compressed
8357120       0x7F8500        Zlib compressed data, compressed
8357372       0x7F85FC        Zlib compressed data, compressed
8358520       0x7F8A78        Zlib compressed data, compressed
8358772       0x7F8B74        Zlib compressed data, compressed
8360032       0x7F9060        Zlib compressed data, compressed
8360280       0x7F9158        Zlib compressed data, compressed
8361428       0x7F95D4        Zlib compressed data, compressed
8361612       0x7F968C        Zlib compressed data, compressed
8361864       0x7F9788        Zlib compressed data, compressed
8363128       0x7F9C78        Zlib compressed data, compressed
8363376       0x7F9D70        Zlib compressed data, compressed
8363624       0x7F9E68        JFFS2 filesystem, little endian
8365028       0x7FA3E4        Zlib compressed data, compressed
8365280       0x7FA4E0        Zlib compressed data, compressed
8366240       0x7FA8A0        Zlib compressed data, compressed
8366492       0x7FA99C        Zlib compressed data, compressed
8367452       0x7FAD5C        Zlib compressed data, compressed
8367704       0x7FAE58        Zlib compressed data, compressed
8368660       0x7FB214        Zlib compressed data, compressed
8368908       0x7FB30C        Zlib compressed data, compressed
8369868       0x7FB6CC        Zlib compressed data, compressed
8370120       0x7FB7C8        Zlib compressed data, compressed
8371080       0x7FBB88        Zlib compressed data, compressed
8371332       0x7FBC84        Zlib compressed data, compressed
8372064       0x7FBF60        JFFS2 filesystem, little endian
8372428       0x7FC0CC        Zlib compressed data, compressed
8372988       0x7FC2FC        JFFS2 filesystem, little endian
8373640       0x7FC588        Zlib compressed data, compressed
8374200       0x7FC7B8        JFFS2 filesystem, little endian
8374852       0x7FCA44        Zlib compressed data, compressed
8375412       0x7FCC74        JFFS2 filesystem, little endian
8376064       0x7FCF00        Zlib compressed data, compressed
8376624       0x7FD130        JFFS2 filesystem, little endian
guino commented 3 years ago

@SamThing since you used #13 the camera can boot without a SD card (just keep in mind that when booting without SD card it will run standard/stock firmware).

For snap/mjpeg to work you need to adjust the jpeg address in the snap.cgi and mjpeg.cgi files - this must be done based on your ppsapp file (which you did not post). Instructions on how to do that are posted in https://github.com/guino/ppsapp-rtsp which also contains instructions on patching ppsapp to enable RTSP.

If you got Telnet access you should have a copy of your ppsapp under /home/app/ppsapp of the SD card. You can either patch it (and find jpeg address) with the instructions on the link above OR post a zip of your ppsapp so I can make a patch for it (and post it).

What I am not exactly clear is what are your trying to get with “http access” - some cameras don’t have that enabled at all, the ones that have that enabled don’t provide you anything other than some information. And in many cameras you can enable http access with ppsFactoryTool.txt but there’s no “web view” of the camera if that’s what you want. The only thing close to a “web view” is the snap.cgi and mjpeg.cgi links which are added by the hack on port 8080 (not port 80 of the firmware). In any case all tuya cameras that I have seen use the same user/password for http links: admin:056565099 for instance http://admin:056565099@IP/proc/cmdline — if it doesn’t work for you I suggest trying a different web browser.

In any case you will gain nothing from the http links that you don’t already have with Telnet so you really just need to get your ppsapp patched for RTSP and set the jpeg address in snap/mjpeg and you will have RTSP, snapshot and mjpeg features enabled on your camera.

Finally please notice the snap/mjpeg links work on port 8080 (not port 80) with user/password defined in http.conf. RTSP requires no user/password once ppsapp is patched.

SamThing commented 3 years ago

Hi @guino , thanks for you quick reply

I'll try to get the address using the instructions you provided. I didn't see that main repo page, only this one issue

Regarding the http access, I mean exactly the built in web server you mentioned (is enabled by default). The 8080 port hack is working like a charm.

The endpoint http://admin:056565099@ip/proc/cmdline (or anyother on the port 80) doesn't work, it keeps asking me user/pass. Same thing on differents browsers. Not sure if it's a tuya camera tho. The firmware_version string contains this "chacon" word. Already tried using the serial number as pass with no luck.

I just need the RSTP stream to be accessible from my PI or something on the network, so patching should do the trick right?

SamThing commented 3 years ago

--deleted-- Here's my ppsapp file (without the txt extension). I'll try to patch it later

guino commented 3 years ago

@SamThing I should be able to patch it and get the jpeg address in a little bit assuming the file is good (haven’t checked yet).

SamThing commented 3 years ago

Np, but I want to learn something of the proccess too. I'm a enthusiast of embedded systems and stuff.

Seems I need help anyway since I couldn't find the ipc_ring occurrence on my file 😄 I also was not able to follow the LAB_0xxxxx label as it doesn't exists

image

image

Sorry for the screenshot quality, I'm running ghidra on headless remote machine (ssh -X)

guino commented 3 years ago

Since you're trying to learn: the LAB_0xxxx is a reference for the main function on newer ppsapp files -- in your older ppsapp the symbol information wasn't removed so it has the 'original' name which is 'main' -- this actually makes it easier to find the main sub since you just have to double click the 'main' word.

SamThing commented 3 years ago

Cool!

The main function seems a little different than the one you showed. Seems like we can call the file passing arguments to disable the watchdog for example.

undefined4 main(int param_1,int param_2)

{
  __pid_t _Var1;
  int iVar2;
  int iVar3;
  int iVar4;
  char *__s1;
  code *pcStack200;
  code *pcStack196;
  undefined4 local_c0;
  undefined4 local_b8;
  char acStack172 [128];
  int local_2c;

  local_2c = __stack_chk_guard;
  _Var1 = getpid();
  sprintf(acStack172,"/proc/%d/oom_score_adj",_Var1);
  iVar2 = getrlimit64(RLIMIT_STACK,(rlimit64 *)&local_c0);
  if (iVar2 != 0) {
    puts("getrlimit failed!");
LAB_0004e864:
    if (local_2c == __stack_chk_guard) {
      return 0xffffffff;
    }
                    /* WARNING: Subroutine does not return */
    __stack_chk_fail();
  }
  printf("ulimit stack soft: %d hard: %d\n",local_c0,local_b8);
  setenv("WATCHDOG","1",0);
  puts("\n");
  puts("=============================================");
  puts("=============================================");
  puts("\n");
  pcStack200 = pps_malloc2;
  pcStack196 = pps_free;
  pps_cJSON_InitHooks(&pcStack200);
  puts("aaaaaaaaaaaaaaa slb init bbbbbbbbbbbbbbbbbbbbbb");
  puts("aaaaaaaaaaaaaaa slb init bbbbbbbbbbbbbbbbbbbbbb");
  puts("aaaaaaaaaaaaaaa slb init bbbbbbbbbbbbbbbbbbbbbb");
  puts("aaaaaaaaaaaaaaa slb init bbbbbbbbbbbbbbbbbbbbbb");
  pps_mem_global_init(&DAT_002c0000);
  if (1 < param_1) {
    iVar2 = 1;
LAB_0004e7bc:
    do {
      iVar3 = strcmp(*(char **)(param_2 + 4),"-h");
      if (iVar3 == 0) {
        puts(
            " <cmd> -option=value ...\n   -h               help information\n   -d              daemon mode\n   -vcodec=         set video codec: only [h264] support\n   -fps=           set video fps: [1~30]\n   -bps=            set video bps: [>1024]\n   -gop=           set video gop: [>0]\n   -vbr             set video bps ctrl type: variable\n   -cbr            set video bps ctrl type: constant\n   -acodec=         set audio codec: [aacor mpg2], default=mpg2\n   -bitrate=        set audio bitrate:8000/16000/32000/64000/128000/192000\n   -sample=         set audio sample rate:8000/16000/32000/z44100/48000\n   -bitwidth=       set audio bitwidth:  8/16/32,default:16bit\n   -channels=       set audio channels:  1/2, default: 1\n   -print_fps      print audio/video fps"
            );
        goto LAB_0004e864;
      }
      __s1 = *(char **)(param_2 + iVar2 * 4);
      iVar4 = strcmp(__s1,"-d");
      iVar3 = iVar2 * 4;
      if (iVar4 != 0) {
        iVar4 = strcmp(__s1,"--watchdog=no");
        if (iVar4 == 0) {
          iVar2 = iVar2 + 1;
          unsetenv("WATCHDOG");
          if (param_1 <= iVar2) break;
          goto LAB_0004e7bc;
        }
        iVar4 = strcmp(__s1,"--watchdog=yes");
        if (iVar4 == 0) {
          setenv("WATCHDOG","1",0);
        }
        else {
          iVar4 = strcmp(__s1,"-sensor");
          if (iVar4 == 0) {
            iVar2 = iVar2 + 1;
            if (param_1 <= iVar2) break;
            setenv("SENSOR_TYPE",*(char **)(param_2 + iVar3 + 4),0);
          }
        }
      }
      iVar2 = iVar2 + 1;
    } while (iVar2 < param_1);
  }
  register_signal_handlers();
  FUN_0004eae0(&DAT_0029445c,ppsdev_init_plugins_core);
  FUN_0004eae0(&DAT_00294464,ppsdev_init_plugins_user);
  FUN_0004eae0("after",ppsdev_init_plugins_after);
  do {
    sleep(10000);
  } while( true );
}
guino commented 3 years ago

@SamThing This really isn't a 'tuya' device as you said. It is a 'ppstrong' firmware but has no tuya functions. It will take some time to review the code before I know what is available. The rtsp functions we've used so far are from tuya so they're not in this ppsapp. There are however some references to rtsp/onvif in the code so I need to see if we can enable it somehow. The instructions I put together won't be as helpful but the JPEG functions seem to be the same, you can try to use snap/mjpeg by setting this address in snap.cgi/mjpeg.cgi : 035cdc4

guino commented 3 years ago

@SamThing play.cgi address should be: 035d7e0

SamThing commented 3 years ago

Awesome!

You rock man! snap/mjpeg works like a charm, I'll try play.cgi now

guino commented 3 years ago

@SamThing can you do (linux command) nmap 192.168.x.x from your linux machine using the IP of your device to see which ports are open ? it looks like it does have a server on port 8554 -- it may not be started depending on the settings (which we can fix).

It would be VERY helpful in investigating the code if you could do this (using telnet on the device):

PPSID=$(ps | grep -v grep | grep ppsapp | awk '{print $1}');   kill $PPSID
/mnt/mmc01/home/app/ppsapp > /mnt/mmc01/ppsapp.log

Then open whatever app it came with and start a video feed, then stop it, execute (on telnet) sync and take the SD card out and post the ppsapp.log file from the SD card so it can help me follow the code quicker. You can email it to me if you prefer (my email is on my github profile).

guino commented 3 years ago

@SamThing can you also check if there's anything useful in /home/cfg/dev_settings.json of the device ? I don't think it has the password for anything but it's worth checking whatever else is in that directory in the device.

SamThing commented 3 years ago

@guino

Good news, the play.cgi works like a charm too

I noted that the RTSP port only opens with the app. Before trying to hack the camera itself, I started with some wireshark stuff. The RTSP traffic is UDP and the port only opens after the app sent any unknown command to the chacon servers. Other thing: if you try to get anything when the port 8554 is open, it causes the camera to crash. Even running nmap does that.

Before the starting the video feed:

nmap 192.168.1.226 -p1-8554
Starting Nmap 7.80 ( https://nmap.org ) at 2021-03-15 15:34 WET
Nmap scan report for 192.168.1.226
Host is up (0.0096s latency).
Not shown: 8549 closed ports
PORT     STATE SERVICE
23/tcp   open  telnet
53/tcp   open  domain
80/tcp   open  http
8080/tcp open  http-proxy

Nmap done: 1 IP address (1 host up) scanned in 2.64 seconds

After starting the video feed:

nmap 192.168.1.226 -p1-8554
Starting Nmap 7.80 ( https://nmap.org ) at 2021-03-15 15:34 WET
Nmap scan report for 192.168.1.226
Host is up (0.0096s latency).
Not shown: 8549 closed ports
PORT     STATE SERVICE
23/tcp   open  telnet
53/tcp   open  domain
80/tcp   open  http
8080/tcp open  http-proxy
8554/tcp open  rtsp-alt

Nmap done: 1 IP address (1 host up) scanned in 2.64 seconds

After running this nmap, the camera restarts. I'll upload the log in a minute

guino commented 3 years ago

@SamThing it looks like the http server on this device allows some post commands to come in to do different things (possibly open RTSP too?). I can probably make a patch that would take 'any' user/password for the http requests but right now I haven't found the user/password combination. I just know for a fact it isn't admin:admin (which you already knew).

SamThing commented 3 years ago

--deleted--

Yes, makes sense. Not sure if the log file will be usefull, I couldn't start the video feed. The ppsapp starts fine, but the android app hangs forever.

Redirecting the output causes anything that prevents the conection to the camera.

guino commented 3 years ago

@SamThing the fact that redirecting output prevents connection with the camera makes me think this ppsapp is unable to re-open the hardware handles once it is killed (thus it probably restarts after awhile). You may need to apply the process described here instead: https://github.com/DanTLehman/orion_sc008ha#total-success -- you can adjust the S90ppstrong-290 file so the line /mnt/mmc01/ppsapp-rtsp & is changed to /mnt/mmc01/home/app/ppsapp > /mnt/mmc01/ppsapp.log & so we have the output while the device works correctly. Then once we have a patch you can change it back to just /mnt/mmc01/ppsapp-rtsp &.

1-Did you check the files under /home/cfg to see if there was anything with perhaps a reference to user/password information ? 2-While on telnet, can you post a response to the 'mount' command ?

Right now I can see in the code+log where it calls the function that is supposed to start the rtsp server but I have no way of knowing if that's being started. Sometimes nmap doesn't show the port open even if it is, so maybe you want to try (from your linux machine) telnet IP 8554 to see if it connects at all -- there's a chance it might (even without patching). Then it would just be a matter of finding the password OR disabling the authentication so any user/password works.

guino commented 3 years ago

@SamThing additional to the above you may want to try http://IP/search (without user/password) to see if it works -- seems like it may provide an 'ONVIF' response on port 80.

SamThing commented 3 years ago

Cool, the search endpoint works:

// 20210315163737
// http://192.168.1.226/search

{
  "deviceName": "059554188",
  "serialno": "059554188",
  "sn": "ppscf12989d3f4854da0",
  "licenseUsed": 1,
  "licenseId": "ppscf12989d3f4854da0",
  "p2p_uuid": "v3-0595541880000111A",
  "factory_code": 0,
  "factory_code_str": "",
  "model": "Mini 8S",
  "tp": "000000000",
  "ip": "192.168.1.226",
  "mask": "255.255.255.0",
  "gw": "192.168.1.1",
  "mac": "ac:64:cf:ea:1d:3e",
  "interface": "wlan0",
  "version": "2.9.5",
  "server_type": "https://apis-eu-frankfurt.meari.com.cn",
  "capability": "{\"ver\":18,\"cat\":\"camera\",\"caps\":{\"vtk\":3,\"fcr\":0,\"dcb\":1,\"md\":1,\"ptz\":0,\"tmpr\":0,\"hmd\":0,\"pir\":0,\"cst\":0,\"geo\":1,\"nst\":1,\"evs\":1,\"vst\":0,\"led\":1,\"cse\":0,\"dnm\":1,\"cs2\":0,\"bps\":226,\"wfs\":0,\"svc\":0,\"flt\":0,\"rng\":0,\"pwm\":0,\"sd\":1,\"ota\":1,\"hms\":0,\"shd\":0,\"flp\":1,\"slp\":1,\"vec\":0,\"bcd\":0,\"ptr\":0,\"pdt\":0,\"rel\":0,\"ovc\":0}}",
  "produceAuth": 1
}

The mount command:

mount
rootfs on / type rootfs (rw,size=15864k,nr_inodes=3966)
proc on /proc type proc (rw,relatime)
sysfs on /sys type sysfs (rw,relatime)
tmpfs on /dev type tmpfs (rw,relatime)
devpts on /dev/pts type devpts (rw,relatime,mode=600,ptmxmode=000)
/dev/mtdblock6 on /home/cfg type jffs2 (rw,relatime)
/dev/mmc01 on /mnt/mmc01 type vfat (rw,relatime,fmask=0022,dmask=0022,codepage=437,iocharset=iso8859-1,shortname=mixed,errors=remount-ro)

I couldn't find anything usefull on the cfg folder:

ls -la /home/cfg/
-rw-r--r--    1 root     root            14 Mar 16 00:37 region
-rw-r--r--    1 root     root            12 Mar 16 00:37 TZ
-rw-r--r--    1 root     root            15 Jan  1  2016 device.token
-rw-r--r--    1 root     root           422 Mar 16 00:37 sys_time
-rw-r--r--    1 root     root           315 Mar 16 00:37 capa.info
-rw-r--r--    1 root     root            12 Mar 16 00:37 alarm.cfg
-rw-r--r--    1 root     root           370 Mar 16 00:37 dev_settings.json
-rw-r--r--    1 root     root            77 Jan  1  2016 test_info_save.conf
lrwxrwxrwx    1 root     root             9 Mar 15 17:53 cfg -> /home/cfg
-rw-r--r--    1 root     root           260 Mar 16 00:37 wifi.info
-rw-r--r--    1 root     root            74 Jan  1  2016 pps_appserver.json
cat dev_settings.json
{
        "ntp_pool":     ["time1.aliyun.com", "time2.aliyun.com", "time3.aliyun.com", "time4.aliyun.com", "time5.aliyun.com", "time6.aliyun.com", "time7.aliyun.com"],
        "sleep":        "off",
        "sleep_time":   [],
        "home_geographic":      {
},
        "home_geo_fencing_state":       "0",
        "timezone":     "UTC8:00",
        "motion_detect":        {
                "enable":       0,
                "alarmtype":    1,
                "sensitivity":  4
        },
        "video_mirror": 0

cat test_info_save.conf
{
        "semi_state":   1,
        "aging_state":  0,
        "madeup_state": 1,
        "auth_state":   1
}
guino commented 3 years ago

@SamThing cool, did you check if there was anything useful in pps_appserver.json ?

It looks like your device has rw root partition which means we could just modify the /etc/init.d/S90PPstrong file so it mounts the SD card and copies a modified ppsapp to /opt/pps/home/app/ppsapp and redirects the ppsapp line to /tmp/ppsapp.log (so we could get the log later) and reboot to see if the changes are presistent or get reset after reboot. For testing I guess you can just modify anything in that file, reboot and see if the file still has the changes after reboot.

If the changes are persistent (I have cameras that are like that) then we can work on the other changes -- but the changes from the link I posted (Dan's github) should work just the same (with the benefit of being persistent after firmware upgrades).

Let me know

SamThing commented 3 years ago

Let me try that

Btw, the 8554 seems open (but hidden indeed):

telnet 192.168.1.226 8554
Trying 192.168.1.226...
Connected to 192.168.1.226.
Escape character is '^]'.
Connection closed by foreign host.

And then the camera restarts

SamThing commented 3 years ago
cat pps_appserver.json
{
        "endpoint":     "https://apis-eu-frankfurt.meari.com.cn",
        "gwCode":       "EU"
}
guino commented 3 years ago

@SamThing with port 8554 open I can only assume the RTSP server is starting up, it's just that it will likely need a user/password that we currently don't have. I can make it so it accepts anything like admin:admin but that still requires us being able to start the ppsapp correctly without having to kill it first -- this means either using Dan's method OR being able to modify that S90PPStronf startup script. Let me know what you find out.

PS: Too bad there was nothing in /home/cfg that could hint to the password.

SamThing commented 3 years ago

The alterations are not persistent between reboots.

But the Dan's method worked!

Now I have the log file with the steam feed. Seems like there's some mqqt involved.

--deleted--

SamThing commented 3 years ago

The password is in the logfile: admin/c4c5bdec9d412936e2b37f89939ab407

guino commented 3 years ago

@SamThing I would try that with VLC rtsp://admin:c4c5bdec9d412936e2b37f89939ab407@IP:8554/ and also with Streaming/Channels/101 to see if it works at all

SamThing commented 3 years ago

No luck.

With or without the video stream feed on the camera keeps crashing

guino commented 3 years ago

@SamThing can you try password just: c4c5bdec9d412936 -- it seems like it has some references to just that in the log.

Since you got Dan's method going, I can make you a patched ppsapp that should accept any password if you like to try.

SamThing commented 3 years ago

Same result.

That would be great!

guino commented 3 years ago

--deleted--

Place that one on the SD card and make sure the S90PPStrong-290 file on the SD card points to the correct filename -- it should (hopefully) accept user admin with any password. I am hoping this will allow the RTSP feed to be viewed on one of rtsp://IP:8554/ or with Streaming/Channels/101

SamThing commented 3 years ago

No luck

The patched version runs as the unpatched. Requires the same password. The android app still working and no RTSP stream (even with the right password)

ps |grep pp
  924 root      1104 S    ./ppsdsry
  952 root      123m S    /mnt/mmc01/ppsapp-rtsp
guino commented 3 years ago

@SamThing orry, I forgot to mention they have a specific prevention against using admin as the password so if you tried admin:admin by any chance try admin:password instead.

You obviously have ppsapp-rtsp running (from the ps output, so I'd like you to try this:

http://admin:password@IP/proc/cmdline to see if it works

And the other thing I was going to ask is if you're trying VLC with TCP or UDP for the RTSP stream. By default I think VLC uses RTSP over UDP, but you can go in the settings ans switch to TCP (Click 'Tools > Preferences > Input / Codecs and select 'RTP over RTSP (TCP)' at the bottom, them click 'Save') you should be trying both to see.

SamThing commented 3 years ago

hi, only the right password works for the http endpoints, already tried other combinations.

The TCP stream fails as it does with UDP

😢

guino commented 3 years ago

so you're saying http://admin:RIGHTPASSWORD@IP/proc/cmdline works if you use the password from the log file, but doesn't work with RTSP ?

SamThing commented 3 years ago

Yes, that's right.

So the patched file works just the same as the unpatched one. On the http endpoints only the right password works and regarding the RTSP stream, no luck so far.

Looking to the logs, seems that first there's a mqtt connection to the server from both the android client and the camera. And then, begins an p2p conection between the android app and the camera. Still trying to get the details from the log.

guino commented 3 years ago

Did you happen to try the http endpounts like /proc/cmdline with the correct password before using the patched ppsapp file ? I am double checking the changes I made.

guino commented 3 years ago

@SamThing I think I found a case where my change was not catching, making one more change so you can try..

SamThing commented 3 years ago

Cool!

Yes, tried several passwords on the http endpoints, only the "original" one works

guino commented 3 years ago

@SamThing ok, try this one -- please try /proc/cmdline first to see if it takes any password (other than admin): --deleted--

guino commented 3 years ago

btw I didn't see much more info on the log you posted last time compared to the first one (just fyi) -- I was expecting to see some more stuff related to the RTSP stream.

SamThing commented 3 years ago

Yeah, me too. I can try get more logs.

No luck with this patch too. Same behaviour, only the right password works on http endpoints. RTSP still causes the camera to reboot (both UDP/TCP)

Let me know Should I get more logs?

Just out of curiosity: does any other camera you know use mqtt?

guino commented 3 years ago

tuya cameras use mqtt too but to tuya servers.

More logs may be helpful -- can you triple check that the S90PPStrong-290 on the root of the SD card is running the patched ppsapp-rtsp on the SD card (which by default is on the root of the SD card too) ? I know we modified it initially and just wanted to double check -- there's just no way for the "pps_user_verify_user()" function to be returning anything other than a good response on the last patch. So I am going to check the code for any other 'similar' functions but that one should be working, so it is weird to see no change in behavior.

SamThing commented 3 years ago

I modified the file to call the custom.sh on the root of the SD card:

cat /etc/init.d/S90PPStrong
#!/bin/sh

export PATH=/usr/bin:/sbin/:/usr/sbin:/bin

mkdir -p /opt/pps
mount -t cramfs /dev/mtdblock5 /opt/pps
tar xzf /opt/pps/app.tar.gz -C /
rm -f /home/init.d/S60ppsapp
umount /opt/pps

(
/home/init.d/initS
cd /home/app/
./network &
sleep 1

mkdir -p /mnt/mmc01
mount -t vfat /dev/mmcblk0p1 /mnt/mmc01
sleep 1

/mnt/mmc01/custom.sh &
#/mnt/mmc01/home/app/ppsapp &
#/mnt/mmc01/home/app/ppsapp > /mnt/mmc01/ppsapp.log &

sleep 15
rm /home/app -rf
sleep 20
until [ 1 -gt 2 ]
do
 echo 3 > /proc/sys/vm/drop_caches
 sleep 2
done
) &

And on the custom.sh I added the patched file:

cat custom.sh
#!/bin/sh
if [ ! -e /tmp/customrun ]; then
 echo custom > /tmp/customrun
 cp /mnt/mmc01/passwd /etc/passwd

 /mnt/mmc01/set record_enable 0
 /mnt/mmc01/set enable_event_record 0
 /mnt/mmc01/set onvif_enable 1

 if [ -e /mnt/mmc01/ppsapp ]; then
  #PPSID=$(ps | grep -v grep | grep ppsapp | awk '{print $1}')
  #kill $PPSID

  #/mnt/mmc01/ppsapp &
  /mnt/mmc01/ppsapp-rtsp &
  #/mnt/mmc01/ppsapp > /mnt/mmc01/ppsapp.log &
 else
  /mnt/mmc01/home/app/ppsapp
  #/mnt/mmc01/home/app/ppsapp > /mnt/mmc01/ppsapp.log &
 fi

 /mnt/mmc01/busybox telnetd -l /bin/sh
 /mnt/mmc01/busybox httpd -c /mnt/mmc01/httpd.conf -h /mnt/mmc01 -p 8080

fi
if [ ! -e /tmp/cleanup`date +%Y%m%d` ]; then
 rm -rf /tmp/cleanup*
 touch /tmp/cleanup`date +%Y%m%d`
 /mnt/mmc01/cgi-bin/cleanup.cgi > /tmp/cleanup.log
fi

As you can see, the ps show the patched file:

ps |grep pp
  924 root      1104 S    ./ppsdsry
  952 root      123m S    /mnt/mmc01/ppsapp-rtsp
 1439 root      1476 S    grep pp

And regarding the version that's running, here you can see the creation date (corresponding to the second one):

ls -la ppsapp-rtsp
-rwxr-xr-x    1 root     root       3318036 Mar 15 20:08 ppsapp-rtsp

My local time here is 20:32

So no doubt that's the last patched file that's running 😄

guino commented 3 years ago

sounds good -- I think I need a more comprehensive log so I don't go blind into this thing

guino commented 3 years ago

@SamThing it would be helpful if the log had some attempts to use RTSP and /proc/cmdline with (correct/wrong password too) as well and the RTSP using the app.

SamThing commented 3 years ago

Timeline:

--deleted--

SamThing commented 3 years ago

I can't try using external rtsp as the camera crashes and the log is erased. I can try appending the log file instead.

Let me try that. Just need to resolve some personal things first. Brb ~30m

guino commented 3 years ago

I think the function I patched is meant only for 'basic' authentication but apparently the requests are going out with 'Digest' so the changes I made are basically ignored. I don't know if there's a way to force basic authentication in the browser/VLC (or whatever RTSP client) but I'm trying to see if I can bypass the password on Digest.

SamThing commented 3 years ago

Works with basic auth!

And seems you're right:

curl -XGET 192.168.1.226/devices/network \
-H "User-Agent: Awesome HTTP Client" --digest --user admin:banana

401
curl -XGET 192.168.1.226/devices/network \
-H "User-Agent: Awesome HTTP Client" --user admin:banana

200 - ok

Not sure if there's a way to try it on rtsp, I'll investigate