aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Capabilities/Handlers/GetTexture/GetTextureRobustHandler.cs (unfollow)
Commit message (Collapse)AuthorFilesLines
2018-07-14some cleanupUbitUmarov1-30/+26
2018-03-10mantis 7885: robust asset services have no cache and only accept a asset ID ↵UbitUmarov1-68/+31
that is a uuid, so regions hack to cache several image formats is not possible. Robut GetTexture is very heavy unless image format is the default (j2k mime type x-j2k), since with no cache image convertions is performed on every request. Adicionally it does expose all textures if the tcp port is public. Avoid using it.
2017-05-06 dispose some MemoryStreamsUbitUmarov1-6/+0
2017-01-05Massive tab and trailing space cleanupMelanie Thielker1-48/+48
2016-12-26robust textures add missing returns or redir caseUbitUmarov1-0/+2
2016-08-22workaround potencial memory leakUbitUmarov1-17/+21
2015-10-14Fixed Robust-bound GetTexture handler that had been knocked off with the new ↵Diva Canto1-155/+156
sim-bound handler that uses a Poll service. Rather than hammering both handlers into one single class, I'm splitting them into 2 classes, because they are considerably different.
2015-09-02seems to compile ( tests comented out)UbitUmarov1-3/+0
2015-08-24 turn off KeepAliveUbitUmarov1-2/+2
2015-08-18do keepalive on mesh and texture GET. Dont use reusecontext any where.UbitUmarov1-2/+2
setting of keepalive is wrong, it should follow the requested one ( or always as http1.1) only deny if needed (errors). KeepAlive may increase stress on number of avaiable file descritors.
2014-05-08Fix test breakageDiva Canto1-1/+1
2014-05-08Make the URL for texture redirects match the path of the resource that we ↵Diva Canto1-1/+1
use in OpenSim.
2014-05-07Finished implementing redirects in GetTexture.Diva Canto1-4/+8
2013-11-15refactor: replace verbose checks with String.IsNullOrEmpty where applicable.Justin Clark-Casey (justincc)1-1/+1
Thanks to Kira for this patch from http://opensimulator.org/mantis/view.php?id=6845
2013-07-08Add "show caps stats by user" and "show caps stats by cap" console commands ↵Justin Clark-Casey (justincc)1-1/+1
to print various counts of capability invocation by user and by cap This currently prints caps requests received and handled, so that overload of received compared to handled or deadlock can be detected. This involves making BaseStreamHandler and BaseOutputStream record the ints, which means inheritors should subclass ProcessRequest() instead of Handle() However, existing inheriting classes overriding Handle() will still work, albeit without stats recording. "show caps" becomes "show caps list" to disambiguate between show caps commands
2013-06-10Remove Temporary from use to shortcut asset stores. The Local propertyMic Bowman1-0/+1
differentiates between local & grid storage. The Temporary property just says that which service handles the it, the asset can be safely removed in the future.
2013-01-21* A better way to handle the last fix (This is in case the viewer provides a ↵teravus1-10/+16
list of preferred formats, though, technically, the sim would pick the first provided format the old way). This just makes it more obvious what's happening.
2013-01-21* The fallthrough of FetchTexture was no longer resulting in a 404 response ↵teravus1-1/+10
on missing textures. It was just waiting and no event was being provided. This re-enables the 404 response.
2012-12-06minor: change method doc on GetTextureHandler.TryParseRange(), mainly to ↵Justin Clark-Casey (justincc)1-2/+2
trigger another build
2012-12-06Allow GetTexture calls with no second value in the range header (e.g. just ↵Justin Clark-Casey (justincc)1-1/+34
5333-) It looks like the latest Kokua is doing this. As per http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html, leaving off the second value is legal This indicates the caller wants the rest of the entity.
2012-11-15Revert "Merge master into teravuswork", it should have been avination, not ↵teravus1-16/+2
master. This reverts commit dfac269032300872c4d0dc507f4f9062d102b0f4, reversing changes made to 619c39e5144f15aca129d6d999bcc5c34133ee64.
2012-11-05Another step in the chain. Pipe the throttle update to the appropriate ↵teravus1-1/+5
PollServiceTextureEventArgs. Each poll service having it's own throttle member is more consistent with the model then the region module keeping track of all of them globally and better for locking too. The Poll Services object is not set static to handle multiple nearby regions on the same simulator. Next step is hooking it up to HasEvents
2012-10-12minor: Comment out "Client requested range for texture ... but" message. ↵Justin Clark-Casey (justincc)1-3/+3
This is not useful during normal operation.
2012-09-26 don't send a partial contents report if we are sending all dataUbitUmarov1-10/+15
2012-09-26 fix GetTextureHandler rangeUbitUmarov1-1/+5
2012-09-14Revamp the HTTP textures handler to allow a maximum of four fetchesMelanie1-94/+73
at any time and to drop requests for avatars n longer in the scene
2012-09-06If the GetTexture capability receives a request for a range of data beyond ↵Justin Clark-Casey (justincc)1-5/+29
that of an otherwise valid asset, return HTTP PartialContent rather than RequestedRangeNotSatisfiable. This is because recent viewers (3.2.1, 3.3.4) and probably earlier ones using the http GetTexture capability will sometimes make such invalid range requests. This appears to happen if the viewer's estimate of texture sizes at discard levels > 0 (chiefly 2) exceeds the total texture size. I believe this does not normally happen but can occur for dynamic textures with are large but mainly blank. If this happens, returning a RequestedRangeNotSatisfiable will cause the viewer to not render the texture at the final resolution. However, returning a PartialContent (or OK) even with 0 data will allow the viewer to render the final texture.
2012-07-06Changed GetTexture error code RequestedRangeNotSatisfiable to NotFound, ↵UbitUmarov1-1/+3
since viewers don't seem to handle that and keep retrying
2012-06-13Don't include time to transmit response back to requester when assessing ↵Justin Clark-Casey (justincc)1-2/+0
slow handling of requests. This is to avoid logging a 'slow' request when the source of delay is the viewer in processing a response. This is not something we can do much about on the server end - it's server-side delay that we're interested in. To ensure consistency, this commit also had to refactor and simplify inbound non-poll network request handling, though there should be no functional change. IOSHttpResponse no longer exposes the Send() method, only classes in OpenSim.Framework.Servers.HttpServer should be doing this. Only the GetTextureHandler was sending its own response. Now it leaves this to BaseHttpServer, like all other core handlers.
2012-05-03Implement optional name and description on http stream handlers so that we ↵Justin Clark-Casey (justincc)1-2/+2
can relate a slow request to what the handler actually does and the agent it serves, if applicable. This is most useful for capabilities where the url is not self-describing.
2011-12-09Add commented log lines to FetchInventoryDescendents2 path for future use.Justin Clark-Casey (justincc)1-3/+9
Haven't been able to resolve issue where attachments are removed by the viewer on relog on a localhost
2011-12-05Implement IOSHttpRequest and IOSHttpResponse http interfaces and use instead ↵Justin Clark-Casey (justincc)1-3/+3
of OSHttpRequest/OSHttpResponse. This is required for the substitution of different HTTP servers or the newer HttpServer.dll without having to commit to a particular implementation. This is also required to write regression tests that involve the HTTP layer. If you need to recompile, all you need to do is replace OSHttpRequest/OSHttpResponse references with IOSHttpRequest/IOSHttpResponse.
2011-12-05For the GetTexture capability, if a data range is requested that covers the ↵Justin Clark-Casey (justincc)1-14/+25
whole asset length, return HTTP PartialContent instead of NotFound NotFound is obviously wrong, and this change stops viewer 3.2.2 (and v probably earlier) complaining in the log about missing textures that are actually present. We still return PartialContent even if the range requested is a superset of the data range as per httpd's behaviour https://issues.apache.org/bugzilla/show_bug.cgi?id=51878 Viewer 3.2.2 and very probably earlier appear happy with this. Whether fixing this NotFound bug has any practical effect apart from resolve viewer log messages is unknown.
2011-12-01refactor: Separate the upload baked texture handler out from BunchOfCapsJustin Clark-Casey (justincc)1-3/+1
2011-09-09Save the default terrain texture UUIDs for a new region instead of leaving ↵Justin Clark-Casey (justincc)1-3/+2
them as UUID.Zero. Leaving them at UUID.Zero meant that when a viewer 2 logged into a region that had been freshly created, it received UUID.Zero for these textures, and hence display the land as plain white. On a simulator restart, the problem would go away since when the database adapators loaded the new region settings, RegionSettings itself has code to use default textures instead of UUID.Zero. This commit resolves the problem by saving the default texture UUIDs instead of Zero. However, we currently have to do this in a roundabout way by resaving once the RegionSettings have been created by the database for the first time. This needless complexity should be addressed. This change will also have the effect of replacing any existing UUID.Zero terrain textures with the default ones. However, this shouldn't have any effect since the UUID.Zeros were already being replaced in memory with those same UUIDs.
2011-05-08Comment verbose debug message in GetTextureDiva Canto1-1/+1
2011-05-02Refactored the GetMesh module into a handler and a module, to be the same as ↵Diva Canto1-0/+0
GetTexture.
2011-05-02Works!Diva Canto1-1/+2
2011-05-01Added OpenSim.Capabilities.Handlers. For the moment it has only the ↵Diva Canto1-54/+6
GetTexture handler. The region module in Linden space uses it. WARNING: nothing of this works yet, it just compiles.
2011-04-30Nope, that didn't feel right. Moving all those modules to Linden space.Diva Canto1-1/+3
2011-04-30Moved several cap-based-service-providing modules from where they were into ↵Diva Canto1-1/+1
a newly created CoreModules/Caps. Not all.
2011-02-02Comment out texture CAPS 'texture not found' message for nowJustin Clark-Casey (justincc)1-3/+1
2011-01-18Prune some of the excess logging for client logins.Justin Clark-Casey (justincc)1-2/+2
Didn't touch the appearance related stuff.
2010-12-08Fixed wrong commentDiva Canto1-1/+1
2010-12-08Fixed previous compile error -- I haven't pushed the CreatorID in AssetBase ↵Diva Canto1-1/+1
yet...
2010-12-08Added ability for GetTexture to serve multiple formats. The format may come ↵Diva Canto1-42/+202
as an extra query parameter in the URL format=<format> (this was tested and working) or it may come in the Accept header (code added, but not tested). The result of the conversion is placed in the asset cache, under the name <uuid>-<format>.
2010-10-09Fix a typo in previouis commit: start must not pass the end of the fileLatif Khalifa1-2/+2
2010-10-09weird line endings fix commitTeravus Ovares (Dan Olivares)1-7/+7
2010-10-09Return error code instead of the last byte of the file if range is not ↵Latif Khalifa1-1/+9
satisfiable
2010-10-09In case when 1 single byte is requested (yes viewer does this)Latif Khalifa1-2/+2
start of the ranges gets clamped with a wrong value. In case of a texture with 601 byte long texture the viewer request range 0-599 first, then 600- in which case both start and end should be 600. End can also be 0, valid request for the firt byte of the file is 0-0. Thanks to Thickbrick for explaining how HTTP range header works.