Jump to content


Photo

serviceapp - gstplayer and exteplayer3

gstreamer ffmpeg

  • Please log in to reply
985 replies to this topic

Re: serviceapp - gstplayer and exteplayer3 #881 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 31 January 2019 - 21:10

Hello @fairbird

 

I do not understand you. This was already added.

Please check the commit: https://github.com/e...f09ffbcd64f811d

 

I have also question for others. Can someone with VU Plus STB (I do not have such one), can give me output of the following command:

cat /proc/stb/info/boxtype

 

Thank you



Re: serviceapp - gstplayer and exteplayer3 #882 athoik

  • PLi® Core member
  • 8,458 posts

+327
Excellent

Posted 31 January 2019 - 21:14

I have also question for others. Can someone with VU Plus STB (I do not have such one), can give me output of the following command:
 

cat /proc/stb/info/boxtype
 
Thank you


Does this help you?

root@vusolo4k:~# cat /proc/stb/info/boxtype
cat: can't open '/proc/stb/info/boxtype': No such file or directory
root@vusolo4k:~# grep -r "" /proc/stb/info/
/proc/stb/info/chipset:7376
/proc/stb/info/vumodel:solo4k
/proc/stb/info/version:1500A0
/proc/stb/info/model:dm8000

Wavefield T90: 0.8W - 1.9E - 4.8E - 13E - 16E - 19.2E - 23.5E - 26E - 33E - 39E - 42E - 45E on EMP Centauri DiseqC 16/1
Unamed: 13E Quattro - 9E Quattro on IKUSI MS-0916

Re: serviceapp - gstplayer and exteplayer3 #883 WanWizard

  • PLi® Core member
  • 70,220 posts

+1,798
Excellent

Posted 31 January 2019 - 21:16

root@vuduo4k:~# grep -r "" /proc/stb/info/
/proc/stb/info/model:dm8000
/proc/stb/info/chipset:7278
/proc/stb/info/version:1500A0
/proc/stb/info/vumodel:duo4k

Currently in use: VU+ Duo 4K (2xFBC S2), VU+ Solo 4K (1xFBC S2), uClan Usytm 4K Ultimate (S2+T2), Octagon SF8008 (S2+T2), Zgemma H9.2H (S2+T2)

Due to my bad health, I will not be very active at times and may be slow to respond. I will not read the forum or PM on a regular basis.

Many answers to your question can be found in our new and improved wiki.


Re: serviceapp - gstplayer and exteplayer3 #884 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 31 January 2019 - 21:29

@athoik, @WanWizard

 

Yes it helps. I need this for this:

https://github.com/e...e1371e4ed1ced60

 

        else if (access("/proc/stb/info/vumodel", F_OK) != -1 && \
                 access("/proc/stb/info/boxtype", F_OK) == -1 ) {
            // some STB like Octagon SF4008 has also /proc/stb/info/vumodel
            // but VU PLUS does not have /proc/stb/info/boxtype
            // please see: https://gitlab.com/e2i/e2iplayer/issues/282

 

Thank you,



Re: serviceapp - gstplayer and exteplayer3 #885 sonic1

  • Senior Member
  • 62 posts

+3
Neutral

Posted 31 January 2019 - 21:32

root@vuultimo4k:~# cat /proc/stb/info/boxtype
cat: can't open '/proc/stb/info/boxtype': No such file or directory
root@vuultimo4k:~# grep -r "" /proc/stb/info/
/proc/stb/info/chipset:7444s
/proc/stb/info/vumodel:ultimo4k
/proc/stb/info/version:1500A0
/proc/stb/info/model:dm8000



Re: serviceapp - gstplayer and exteplayer3 #886 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 1 February 2019 - 12:37

@Sam 

Please can you test these videos with exteplayer3 ?!

https://drive.google...ZXNCLWlQQlV4ZTA

 

On my device dm920 doesn't work with exteplayer3 + ffmpeg4.1 or 3.4

with gstplayer and default player (work just fine)

 

Thank you


Edited by fairbird, 1 February 2019 - 12:37.

DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #887 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 1 February 2019 - 17:28

Hello,

 

I did not test all of them, but this one which was tested by me works.

I tested on Zgemma H9S.

 

Regarding dm920 wost probably there is wrong data format injection used for it by the exteplayer3 since I do not have such STB, so I am not able to test.

 

Do you know source code of the dvbmediasink used by your image? and which version of the exteplayer3?



Re: serviceapp - gstplayer and exteplayer3 #888 foxbob

  • Senior Member
  • 624 posts

+18
Neutral

Posted 1 February 2019 - 17:51

Thank you very much for your work. Playing vp9 on my et110004k works.

Attached Files



Re: serviceapp - gstplayer and exteplayer3 #889 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 1 February 2019 - 23:05

@Sam

Thank you ..

 

This is my recipes what I using ..

 

exteplayer3

SUMMARY = "exteplayer3 - media player for E2"
DESCRIPTION = "Core of movie player for E2 based on the libeplayer using the ffmpeg solution"
SECTION = "multimedia"
LICENSE = "GPL-2.0"
LIC_FILES_CHKSUM = "file://${COMMON_LICENSE_DIR}/GPL-2.0;md5=801f80980d171dd6425610833a22dbe6"

DEPENDS = "ffmpeg"
RDEPENDS_${PN} = "ffmpeg"

inherit gitpkgv

PV = "52+gitr${SRCPV}"
PKGV = "52+gitr${GITPKGV}"

PR = "r1"

SRC_URI = "git://github.com/e2iplayer/exteplayer3.git;branch=master \
			file://use-ioctl-7-for-ac3plus.patch \
			file://define-audio-get-pts.patch \
"

S = "${WORKDIR}/git/"

SOURCE_FILES = "main/exteplayer.c"
SOURCE_FILES =+ "container/container.c"
SOURCE_FILES =+ "container/container_ffmpeg.c"
SOURCE_FILES =+ "manager/manager.c"
SOURCE_FILES =+ "manager/audio.c"
SOURCE_FILES =+ "manager/video.c"
SOURCE_FILES =+ "manager/subtitle.c"
SOURCE_FILES =+ "output/output_subtitle.c"
SOURCE_FILES =+ "output/output.c"
SOURCE_FILES =+ "output/writer/common/pes.c"
SOURCE_FILES =+ "output/writer/common/misc.c"
SOURCE_FILES =+ "output/writer/common/writer.c"
SOURCE_FILES =+ "output/linuxdvb_buffering.c"
SOURCE_FILES =+ "playback/playback.c"
SOURCE_FILES =+ "external/ffmpeg/src/bitstream.c"
SOURCE_FILES =+ "external/ffmpeg/src/latmenc.c"
SOURCE_FILES =+ "external/ffmpeg/src/mpeg4audio.c"
SOURCE_FILES =+ "external/flv2mpeg4/src/m4vencode.c"
SOURCE_FILES =+ "external/flv2mpeg4/src/flvdecoder.c"
SOURCE_FILES =+ "external/flv2mpeg4/src/dcprediction.c"
SOURCE_FILES =+ "external/flv2mpeg4/src/flv2mpeg4.c"

SOURCE_FILES =+ "${@bb.utils.contains("TARGET_ARCH", "sh4", "\
output/linuxdvb_sh4.c \
output/writer/sh4/writer.c \
output/writer/sh4/aac.c \
output/writer/sh4/ac3.c \
output/writer/sh4/divx2.c \
output/writer/sh4/dts.c \
output/writer/sh4/h263.c \
output/writer/sh4/h264.c \
output/writer/sh4/mp3.c \
output/writer/sh4/mpeg2.c \
output/writer/sh4/pcm.c \
output/writer/sh4/vc1.c \
output/writer/sh4/wma.c \
output/writer/sh4/wmv.c ", " \
output/linuxdvb_mipsel.c \
output/writer/mipsel/writer.c \
output/writer/mipsel/aac.c \
output/writer/mipsel/ac3.c \
output/writer/mipsel/mp3.c \
output/writer/mipsel/pcm.c \
output/writer/mipsel/lpcm.c \
output/writer/mipsel/dts.c \
output/writer/mipsel/amr.c \
output/writer/mipsel/wma.c \
output/writer/mipsel/h265.c \
output/writer/mipsel/h264.c \
output/writer/mipsel/h263.c \
output/writer/mipsel/mpeg2.c \
output/writer/mipsel/mpeg4.c \
output/writer/mipsel/divx3.c \
output/writer/mipsel/vp.c \
output/writer/mipsel/wmv.c \
output/writer/mipsel/vc1.c ", d)}"

do_compile() {
    ${CC} ${SOURCE_FILES} -D_FILE_OFFSET_BITS=64 -D_LARGEFILE64_SOURCE -D_LARGEFILE_SOURCE -DHAVE_FLV2MPEG4_CONVERTER -I${S}/include -I${S}/external -I${S}/external/flv2mpeg4 -I${D}/${libdir} -I${D}/${includedir} -lpthread -lavformat -lavcodec -lavutil -lswresample -o exteplayer3 ${LDFLAGS}
}

do_install() {
    install -d ${D}${bindir}
    install -m 0755 ${S}/exteplayer3 ${D}${bindir}
}

gstreamer1.0-plugin-dvbmediasink

DESCRIPTION = "gstreamer dvbmediasink plugin"
SECTION = "multimedia"
PRIORITY = "optional"
LICENSE = "GPLv2"
LIC_FILES_CHKSUM = "file://COPYING;md5=7fbc338309ac38fefcd64b04bb903e34"

DEPENDS = "gstreamer1.0 gstreamer1.0-plugins-base libdca glib-2.0 glib-2.0-native"

# Most machine recipes still (r)depend on gst-plugin-dvbmediasink
RPROVIDES_${PN} = "gst-plugin-dvbmediasink"
RREPLACES_${PN} = "gst-plugin-dvbmediasink"
RCONFLICTS_${PN} = "gst-plugin-dvbmediasink"

PROVIDES += "virtual/gstreamer1.0-mediasink"
RPROVIDES_${PN} += "virtual/gstreamer1.0-dvbmediasink"

GSTVERSION = "1.0"

SRC_URI = "git://github.com/christophecvr/gstreamer1.0-plugin-multibox-dvbmediasink;branch=openatv-dev;protocol=https"

S = "${WORKDIR}/git"

inherit gitpkgv

PV = "${GSTVERSION}+git${SRCPV}"
PKGV = "${GSTVERSION}+git${GITPKGV}"

do_configure_prepend() {
        sed -i 's/AC_INIT.*$/AC_INIT(gst-plugin-dvbmediasink, 1.0.0, @pli4)/' ${S}/configure.ac
        sed -i 's/AM_INIT_AUTOMAKE.*$/AM_INIT_AUTOMAKE([foreign])/' ${S}/configure.ac
}

inherit autotools pkgconfig

FILES_${PN} = "${libdir}/gstreamer-${GSTVERSION}/*.so*"
FILES_${PN}-dev += "${libdir}/gstreamer-${GSTVERSION}/*.la"
FILES_${PN}-staticdev += "${libdir}/gstreamer-${GSTVERSION}/*.a"
FILES_${PN}-dbg += "${libdir}/gstreamer-${GSTVERSION}/.debug"

PACKAGE_ARCH = "${MACHINE_ARCH}"

EXTRA_OECONF = "${DVBMEDIASINK_CONFIG} --with-gstversion=${GSTVERSION}"

DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #890 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 1 February 2019 - 23:57

@fairbird

 

Could you please give the output of the following command:

 


ls -la /proc/stb/tpm/0/serial

 

 

Please test attached exteplayer3 binary and let me know.

 

Regards,

SSS

Attached Files


Edited by samsamsam, 1 February 2019 - 23:59.


Re: serviceapp - gstplayer and exteplayer3 #891 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 2 February 2019 - 09:31

@Sam

Here is out of that command 

root@dm920:~# ls -la /proc/stb/tpm/0/serial
-rw-rw-rw-    1 root     root             0 Feb  2 11:19 /proc/stb/tpm/0/serial

With that attach file still doesn't work ...

 

Here is also debug from gstplayer (work just fine)

RemovePopup, id = ZapError
playing 5001:0:0:0:0:0:0:0:0:0:/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4
GstPlayer::GstPlayer initializing with options:
 audio_id                       = not set
 audio_sink                     = not set
 buffer_duration                = 0s
 buffer_size                    = 8192KB
 download_buffer_path           = not set
 ring_buffer_maxsize            = not set
 subtitles_enabled              = 1
 video_sink                     = not set
eServiceApp::isCurrentlySeekable
resolved to PLAY
eServiceApp::unpause
eServiceApp::isCurrentlySeekable
new service started! trying to download cuts!
download failed, no cuesheet interface
seekable.getLength() returns: (-1, 0)
RemovePopup, id = ZapError
eServiceApp::fillSubservices - failed to retrieve subservices, not supported url
PlayerBackend::gotMessage - tStart
PlayerApp::processStart: gstplayer_gst-1.0 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4" -d 0 -s 8192 -e 
[Skin] Processing screen: MoviePlayer
eServiceApp::getNumberOfTracks
PlayerBackend::gotMessage - tAudioList
WaitThread - waiting for 500ms
GstPlayer::handleJsonOutput - unhandled key "GSTPLAYER_EXTENDED"
PlayerBackend::recvStart - status = 0
PlayerBackend::recvAudioTrackSelected - status = 0, trackId = 0
WaitThread - in time

eServiceApp::getNumberOfTracks
PlayerBackend::gotMessage - tAudioList
WaitThread - waiting for 500ms
WaitThread - in time

[Skin] Processing screen: InfoBarMoviePlayerSummary
PlayerBackend::gotMessage - start
eServiceApp::gotExtPlayerMessage - start
eServiceApp::signalEventUpdatedInfo
eServiceApp::getNumberOfTracks
WaitThread - waiting for 500ms
PlayerBackend::gotMessage - tAudioList
WaitThread - in time

PlayerBackend::gotMessage - tSubtitleList
WaitThread - waiting for 500ms
WaitThread - timed out
eServiceApp::getSubtitleList - found embedded tracks (0)
eServiceApp::getSubtitleList - found external tracks (0)
eServiceApp::getCachedSubtitle - no subtitles available
 

And debug exteplayer3

playing 5002:0:0:0:0:0:0:0:0:0:/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4
ExtEplayer3::ExtEplayer3 initializing with options:
 aac_swdec                      = 0
 ac3_swdec                      = 1
 audio_id                       = not set
 audio_uri                      = not set
 dash_audio_id                  = not set
 dash_video_id                  = not set
 downmix                        = 1
 dts_swdec                      = 1
 eac3_swdec                     = 1
 ffmpeg_option                  = not set
 flv2mpeg4                      = not set
 live_ts                        = not set
 loop                           = not set
 lpcm_injection                 = 1
 mp3_swdec                      = 0
 mpegts_program_id              = not set
 nice                           = not set
 no_pcm_resampling              = not set
 progressive                    = not set
 rtmpproto                      = 0
 subtitle_id                    = not set
 wma_swdec                      = 1
eServiceApp::isCurrentlySeekable
resolved to PLAY
eServiceApp::unpause
eServiceApp::isCurrentlySeekable
new service started! trying to download cuts!
download failed, no cuesheet interface
seekable.getLength() returns: (-1, 0)
RemovePopup, id = ZapError
eServiceApp::fillSubservices - failed to retrieve subservices, not supported url
PlayerBackend::gotMessage - tStart
PlayerApp::processStart: exteplayer3 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4" -a 0 -3 -s -d -e -l -n 0 -w 
[Skin] Processing screen: MoviePlayer
PlayerBackend::recvStopped - retval = 0
PlayerBackend::thread_finished
eServiceApp::getNumberOfTracks
WaitThread - waiting for 500ms
WaitThread - in time

eServiceApp::getNumberOfTracks
[Skin] Processing screen: InfoBarMoviePlayerSummary
[Skin] Processing screen: MessageBoxSimple
warning, skin is missing element WarningPixmap in <class 'Screens.MessageBox.MessageBox'>(Resuming playback)
warning, skin is missing element autoresize in <class 'Screens.MessageBox.MessageBox'>(Resuming playback)
[Skin] Processing screen: MessageBoxSimple_summary
PlayerBackend::gotMessage - stop
eServiceApp::gotExtPlayerMessage - stop
eServiceApp::isCurrentlySeekable
resolved to PAUSE
eServiceApp::pause
Timeout!
eServiceApp::isCurrentlySeekable
eServiceApp::seekTo - position = 1017000
eServiceApp::seekTo - cannot get length

from telnet command

root@dm920:~# exteplayer3 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4" -a 0 -3 -s -d -e -l -n 0 -w
{"EPLAYER3_EXTENDED":{"version":52}}
Software decoder will be used for AAC codec
Software decoder will be used for AC3 codec
Software decoder will decode to stereo
Software decoder will be used for DTS codec
Software decoder will be used for EAC3 codec
Audio software decoding as LPCM
Force rtmp protocol implementation
Software decoder will be used for WMA codec
file: [file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4]
{"PLAYBACK_OPEN":{"OutputName":"Output", "file":"file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4", "sts":0}}
{"OUTPUT_OPEN":{"sts":-1}}
{"PLAYBACK_PLAY":{"sts":0}}
{"v_c":{"id":33,"e":"V_HEVC","n":"und","w":3840,"h":2160,"f":23976,"p":-1,"an":1,"ad":1}}
{"a_l": [{"id":35,"e":"A_LPCM","n":"und"}]}
{"a_c":{"id":35,"e":"A_LPCM","n":"und"}}
{"s_l": []}
{"s_c":{"id":-1,"e":"","n":""}}
{"log":"Frame read error: 'End of file'"}
 

Thank you


Edited by fairbird, 2 February 2019 - 09:31.

DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #892 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 2 February 2019 - 12:35

@fairbird

 

This file is not VP9. These is HEVC H265 file.


Edited by samsamsam, 2 February 2019 - 12:35.


Re: serviceapp - gstplayer and exteplayer3 #893 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 2 February 2019 - 14:09

Anyway it works for me on Zgemma H9S.

 

If this works for you via gstreamer but does not work via exteplayer3 there will be need to dump PES deata injected to the video0 decoder and compare them, to see where there is difference.

 

Please also try to play it as:


exteplayer3 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4"

 

When with option -e there is used software decoding of the EAC3, so maybe this is a problem.



Re: serviceapp - gstplayer and exteplayer3 #894 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 2 February 2019 - 14:25

Thank you sam ..

 

Here is out put

root@dm920:~# exteplayer3 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4"
{"EPLAYER3_EXTENDED":{"version":53}}
file: [file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4]
{"PLAYBACK_OPEN":{"OutputName":"Output", "file":"file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4", "sts":0}}
{"OUTPUT_OPEN":{"sts":0}}
{"PLAYBACK_PLAY":{"sts":0}}
{"v_c":{"id":33,"e":"V_HEVC","n":"und","w":3840,"h":2160,"f":23976,"p":-1,"an":1,"ad":1}}
{"a_l": [{"id":35,"e":"A_EAC3","n":"und"}]}
{"a_c":{"id":35,"e":"A_EAC3","n":"und"}}
{"s_l": []}
{"s_c":{"id":-1,"e":"","n":""}}

DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #895 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 2 February 2019 - 14:31

About VP9 .. Do you have direct link to test it on my dm920 ?!


DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #896 jenseneverest

  • Senior Member
  • 65 posts

+5
Neutral

Posted 2 February 2019 - 14:54

About VP9 .. Do you have direct link to test it on my dm920 ?!

https://kodi.wiki/view/Samples


Re: serviceapp - gstplayer and exteplayer3 #897 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 2 February 2019 - 15:28

VP9 Working with exteplayer3 on dm920 ..

Attached Files

  • Attached File  1.jpg   207.25KB   13 downloads

Edited by fairbird, 2 February 2019 - 15:29.

DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #898 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 2 February 2019 - 20:35

 

Thank you sam ..

 

Here is out put

root@dm920:~# exteplayer3 "/hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4"
{"EPLAYER3_EXTENDED":{"version":53}}
file: [file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4]
{"PLAYBACK_OPEN":{"OutputName":"Output", "file":"file:///hdd/movie/LG_2_DEMO_4K_O_H_1_Dolby Comparison_OLED.mp4", "sts":0}}
{"OUTPUT_OPEN":{"sts":0}}
{"PLAYBACK_PLAY":{"sts":0}}
{"v_c":{"id":33,"e":"V_HEVC","n":"und","w":3840,"h":2160,"f":23976,"p":-1,"an":1,"ad":1}}
{"a_l": [{"id":35,"e":"A_EAC3","n":"und"}]}
{"a_c":{"id":35,"e":"A_EAC3","n":"und"}}
{"s_l": []}
{"s_c":{"id":-1,"e":"","n":""}}

 

I wrote about PES stream data not about exteplayer3 output. There will be need to modify dvbmediasink and add code to dump PES data before wrote to video0.

Then it will dumps PES formatted data and we will be able to compare to see difference.

 

 

Another question

On which version of the exteplayer3 did you test VP9 on the dm920? On this one attached by me or on v53 from repo. 

Does VP9 works on gstreamer on your STB?

 

Because most probably I broken VP9 playback for DM in last v54 version.


Edited by samsamsam, 2 February 2019 - 20:39.


Re: serviceapp - gstplayer and exteplayer3 #899 fairbird

  • Senior Member
  • 413 posts

+20
Neutral

Posted 2 February 2019 - 22:00

About VP9 of course my friend I have tested with your file Version 53 in attach and with my built version 54 ...

​Both files works fine .. 

root@dm920:~# exteplayer3 -V
{"EPLAYER3_EXTENDED":{"version":54}}


DM500s
DM800

DM800se

DM920UHD


Re: serviceapp - gstplayer and exteplayer3 #900 samsamsam

  • Senior Member
  • 2,024 posts

+146
Excellent

Posted 3 February 2019 - 01:21

Hello @fairbird

 

Please re-try with attached exteplayer3  (v55)

Attached Files


Edited by samsamsam, 3 February 2019 - 01:21.




32 user(s) are reading this topic

0 members, 32 guests, 0 anonymous users