oksure-naver 0.1.1 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/CHANGELOG.rdoc CHANGED
@@ -1,9 +1,17 @@
1
+ == 0.2.1, release 2008-12-04
2
+
3
+ * converted class Naver to module Naver ("Naver.new" is no longer available) / 클래스에서 모듈로 구조 변경 ("Naver.new"는 더 이상 사용 불가)
4
+ * implemented method missing to use search target name as method / 메소드 미싱을 구현하여 검색 타겟을 메소드로 호출할 수 있게 함
5
+ * added abbreviation hash for passing arguments / 검색 조건 넘길 때 약어로 넘길 수 있게 함
6
+ * added Korean parts of readme and changelog files / readme와 changelog에 한글 부분 추가
7
+ * distributed on rubyforge.org as well (originally only available on github) / 루비포지에서도 배포 (원래는 github에만 있었음)
8
+
1
9
  == 0.1.1, release 2008-11-23
2
10
 
3
- * primitive 'request' method implemented
4
- * added init.rb
11
+ * primitive 'request' method implemented / 원시 'request' 메소드 구현
12
+ * added init.rb / init.rb 파일 추가
5
13
 
6
14
  == 0.0.1, release 2008-11-22
7
15
 
8
- * first commit
9
- * no classes, methods implemented
16
+ * first commit / 첫 번째 커밋
17
+ * no classes, methods implemented / 아직 아무 것도 안 했음
data/README.rdoc CHANGED
@@ -1,21 +1,53 @@
1
- = Naver
1
+ = Naver 0.2.1
2
2
 
3
3
  Ruby gem for using Naver OpenAPI (http://dev.naver.com/openapi/tutorial).
4
+ 네이버 OpenAPI를 위한 루비젬입니다.
4
5
 
5
6
 
6
- == Install
7
+ == IMPORTANT NOTE / 중요 공지
8
+
9
+ Since this is still in development stage, every method or usage may be deprecated in future versions without any prior notice. (I will try to keep track of changes in CHANGELOG.rdoc, though.)
10
+ Although I read the Rational Versioning Policy, I would change the middle number when some old codes might not work well with updates since Naver gem is still in development stage. When this gem considered stable, I will follow the RVP.
11
+ 현재 초기 작업 단계이기 때문에, 사전 공지 없이 모든 메소드나 사용법이 미래 버전에서는 사용하게 없게 될 수도 있습니다. (물론 CHANGELOG.rdoc에 변화 사항들을 기록하려고 노력은 하겠습니다만)
12
+ Rational Versioning Policy에 대해서 읽기는 했습니다만, 역시 아직 초기 개발 단계라서 과거 버전과 compatible하지 않은 버전을 릴리즈할 경우에 버전의 첫째 자리가 아닌 중간 자리 숫자를 변경할 생각입니다.
13
+
14
+
15
+ == Install / 설치법
7
16
 
8
17
  gem sources -a http://gems.github.com
9
18
  gem install oksure-naver
10
19
 
11
20
 
12
- == Usage
21
+ == Usage / 사용법
13
22
 
14
23
  Before using this gem, you need to get your own API key. To obtain your API key, see http://dev.naver.com/openapi/register.
24
+ 이 젬을 사용하기 전에 API 키를 발급 받으셔야 합니다. API 키 발급을 위해서는 http://dev.naver.com/openapi/register 링크를 참고해 주세요.
15
25
 
16
26
  require 'naver'
17
- naver = Naver.new(api_key) ### create a naver client
18
- naver.request("kin", "go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node
27
+ naver = Naver::Base.new(api_key) ### create a naver client / 네이버 클라이언트를 생성합니다
28
+ naver.request("kin", "go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node / libxml 형식의 노드로 루트 노드를 반환합니다
29
+ naver.kin("go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node / libxml 형식의 노드로 루트 노드를 반환합니다
30
+ naver.kin("go", {:d => "5", :start => "5", :so => "sim"}) ### It's possible to use abbreviation for each option / 검색 옵션을 넘길 때 약어를 사용 가능합니다
31
+
32
+
33
+ == Abbreviation List / 약어 목록
34
+
35
+ The full list of abbreviation codes is the following. (You can still use full name of each parameter.)
36
+ 약어 전체 목록을 아래에 정리하였습니다. (약어를 쓰지 않으셔도 작동합니다.)
37
+
38
+ d = display
39
+ st = start
40
+ so = sort
41
+ f = filter
42
+ p = payment
43
+ dt = d_titl
44
+ da = d_auth
45
+ dcon = d_cont
46
+ di = d_isbn
47
+ dp = d_publ
48
+ ddaf = d_dafr
49
+ ddat = d_dato
50
+ dcat = d_catg
19
51
 
20
52
 
21
53
  == License
data/Rakefile CHANGED
@@ -2,13 +2,13 @@ require 'rubygems'
2
2
  require 'rake'
3
3
  require 'echoe'
4
4
 
5
- Echoe.new('naver', '0.1.1') do |p|
6
- p.description = "Ruby Gem for Naver OpenAPI"
7
- p.url = "http://oksurerails.com/naver"
8
- p.author = "Hyunwoo Park"
9
- p.email = "hwpark@oksurerails.com"
10
- p.ignore_pattern = ["tmp/*", "script/*"]
11
- p.development_dependencies = ['libxml-ruby >=0.9.2']
5
+ Echoe.new('naver', '0.2.1') do |p|
6
+ p.description = "Ruby Gem for Naver OpenAPI"
7
+ p.url = "http://oksurerails.com/naver"
8
+ p.author = "Hyunwoo Park"
9
+ p.email = "hwpark@oksurerails.com"
10
+ p.ignore_pattern = ["tmp/*", "script/*"]
11
+ p.development_dependencies = ["libxml-ruby"]
12
12
  end
13
13
 
14
14
  Dir["#{File.dirname(__FILE__)}/tasks/*.rake"].sort.each { |ext| load ext }
data/lib/naver/base.rb ADDED
@@ -0,0 +1,47 @@
1
+ module Naver
2
+ include LibXML
3
+
4
+ class Base
5
+
6
+ attr_accessor :doc, :raw_xml
7
+
8
+ # Replace this API key with your own (see http://dev.naver.com/openapi/register)
9
+ def initialize(key=nil)
10
+ @key = key
11
+ @host = 'http://openapi.naver.com'
12
+ @api = '/search'
13
+ end
14
+
15
+ def method_missing(target, query, params={})
16
+ if METHOD_LIST.include?(target.to_s)
17
+ request(target, query, params)
18
+ else
19
+ raise NoMethod
20
+ end
21
+ end
22
+
23
+ # Takes a Naver API method name and set of parameters; returns an libxml object with the response
24
+ def request(target, query, params={})
25
+ response = http_get(request_url(target, query, params))
26
+ parser, parser.string = LibXML::XML::Parser.new, response
27
+ @raw_xml = parser.parse
28
+ @doc = @raw_xml.root
29
+ end
30
+
31
+ # Takes a Naver API method name and set of parameters; returns the correct URL for the REST API.
32
+ def request_url(target, query, params={})
33
+ url = "#{@host}#{@api}?key=#{@key}&target=#{target}&query=#{query}"
34
+ params.each do |key, value|
35
+ key = ABBREVIATION[key] unless ABBREVIATION[key].nil?
36
+ url += "&#{key}=" + CGI::escape(value)
37
+ end unless params.nil?
38
+ url
39
+ end
40
+
41
+ # Does an HTTP GET on a given URL and returns the response body
42
+ def http_get(url)
43
+ Net::HTTP.get_response(URI.parse(url)).body.to_s
44
+ end
45
+
46
+ end
47
+ end
data/lib/naver.rb CHANGED
@@ -9,40 +9,34 @@
9
9
  # require 'naver'
10
10
  # naver = Naver.new(api_key) ### create a naver client
11
11
  # naver.request("kin", "go", {:display => "5", :start => "1", :sort => "sim"}) ### return root node as libxml node
12
-
12
+ #
13
+ # To Do:
14
+ # local search implementation
13
15
 
14
16
  require "cgi"
15
17
  require "net/http"
16
- require "xml"
17
-
18
- class Naver
19
-
20
- # Replace this API key with your own (see http://dev.naver.com/openapi/register)
21
- def initialize(key=nil)
22
- @key = key
23
- @host = 'http://openapi.naver.com'
24
- @api = '/search'
25
- end
26
-
27
- # Takes a Naver API method name and set of parameters; returns an libxml object with the response
28
- def request(target, query, params={})
29
- response = http_get(request_url(target, query, params))
30
- parser = XML::Parser.new
31
- parser.string = response
32
- doc = parser.parse
33
- doc.root
34
- end
35
-
36
- # Takes a Naver API method name and set of parameters; returns the correct URL for the REST API.
37
- def request_url(target, query, params={})
38
- url = "#{@host}#{@api}?key=#{@key}&target=#{target}&query=#{query}"
39
- params.each { |key, value| url += "&#{key}=" + CGI::escape(value) } unless params.nil?
40
- url
41
- end
42
-
43
- # Does an HTTP GET on a given URL and returns the response body
44
- def http_get(url)
45
- Net::HTTP.get_response(URI.parse(url)).body.to_s
46
- end
18
+ require "libxml"
19
+
20
+ $:.unshift(File.join(File.dirname(__FILE__)))
21
+ require "naver/base"
22
+
23
+ module Naver
24
+ class NoMethod < StandardError; end
25
+
26
+ # Searches that returns results in RSS format
27
+ RSS_LIST = %w[kin video image doc book book_adv local shop encyc krdic endic jpdic blog cafe cafearticle webkr news]
28
+
29
+ # Searches that returns results in Non-RSS but XML format
30
+ XML_LIST = %w[rank rankthem recmd adult errata shortcut]
31
+
32
+ # Whole available search list
33
+ METHOD_LIST = RSS_LIST.concat(XML_LIST)
34
+
35
+ # Abbreviation for passing options
36
+ ABBREVIATION = {:d => :display, :st => :start, :so => :sort, :f => :filter, :p => :payment,
37
+ :dt => :d_titl, :da => :d_auth, :dco => :d_cont, :di => :d_isbn, :dp => :d_publ,
38
+ :ddaf => :d_dafr, :ddat => :d_dato, :dca => :d_catg}
47
39
 
40
+ SourceName = 'navergem'
41
+
48
42
  end
data/naver.gemspec CHANGED
@@ -2,15 +2,15 @@
2
2
 
3
3
  Gem::Specification.new do |s|
4
4
  s.name = %q{naver}
5
- s.version = "0.1.1"
5
+ s.version = "0.2.1"
6
6
 
7
7
  s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
8
8
  s.authors = ["Hyunwoo Park"]
9
- s.date = %q{2008-11-23}
9
+ s.date = %q{2008-12-04}
10
10
  s.description = %q{Ruby Gem for Naver OpenAPI}
11
11
  s.email = %q{hwpark@oksurerails.com}
12
- s.extra_rdoc_files = ["CHANGELOG.rdoc", "lib/naver.rb", "README.rdoc"]
13
- s.files = ["CHANGELOG.rdoc", "init.rb", "lib/naver.rb", "Manifest", "naver.gemspec", "nbproject/private/config.properties", "nbproject/private/private.properties", "nbproject/private/private.xml", "nbproject/private/rake-d.txt", "nbproject/project.properties", "nbproject/project.xml", "Rakefile", "README.rdoc"]
12
+ s.extra_rdoc_files = ["CHANGELOG.rdoc", "lib/naver/base.rb", "lib/naver.rb", "README.rdoc"]
13
+ s.files = ["CHANGELOG.rdoc", "init.rb", "lib/naver/base.rb", "lib/naver.rb", "Manifest", "rakefile", "README.rdoc", "Rakefile", "naver.gemspec"]
14
14
  s.has_rdoc = true
15
15
  s.homepage = %q{http://oksurerails.com/naver}
16
16
  s.rdoc_options = ["--line-numbers", "--inline-source", "--title", "Naver", "--main", "README.rdoc"]
@@ -24,11 +24,11 @@ Gem::Specification.new do |s|
24
24
  s.specification_version = 2
25
25
 
26
26
  if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
27
- s.add_development_dependency(%q<libxml-ruby>, [">= 0.9.2"])
27
+ s.add_development_dependency(%q<libxml-ruby>, [">= 0"])
28
28
  else
29
- s.add_dependency(%q<libxml-ruby>, [">= 0.9.2"])
29
+ s.add_dependency(%q<libxml-ruby>, [">= 0"])
30
30
  end
31
31
  else
32
- s.add_dependency(%q<libxml-ruby>, [">= 0.9.2"])
32
+ s.add_dependency(%q<libxml-ruby>, [">= 0"])
33
33
  end
34
34
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: oksure-naver
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Hyunwoo Park
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2008-11-23 00:00:00 -08:00
12
+ date: 2008-12-04 00:00:00 -08:00
13
13
  default_executable:
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
@@ -19,7 +19,7 @@ dependencies:
19
19
  requirements:
20
20
  - - ">="
21
21
  - !ruby/object:Gem::Version
22
- version: 0.9.2
22
+ version: "0"
23
23
  version:
24
24
  description: Ruby Gem for Naver OpenAPI
25
25
  email: hwpark@oksurerails.com
@@ -29,22 +29,19 @@ extensions: []
29
29
 
30
30
  extra_rdoc_files:
31
31
  - CHANGELOG.rdoc
32
+ - lib/naver/base.rb
32
33
  - lib/naver.rb
33
34
  - README.rdoc
34
35
  files:
35
36
  - CHANGELOG.rdoc
36
37
  - init.rb
38
+ - lib/naver/base.rb
37
39
  - lib/naver.rb
38
40
  - Manifest
39
- - naver.gemspec
40
- - nbproject/private/config.properties
41
- - nbproject/private/private.properties
42
- - nbproject/private/private.xml
43
- - nbproject/private/rake-d.txt
44
- - nbproject/project.properties
45
- - nbproject/project.xml
46
- - Rakefile
41
+ - rakefile
47
42
  - README.rdoc
43
+ - Rakefile
44
+ - naver.gemspec
48
45
  has_rdoc: true
49
46
  homepage: http://oksurerails.com/naver
50
47
  post_install_message: