XmlResolver.cs 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. //
  2. // System.Xml.XmlResolver.cs
  3. //
  4. // Author:
  5. // Jason Diamond ([email protected])
  6. // Atsushi Enomoto ([email protected])
  7. //
  8. // (C) 2001 Jason Diamond http://injektilo.org/
  9. // (C) 2004 Novell Inc.
  10. //
  11. //
  12. // Permission is hereby granted, free of charge, to any person obtaining
  13. // a copy of this software and associated documentation files (the
  14. // "Software"), to deal in the Software without restriction, including
  15. // without limitation the rights to use, copy, modify, merge, publish,
  16. // distribute, sublicense, and/or sell copies of the Software, and to
  17. // permit persons to whom the Software is furnished to do so, subject to
  18. // the following conditions:
  19. //
  20. // The above copyright notice and this permission notice shall be
  21. // included in all copies or substantial portions of the Software.
  22. //
  23. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  27. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  28. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  29. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  30. //
  31. using System;
  32. using System.IO;
  33. using System.Net;
  34. namespace System.Xml
  35. {
  36. public abstract class XmlResolver
  37. {
  38. #if NET_2_0
  39. public virtual XmlNameTable NameTable {
  40. get { return null; }
  41. }
  42. #endif
  43. public abstract ICredentials Credentials { set; }
  44. public abstract object GetEntity (
  45. Uri absoluteUri,
  46. string role,
  47. Type type);
  48. public virtual Uri ResolveUri (Uri baseUri, string relativeUri)
  49. {
  50. if (baseUri == null) {
  51. if (relativeUri == null)
  52. throw new ArgumentException ("Either baseUri or relativeUri are required.");
  53. // Don't ignore such case that relativeUri is in fact absolute uri (e.g. ResolveUri (null, "http://foo.com")).
  54. if (relativeUri.StartsWith ("http:") ||
  55. relativeUri.StartsWith ("https:") ||
  56. relativeUri.StartsWith ("file:"))
  57. return new Uri (relativeUri);
  58. else
  59. // extraneous "/a" is required because current Uri stuff
  60. // seems ignorant of difference between "." and "./".
  61. // I'd be appleciate if it is fixed with better solution.
  62. return new Uri (Path.GetFullPath (relativeUri));
  63. // return new Uri (new Uri (Path.GetFullPath ("./a")), EscapeRelativeUriBody (relativeUri));
  64. }
  65. if (relativeUri == null)
  66. return baseUri;
  67. return new Uri (baseUri, EscapeRelativeUriBody (relativeUri));
  68. }
  69. // see also XmlUrlResolver.UnescapeRelativeUriBody().
  70. private string EscapeRelativeUriBody (string src)
  71. {
  72. return src.Replace ("<", "%3C")
  73. .Replace (">", "%3E")
  74. .Replace ("#", "%23")
  75. .Replace ("%", "%25")
  76. .Replace ("\"", "%22");
  77. }
  78. }
  79. }